Refactoring tests out into separate files.
This commit is contained in:
parent
e506c5172a
commit
6aa2217706
2
Rakefile
2
Rakefile
@ -16,7 +16,7 @@ end
|
|||||||
|
|
||||||
desc 'Run tests (default)'
|
desc 'Run tests (default)'
|
||||||
Rake::TestTask.new(:test) do |t|
|
Rake::TestTask.new(:test) do |t|
|
||||||
t.test_files = FileList['test/*_test.rb']
|
t.test_files = FileList['test/suite.rb']
|
||||||
t.ruby_opts = ['-rubygems'] if defined? Gem
|
t.ruby_opts = ['-rubygems'] if defined? Gem
|
||||||
end
|
end
|
||||||
|
|
||||||
|
23
test/helper.rb
Normal file
23
test/helper.rb
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
rootdir = File.dirname(File.dirname(__FILE__))
|
||||||
|
$LOAD_PATH.unshift "#{rootdir}/lib"
|
||||||
|
|
||||||
|
require 'test/unit'
|
||||||
|
begin; require 'turn'; rescue LoadError; end
|
||||||
|
begin
|
||||||
|
require 'rdiscount'
|
||||||
|
rescue LoadError
|
||||||
|
if !defined?(Gem)
|
||||||
|
require 'rubygems'
|
||||||
|
retry
|
||||||
|
end
|
||||||
|
end
|
||||||
|
require 'rocco'
|
||||||
|
|
||||||
|
def roccoize( filename, contents, options = {} )
|
||||||
|
Rocco.new( filename, [ filename ], options ) {
|
||||||
|
contents
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
# Send STDERR into the void to suppress program output messages
|
||||||
|
STDERR.reopen(test(?e, '/dev/null') ? '/dev/null' : 'NUL:')
|
@ -1,267 +0,0 @@
|
|||||||
rootdir = File.dirname(File.dirname(__FILE__))
|
|
||||||
$LOAD_PATH.unshift "#{rootdir}/lib"
|
|
||||||
|
|
||||||
require 'test/unit'
|
|
||||||
begin; require 'turn'; rescue LoadError; end
|
|
||||||
begin
|
|
||||||
require 'rdiscount'
|
|
||||||
rescue LoadError
|
|
||||||
if !defined?(Gem)
|
|
||||||
require 'rubygems'
|
|
||||||
retry
|
|
||||||
end
|
|
||||||
end
|
|
||||||
require 'rocco'
|
|
||||||
|
|
||||||
def roccoize( filename, contents, options = {} )
|
|
||||||
Rocco.new( filename, [ filename ], options ) {
|
|
||||||
contents
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
class RoccoBasicTests < Test::Unit::TestCase
|
|
||||||
def test_rocco_exists_and_is_instancable
|
|
||||||
roccoize( "filename.rb", "# Comment 1\ndef codeblock\nend\n" )
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_filename
|
|
||||||
r = roccoize( "filename.rb", "# Comment 1\ndef codeblock\nend\n" )
|
|
||||||
assert_equal "filename.rb", r.file
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_sources
|
|
||||||
r = roccoize( "filename.rb", "# Comment 1\ndef codeblock\nend\n" )
|
|
||||||
assert_equal [ "filename.rb" ], r.sources
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_sections
|
|
||||||
r = roccoize( "filename.rb", "# Comment 1\ndef codeblock\nend\n" )
|
|
||||||
assert_equal 1, r.sections.length
|
|
||||||
assert_equal 2, r.sections[ 0 ].length
|
|
||||||
assert_equal "<p>Comment 1</p>\n", r.sections[ 0 ][ 0 ]
|
|
||||||
assert_equal "<span class=\"k\">def</span> <span class=\"nf\">codeblock</span>\n<span class=\"k\">end</span>", r.sections[ 0 ][ 1 ]
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_parsing
|
|
||||||
r = Rocco.new( 'test' ) { "" } # Generate throwaway instance so I can test `parse`
|
|
||||||
assert_equal(
|
|
||||||
[
|
|
||||||
[ [ "# Comment 1" ], [ "def codeblock", "end" ] ]
|
|
||||||
],
|
|
||||||
r.parse( "# Comment 1\ndef codeblock\nend\n" )
|
|
||||||
)
|
|
||||||
assert_equal(
|
|
||||||
[
|
|
||||||
[ [ "# Comment 1" ], [ "def codeblock" ] ],
|
|
||||||
[ [ "# Comment 2" ], [ "end" ] ]
|
|
||||||
],
|
|
||||||
r.parse( "# Comment 1\ndef codeblock\n# Comment 2\nend\n" )
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_splitting
|
|
||||||
r = Rocco.new( 'test' ) { "" } # Generate throwaway instance so I can test `split`
|
|
||||||
assert_equal(
|
|
||||||
[
|
|
||||||
[ "Comment 1" ],
|
|
||||||
[ "def codeblock\nend" ]
|
|
||||||
],
|
|
||||||
r.split([ [ [ "# Comment 1" ], [ "def codeblock", "end" ] ] ])
|
|
||||||
)
|
|
||||||
assert_equal(
|
|
||||||
[
|
|
||||||
[ "Comment 1", "Comment 2" ],
|
|
||||||
[ "def codeblock", "end" ]
|
|
||||||
],
|
|
||||||
r.split( [
|
|
||||||
[ [ "# Comment 1" ], [ "def codeblock" ] ],
|
|
||||||
[ [ "# Comment 2" ], [ "end" ] ]
|
|
||||||
] )
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
class RoccoSkippableLines < Test::Unit::TestCase
|
|
||||||
def test_shebang_first_line
|
|
||||||
r = Rocco.new( 'filename.sh' ) { "" }
|
|
||||||
assert_equal(
|
|
||||||
[
|
|
||||||
[ [ "# Comment 1" ], [ "def codeblock" ] ],
|
|
||||||
[ [ "# Comment 2" ], [ "end" ] ]
|
|
||||||
],
|
|
||||||
r.parse( "#!/usr/bin/env bash\n# Comment 1\ndef codeblock\n# Comment 2\nend\n" ),
|
|
||||||
"Shebang should be stripped when it appears as the first line."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
def test_shebang_in_content
|
|
||||||
r = Rocco.new( 'filename.sh' ) { "" }
|
|
||||||
assert_equal(
|
|
||||||
[
|
|
||||||
[ [ "# Comment 1", "#!/usr/bin/env bash" ], [ "def codeblock" ] ],
|
|
||||||
[ [ "# Comment 2" ], [ "end" ] ]
|
|
||||||
],
|
|
||||||
r.parse( "# Comment 1\n#!/usr/bin/env bash\ndef codeblock\n# Comment 2\nend\n" ),
|
|
||||||
"Shebang shouldn't be stripped anywhere other than as the first line."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
def test_encoding_in_ruby
|
|
||||||
r = Rocco.new( 'filename.rb' ) { "" }
|
|
||||||
assert_equal(
|
|
||||||
[
|
|
||||||
[ [ "# Comment 1" ], [ "def codeblock" ] ],
|
|
||||||
[ [ "# Comment 2" ], [ "end" ] ]
|
|
||||||
],
|
|
||||||
r.parse( "#!/usr/bin/env bash\n# encoding: utf-8\n# Comment 1\ndef codeblock\n# Comment 2\nend\n" ),
|
|
||||||
"Strings matching the PEP 263 encoding definition regex should be stripped when they appear at the top of a python document."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
def test_encoding_in_python
|
|
||||||
r = Rocco.new( 'filename.py' ) { "" }
|
|
||||||
assert_equal(
|
|
||||||
[
|
|
||||||
[ [ "# Comment 1" ], [ "def codeblock" ] ],
|
|
||||||
[ [ "# Comment 2" ], [ "end" ] ]
|
|
||||||
],
|
|
||||||
r.parse( "#!/usr/bin/env bash\n# encoding: utf-8\n# Comment 1\ndef codeblock\n# Comment 2\nend\n" ),
|
|
||||||
"Strings matching the PEP 263 encoding definition regex should be stripped when they appear at the top of a python document."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
def test_encoding_in_notpython
|
|
||||||
r = Rocco.new( 'filename.sh' ) { "" }
|
|
||||||
assert_equal(
|
|
||||||
[
|
|
||||||
[ [ "# encoding: utf-8", "# Comment 1" ], [ "def codeblock" ] ],
|
|
||||||
[ [ "# Comment 2" ], [ "end" ] ]
|
|
||||||
],
|
|
||||||
r.parse( "#!/usr/bin/env bash\n# encoding: utf-8\n# Comment 1\ndef codeblock\n# Comment 2\nend\n" ),
|
|
||||||
"Strings matching the PEP 263 encoding definition regex should be stripped when they appear at the top of a python document."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
class RoccoLanguageDetection < Test::Unit::TestCase
|
|
||||||
def test_basic_detection
|
|
||||||
r = Rocco.new( 'filename.py' ) { "" }
|
|
||||||
if r.pygmentize?
|
|
||||||
assert_equal "python", r.detect_language(), "`detect_language()` should return the correct language"
|
|
||||||
assert_equal "python", r.options[:language], "`@options[:language]` should be set to the correct language"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
def test_fallback_default
|
|
||||||
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever' ) { "" }
|
|
||||||
if r.pygmentize?
|
|
||||||
assert_equal "text", r.detect_language(), "`detect_language()` should return `text` when nothing else is detected"
|
|
||||||
assert_equal "ruby", r.options[:language], "`@options[:language]` should be set to `ruby` when nothing else is detected"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
def test_fallback_user
|
|
||||||
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever', '', { :language => "c" } ) { "" }
|
|
||||||
if r.pygmentize?
|
|
||||||
assert_equal "text", r.detect_language(), "`detect_language()` should return `text` nothing else is detected"
|
|
||||||
assert_equal "c", r.options[:language], "`@options[:language]` should be set to the user's setting when nothing else is detected"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
class RoccoAutomaticCommentChars < Test::Unit::TestCase
|
|
||||||
def test_basic_detection
|
|
||||||
r = Rocco.new( 'filename.js' ) { "" }
|
|
||||||
assert_equal "//", r.options[:comment_chars]
|
|
||||||
end
|
|
||||||
def test_fallback_language
|
|
||||||
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever', '', { :language => "js" } ) { "" }
|
|
||||||
assert_equal "//", r.options[:comment_chars]
|
|
||||||
end
|
|
||||||
def test_fallback_default
|
|
||||||
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever' ) { "" }
|
|
||||||
assert_equal "#", r.options[:comment_chars], "`:comment_chars` should be `#` when falling back to defaults."
|
|
||||||
end
|
|
||||||
def test_fallback_user
|
|
||||||
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever', '', { :comment_chars => "user" } ) { "" }
|
|
||||||
assert_equal "user", r.options[:comment_chars], "`:comment_chars` should be the user's default when falling back to user-provided settings."
|
|
||||||
end
|
|
||||||
def test_fallback_user_with_unknown_language
|
|
||||||
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever', '', { :language => "not-a-language", :comment_chars => "user" } ) { "" }
|
|
||||||
assert_equal "user", r.options[:comment_chars], "`:comment_chars` should be the user's default when falling back to user-provided settings."
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
class RoccoIssueTests < Test::Unit::TestCase
|
|
||||||
def test_issue07_incorrect_parsing_in_c_mode
|
|
||||||
# Precursor to issue #13 below, Rocco incorrectly parsed C/C++
|
|
||||||
# http://github.com/rtomayko/rocco/issues#issue/7
|
|
||||||
r = Rocco.new( 'issue7.c', [], { :language => 'c' } ) {
|
|
||||||
"// *stdio.h* declares *puts*\n#include <stdio.h>\n\n//### code hello world\n\n// every C program contains function *main*.\nint main (int argc, char *argv[]) {\n puts('hello world');\n return 0;\n}\n\n// that's it!"
|
|
||||||
}
|
|
||||||
r.sections.each do | section |
|
|
||||||
if not section[1].nil?
|
|
||||||
assert(
|
|
||||||
!section[1].include?("<span class=\"c\"># DIVIDER</span>"),
|
|
||||||
"`# DIVIDER` present in code text, which means the highligher screwed up somewhere."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
def test_issue10_utf8_processing
|
|
||||||
# Rocco has issues with strange UTF-8 characters: need to explicitly set the encoding for Pygments
|
|
||||||
# http://github.com/rtomayko/rocco/issues#issue/10
|
|
||||||
r = Rocco.new( File.dirname(__FILE__) + "/fixtures/issue10.utf-8.rb" )
|
|
||||||
assert_equal(
|
|
||||||
"<p>hello ąćęłńóśźż</p>\n",
|
|
||||||
r.sections[0][0],
|
|
||||||
"UTF-8 input files ought behave correctly."
|
|
||||||
)
|
|
||||||
# and, just for grins, ensure that iso-8859-1 works too.
|
|
||||||
# @TODO: Is this really the correct behavior? Converting text
|
|
||||||
# to UTF-8 on the way out is probably preferable.
|
|
||||||
r = Rocco.new( File.dirname(__FILE__) + "/fixtures/issue10.iso-8859-1.rb" )
|
|
||||||
assert_equal(
|
|
||||||
"<p>hello w\366rld</p>\n",
|
|
||||||
r.sections[0][0],
|
|
||||||
"ISO-8859-1 input should probably also behave correctly."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
def test_issue12_css_octothorpe_classname_change
|
|
||||||
# Docco changed some CSS classes. Rocco needs to update its default template.
|
|
||||||
# http://github.com/rtomayko/rocco/issues#issue/12
|
|
||||||
r = Rocco.new( 'issue12.sh' ) {
|
|
||||||
"# Comment 1\n# Comment 1\nprint 'omg!'"
|
|
||||||
}
|
|
||||||
html = r.to_html
|
|
||||||
assert(
|
|
||||||
!html.include?( "<div class=\"octowrap\">" ),
|
|
||||||
"`octowrap` wrapper is present in rendered HTML. This ought be replaced with `pilwrap`."
|
|
||||||
)
|
|
||||||
assert(
|
|
||||||
!html.include?( "<a class=\"octothorpe\" href=\"#section-1\">" ),
|
|
||||||
"`octothorpe` link is present in rendered HTML. This ought be replaced with `pilcrow`."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
def test_issue13_incorrect_code_divider_parsing
|
|
||||||
# In `bash` mode (among others), the comment class is `c`, not `c1`.
|
|
||||||
# http://github.com/rtomayko/rocco/issues#issue/13
|
|
||||||
r = Rocco.new( 'issue13.sh', [], { :language => 'bash' } ) {
|
|
||||||
"# Comment 1\necho 'code';\n# Comment 2\necho 'code';\n# Comment 3\necho 'code';\n"
|
|
||||||
}
|
|
||||||
r.sections.each do | section |
|
|
||||||
if not section[1].nil?
|
|
||||||
assert(
|
|
||||||
!section[1].include?("<span class=\"c\"># DIVIDER</span>"),
|
|
||||||
"`# DIVIDER` present in code text, which means the highligher screwed up somewhere."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
def test_issue15_extra_space_after_comment_character_remains
|
|
||||||
# After the comment character, a single space should be removed.
|
|
||||||
# http://github.com/rtomayko/rocco/issues#issue/15
|
|
||||||
r = Rocco.new( 'issue15.sh') {
|
|
||||||
"# Comment 1\n# ---------\necho 'code';"
|
|
||||||
}
|
|
||||||
assert(
|
|
||||||
!r.sections[0][0].include?( "<hr />" ),
|
|
||||||
"`<hr />` present in rendered documentation text. It should be a header, not text followed by a horizontal rule."
|
|
||||||
)
|
|
||||||
assert_equal( "<h2>Comment 1</h2>\n", r.sections[0][0] )
|
|
||||||
end
|
|
||||||
end
|
|
6
test/suite.rb
Normal file
6
test/suite.rb
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
require 'test/unit'
|
||||||
|
|
||||||
|
tests = Dir["#{File.dirname(__FILE__)}/test_*.rb"]
|
||||||
|
tests.each do |file|
|
||||||
|
require file
|
||||||
|
end
|
64
test/test_basics.rb
Normal file
64
test/test_basics.rb
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
require File.dirname(__FILE__) + '/helper'
|
||||||
|
|
||||||
|
class RoccoBasicTests < Test::Unit::TestCase
|
||||||
|
def test_rocco_exists_and_is_instancable
|
||||||
|
roccoize( "filename.rb", "# Comment 1\ndef codeblock\nend\n" )
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_filename
|
||||||
|
r = roccoize( "filename.rb", "# Comment 1\ndef codeblock\nend\n" )
|
||||||
|
assert_equal "filename.rb", r.file
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_sources
|
||||||
|
r = roccoize( "filename.rb", "# Comment 1\ndef codeblock\nend\n" )
|
||||||
|
assert_equal [ "filename.rb" ], r.sources
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_sections
|
||||||
|
r = roccoize( "filename.rb", "# Comment 1\ndef codeblock\nend\n" )
|
||||||
|
assert_equal 1, r.sections.length
|
||||||
|
assert_equal 2, r.sections[ 0 ].length
|
||||||
|
assert_equal "<p>Comment 1</p>\n", r.sections[ 0 ][ 0 ]
|
||||||
|
assert_equal "<span class=\"k\">def</span> <span class=\"nf\">codeblock</span>\n<span class=\"k\">end</span>", r.sections[ 0 ][ 1 ]
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_parsing
|
||||||
|
r = Rocco.new( 'test' ) { "" } # Generate throwaway instance so I can test `parse`
|
||||||
|
assert_equal(
|
||||||
|
[
|
||||||
|
[ [ "# Comment 1" ], [ "def codeblock", "end" ] ]
|
||||||
|
],
|
||||||
|
r.parse( "# Comment 1\ndef codeblock\nend\n" )
|
||||||
|
)
|
||||||
|
assert_equal(
|
||||||
|
[
|
||||||
|
[ [ "# Comment 1" ], [ "def codeblock" ] ],
|
||||||
|
[ [ "# Comment 2" ], [ "end" ] ]
|
||||||
|
],
|
||||||
|
r.parse( "# Comment 1\ndef codeblock\n# Comment 2\nend\n" )
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_splitting
|
||||||
|
r = Rocco.new( 'test' ) { "" } # Generate throwaway instance so I can test `split`
|
||||||
|
assert_equal(
|
||||||
|
[
|
||||||
|
[ "Comment 1" ],
|
||||||
|
[ "def codeblock\nend" ]
|
||||||
|
],
|
||||||
|
r.split([ [ [ "# Comment 1" ], [ "def codeblock", "end" ] ] ])
|
||||||
|
)
|
||||||
|
assert_equal(
|
||||||
|
[
|
||||||
|
[ "Comment 1", "Comment 2" ],
|
||||||
|
[ "def codeblock", "end" ]
|
||||||
|
],
|
||||||
|
r.split( [
|
||||||
|
[ [ "# Comment 1" ], [ "def codeblock" ] ],
|
||||||
|
[ [ "# Comment 2" ], [ "end" ] ]
|
||||||
|
] )
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
24
test/test_commentchar_detection.rb
Normal file
24
test/test_commentchar_detection.rb
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
require File.dirname(__FILE__) + '/helper'
|
||||||
|
|
||||||
|
class RoccoAutomaticCommentChars < Test::Unit::TestCase
|
||||||
|
def test_basic_detection
|
||||||
|
r = Rocco.new( 'filename.js' ) { "" }
|
||||||
|
assert_equal "//", r.options[:comment_chars]
|
||||||
|
end
|
||||||
|
def test_fallback_language
|
||||||
|
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever', '', { :language => "js" } ) { "" }
|
||||||
|
assert_equal "//", r.options[:comment_chars]
|
||||||
|
end
|
||||||
|
def test_fallback_default
|
||||||
|
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever' ) { "" }
|
||||||
|
assert_equal "#", r.options[:comment_chars], "`:comment_chars` should be `#` when falling back to defaults."
|
||||||
|
end
|
||||||
|
def test_fallback_user
|
||||||
|
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever', '', { :comment_chars => "user" } ) { "" }
|
||||||
|
assert_equal "user", r.options[:comment_chars], "`:comment_chars` should be the user's default when falling back to user-provided settings."
|
||||||
|
end
|
||||||
|
def test_fallback_user_with_unknown_language
|
||||||
|
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever', '', { :language => "not-a-language", :comment_chars => "user" } ) { "" }
|
||||||
|
assert_equal "user", r.options[:comment_chars], "`:comment_chars` should be the user's default when falling back to user-provided settings."
|
||||||
|
end
|
||||||
|
end
|
25
test/test_language_detection.rb
Normal file
25
test/test_language_detection.rb
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
require File.dirname(__FILE__) + '/helper'
|
||||||
|
|
||||||
|
class RoccoLanguageDetection < Test::Unit::TestCase
|
||||||
|
def test_basic_detection
|
||||||
|
r = Rocco.new( 'filename.py' ) { "" }
|
||||||
|
if r.pygmentize?
|
||||||
|
assert_equal "python", r.detect_language(), "`detect_language()` should return the correct language"
|
||||||
|
assert_equal "python", r.options[:language], "`@options[:language]` should be set to the correct language"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
def test_fallback_default
|
||||||
|
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever' ) { "" }
|
||||||
|
if r.pygmentize?
|
||||||
|
assert_equal "text", r.detect_language(), "`detect_language()` should return `text` when nothing else is detected"
|
||||||
|
assert_equal "ruby", r.options[:language], "`@options[:language]` should be set to `ruby` when nothing else is detected"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
def test_fallback_user
|
||||||
|
r = Rocco.new( 'filename.an_extension_with_no_meaning_whatsoever', '', { :language => "c" } ) { "" }
|
||||||
|
if r.pygmentize?
|
||||||
|
assert_equal "text", r.detect_language(), "`detect_language()` should return `text` nothing else is detected"
|
||||||
|
assert_equal "c", r.options[:language], "`@options[:language]` should be set to the user's setting when nothing else is detected"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
81
test/test_reported_issues.rb
Normal file
81
test/test_reported_issues.rb
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
require File.dirname(__FILE__) + '/helper'
|
||||||
|
|
||||||
|
class RoccoIssueTests < Test::Unit::TestCase
|
||||||
|
def test_issue07_incorrect_parsing_in_c_mode
|
||||||
|
# Precursor to issue #13 below, Rocco incorrectly parsed C/C++
|
||||||
|
# http://github.com/rtomayko/rocco/issues#issue/7
|
||||||
|
r = Rocco.new( 'issue7.c', [], { :language => 'c' } ) {
|
||||||
|
"// *stdio.h* declares *puts*\n#include <stdio.h>\n\n//### code hello world\n\n// every C program contains function *main*.\nint main (int argc, char *argv[]) {\n puts('hello world');\n return 0;\n}\n\n// that's it!"
|
||||||
|
}
|
||||||
|
r.sections.each do | section |
|
||||||
|
if not section[1].nil?
|
||||||
|
assert(
|
||||||
|
!section[1].include?("<span class=\"c\"># DIVIDER</span>"),
|
||||||
|
"`# DIVIDER` present in code text, which means the highligher screwed up somewhere."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
def test_issue10_utf8_processing
|
||||||
|
# Rocco has issues with strange UTF-8 characters: need to explicitly set the encoding for Pygments
|
||||||
|
# http://github.com/rtomayko/rocco/issues#issue/10
|
||||||
|
r = Rocco.new( File.dirname(__FILE__) + "/fixtures/issue10.utf-8.rb" )
|
||||||
|
assert_equal(
|
||||||
|
"<p>hello ąćęłńóśźż</p>\n",
|
||||||
|
r.sections[0][0],
|
||||||
|
"UTF-8 input files ought behave correctly."
|
||||||
|
)
|
||||||
|
# and, just for grins, ensure that iso-8859-1 works too.
|
||||||
|
# @TODO: Is this really the correct behavior? Converting text
|
||||||
|
# to UTF-8 on the way out is probably preferable.
|
||||||
|
r = Rocco.new( File.dirname(__FILE__) + "/fixtures/issue10.iso-8859-1.rb" )
|
||||||
|
assert_equal(
|
||||||
|
"<p>hello w\366rld</p>\n",
|
||||||
|
r.sections[0][0],
|
||||||
|
"ISO-8859-1 input should probably also behave correctly."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
def test_issue12_css_octothorpe_classname_change
|
||||||
|
# Docco changed some CSS classes. Rocco needs to update its default template.
|
||||||
|
# http://github.com/rtomayko/rocco/issues#issue/12
|
||||||
|
r = Rocco.new( 'issue12.sh' ) {
|
||||||
|
"# Comment 1\n# Comment 1\nprint 'omg!'"
|
||||||
|
}
|
||||||
|
html = r.to_html
|
||||||
|
assert(
|
||||||
|
!html.include?( "<div class=\"octowrap\">" ),
|
||||||
|
"`octowrap` wrapper is present in rendered HTML. This ought be replaced with `pilwrap`."
|
||||||
|
)
|
||||||
|
assert(
|
||||||
|
!html.include?( "<a class=\"octothorpe\" href=\"#section-1\">" ),
|
||||||
|
"`octothorpe` link is present in rendered HTML. This ought be replaced with `pilcrow`."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
def test_issue13_incorrect_code_divider_parsing
|
||||||
|
# In `bash` mode (among others), the comment class is `c`, not `c1`.
|
||||||
|
# http://github.com/rtomayko/rocco/issues#issue/13
|
||||||
|
r = Rocco.new( 'issue13.sh', [], { :language => 'bash' } ) {
|
||||||
|
"# Comment 1\necho 'code';\n# Comment 2\necho 'code';\n# Comment 3\necho 'code';\n"
|
||||||
|
}
|
||||||
|
r.sections.each do | section |
|
||||||
|
if not section[1].nil?
|
||||||
|
assert(
|
||||||
|
!section[1].include?("<span class=\"c\"># DIVIDER</span>"),
|
||||||
|
"`# DIVIDER` present in code text, which means the highligher screwed up somewhere."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
def test_issue15_extra_space_after_comment_character_remains
|
||||||
|
# After the comment character, a single space should be removed.
|
||||||
|
# http://github.com/rtomayko/rocco/issues#issue/15
|
||||||
|
r = Rocco.new( 'issue15.sh') {
|
||||||
|
"# Comment 1\n# ---------\necho 'code';"
|
||||||
|
}
|
||||||
|
assert(
|
||||||
|
!r.sections[0][0].include?( "<hr />" ),
|
||||||
|
"`<hr />` present in rendered documentation text. It should be a header, not text followed by a horizontal rule."
|
||||||
|
)
|
||||||
|
assert_equal( "<h2>Comment 1</h2>\n", r.sections[0][0] )
|
||||||
|
end
|
||||||
|
end
|
59
test/test_skippable_lines.rb
Normal file
59
test/test_skippable_lines.rb
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
require File.dirname(__FILE__) + '/helper'
|
||||||
|
|
||||||
|
class RoccoSkippableLines < Test::Unit::TestCase
|
||||||
|
def test_shebang_first_line
|
||||||
|
r = Rocco.new( 'filename.sh' ) { "" }
|
||||||
|
assert_equal(
|
||||||
|
[
|
||||||
|
[ [ "# Comment 1" ], [ "def codeblock" ] ],
|
||||||
|
[ [ "# Comment 2" ], [ "end" ] ]
|
||||||
|
],
|
||||||
|
r.parse( "#!/usr/bin/env bash\n# Comment 1\ndef codeblock\n# Comment 2\nend\n" ),
|
||||||
|
"Shebang should be stripped when it appears as the first line."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
def test_shebang_in_content
|
||||||
|
r = Rocco.new( 'filename.sh' ) { "" }
|
||||||
|
assert_equal(
|
||||||
|
[
|
||||||
|
[ [ "# Comment 1", "#!/usr/bin/env bash" ], [ "def codeblock" ] ],
|
||||||
|
[ [ "# Comment 2" ], [ "end" ] ]
|
||||||
|
],
|
||||||
|
r.parse( "# Comment 1\n#!/usr/bin/env bash\ndef codeblock\n# Comment 2\nend\n" ),
|
||||||
|
"Shebang shouldn't be stripped anywhere other than as the first line."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
def test_encoding_in_ruby
|
||||||
|
r = Rocco.new( 'filename.rb' ) { "" }
|
||||||
|
assert_equal(
|
||||||
|
[
|
||||||
|
[ [ "# Comment 1" ], [ "def codeblock" ] ],
|
||||||
|
[ [ "# Comment 2" ], [ "end" ] ]
|
||||||
|
],
|
||||||
|
r.parse( "#!/usr/bin/env bash\n# encoding: utf-8\n# Comment 1\ndef codeblock\n# Comment 2\nend\n" ),
|
||||||
|
"Strings matching the PEP 263 encoding definition regex should be stripped when they appear at the top of a python document."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
def test_encoding_in_python
|
||||||
|
r = Rocco.new( 'filename.py' ) { "" }
|
||||||
|
assert_equal(
|
||||||
|
[
|
||||||
|
[ [ "# Comment 1" ], [ "def codeblock" ] ],
|
||||||
|
[ [ "# Comment 2" ], [ "end" ] ]
|
||||||
|
],
|
||||||
|
r.parse( "#!/usr/bin/env bash\n# encoding: utf-8\n# Comment 1\ndef codeblock\n# Comment 2\nend\n" ),
|
||||||
|
"Strings matching the PEP 263 encoding definition regex should be stripped when they appear at the top of a python document."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
def test_encoding_in_notpython
|
||||||
|
r = Rocco.new( 'filename.sh' ) { "" }
|
||||||
|
assert_equal(
|
||||||
|
[
|
||||||
|
[ [ "# encoding: utf-8", "# Comment 1" ], [ "def codeblock" ] ],
|
||||||
|
[ [ "# Comment 2" ], [ "end" ] ]
|
||||||
|
],
|
||||||
|
r.parse( "#!/usr/bin/env bash\n# encoding: utf-8\n# Comment 1\ndef codeblock\n# Comment 2\nend\n" ),
|
||||||
|
"Strings matching the PEP 263 encoding definition regex should be stripped when they appear at the top of a python document."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue
Block a user