summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rwxr-xr-xtest/functional/basic.rb11
-rw-r--r--test/functional/word_list.rb2
-rw-r--r--test/scanners/coderay_suite.rb27
3 files changed, 32 insertions, 8 deletions
diff --git a/test/functional/basic.rb b/test/functional/basic.rb
index 2da85e6..5e0e759 100755
--- a/test/functional/basic.rb
+++ b/test/functional/basic.rb
@@ -25,19 +25,26 @@ class BasicTest < Test::Unit::TestCase
def test_duo
assert_equal(RUBY_TEST_CODE,
CodeRay::Duo[:plain, :plain].highlight(RUBY_TEST_CODE))
+ assert_equal(RUBY_TEST_CODE,
+ CodeRay::Duo[:plain => :plain].highlight(RUBY_TEST_CODE))
+ end
+
+ def test_duo_stream
+ assert_equal(RUBY_TEST_CODE,
+ CodeRay::Duo[:plain, :plain].highlight(RUBY_TEST_CODE, :stream => true))
end
ENCODERS_LIST = %w(
count debug div html null page span statistic text tokens xml yaml
)
- def test_list_of_encoders
+ def _test_list_of_encoders
assert_equal(ENCODERS_LIST, CodeRay::Encoders.list.sort)
end
SCANNERS_LIST = %w(
c debug delphi html nitro_xhtml plaintext rhtml ruby xml
)
- def test_list_of_scanners
+ def _test_list_of_scanners
assert_equal(SCANNERS_LIST, CodeRay::Scanners.list.sort)
end
diff --git a/test/functional/word_list.rb b/test/functional/word_list.rb
index c710d77..0ef275a 100644
--- a/test/functional/word_list.rb
+++ b/test/functional/word_list.rb
@@ -2,6 +2,8 @@ require "test/unit"
require "coderay"
class WordListTest < Test::Unit::TestCase
+
+ include CodeRay
# define word arrays
RESERVED_WORDS = %w[
diff --git a/test/scanners/coderay_suite.rb b/test/scanners/coderay_suite.rb
index 82236c9..9ca0128 100644
--- a/test/scanners/coderay_suite.rb
+++ b/test/scanners/coderay_suite.rb
@@ -13,8 +13,10 @@ rescue LoadError
begin
require 'rubygems'
require_gem 'term-ansicolor'
+ rescue LoadError
+ # ignore
end
-end
+end unless ENV['nocolor']
if defined? Term::ANSIColor
class String
@@ -35,7 +37,6 @@ $DEBUG = debug
unless defined? Term::ANSIColor
puts 'You should gem install term-ansicolor.'
- sleep 2
end
# from Ruby Facets (http://facets.rubyforge.org/)
@@ -168,7 +169,7 @@ module CodeRay
for example_filename in Dir["*.#{extension}"]
name = File.basename(example_filename, ".#{extension}")
next if ENV['example'] and ENV['example'] != name
- print ('%15s'.cyan + ' %4.0fK: '.yellow) %
+ print name_and_size = ('%15s'.cyan + ' %4.0fK: '.yellow) %
[ name, File.size(example_filename) / 1024.0 ]
time_for_file = Benchmark.realtime do
example_test example_filename, name, scanner, max
@@ -195,7 +196,9 @@ module CodeRay
end
tokens = compare_test scanner, code, name
-
+
+ identity_test scanner, tokens
+
unless ENV['nohl'] or code.size > MAX_CODE_SIZE_TO_HIGHLIGHT
highlight_test tokens, name
else
@@ -274,6 +277,15 @@ module CodeRay
tokens
end
+ def identity_test scanner, tokens
+ print 'identity...'.red
+ unless scanner.instance_of? CodeRay::Scanners[:debug]
+ assert_equal scanner.code, tokens.text
+ end
+ print "\b\b\b"
+ print ', '.red
+ end
+
def highlight_test tokens, name
print 'highlighting, '.red
highlighted = Highlighter.encode_tokens tokens
@@ -307,10 +319,13 @@ module CodeRay
end
def load
- if subsuite = ARGV.find { |a| break $1 if a[/^([^-].*)/] } || ENV['lang']
+ subsuite = ARGV.find { |a| break $& if a[/^[^-].*/] } || ENV['lang']
+ if subsuite
load_suite(subsuite) or exit
else
- Dir[File.join($mydir, '*', '')].sort.each { |suite| load_suite File.basename(suite) }
+ Dir[File.join($mydir, '*', '')].sort.each do |suite|
+ load_suite File.basename(suite)
+ end
end
end