From fcbf63e62c627deae76c1b8cb8c0876c536ed811 Mon Sep 17 00:00:00 2001 From: Jari Vetoniemi Date: Mon, 16 Mar 2020 18:49:26 +0900 Subject: Fresh start --- jni/ruby/test/erb/hello.erb | 4 + jni/ruby/test/erb/test_erb.rb | 504 ++++++++++++++++++++++++++++++++++ jni/ruby/test/erb/test_erb_command.rb | 11 + jni/ruby/test/erb/test_erb_m17n.rb | 123 +++++++++ 4 files changed, 642 insertions(+) create mode 100644 jni/ruby/test/erb/hello.erb create mode 100644 jni/ruby/test/erb/test_erb.rb create mode 100644 jni/ruby/test/erb/test_erb_command.rb create mode 100644 jni/ruby/test/erb/test_erb_m17n.rb (limited to 'jni/ruby/test/erb') diff --git a/jni/ruby/test/erb/hello.erb b/jni/ruby/test/erb/hello.erb new file mode 100644 index 0000000..d5ebcb7 --- /dev/null +++ b/jni/ruby/test/erb/hello.erb @@ -0,0 +1,4 @@ += hello +<% 3.times do |n| %> +* <%= n %> +<% end %> diff --git a/jni/ruby/test/erb/test_erb.rb b/jni/ruby/test/erb/test_erb.rb new file mode 100644 index 0000000..107ad1a --- /dev/null +++ b/jni/ruby/test/erb/test_erb.rb @@ -0,0 +1,504 @@ +# -*- coding: us-ascii -*- +require 'test/unit' +require 'erb' + +class TestERB < Test::Unit::TestCase + class MyError < RuntimeError ; end + + def test_without_filename + erb = ERB.new("<% raise ::TestERB::MyError %>") + e = assert_raise(MyError) { + erb.result + } + assert_match(/\A\(erb\):1\b/, e.backtrace[0]) + end + + def test_with_filename + erb = ERB.new("<% raise ::TestERB::MyError %>") + erb.filename = "test filename" + e = assert_raise(MyError) { + erb.result + } + assert_match(/\Atest filename:1\b/, e.backtrace[0]) + end + + def test_without_filename_with_safe_level + erb = ERB.new("<% raise ::TestERB::MyError %>", 1) + e = assert_raise(MyError) { + erb.result + } + assert_match(/\A\(erb\):1\b/, e.backtrace[0]) + end + + def test_with_filename_and_safe_level + erb = ERB.new("<% raise ::TestERB::MyError %>", 1) + erb.filename = "test filename" + e = assert_raise(MyError) { + erb.result + } + assert_match(/\Atest filename:1\b/, e.backtrace[0]) + end + + def test_with_filename_lineno + erb = ERB.new("<% raise ::TestERB::MyError %>") + erb.filename = "test filename" + erb.lineno = 100 + e = assert_raise(MyError) { + erb.result + } + assert_match(/\Atest filename:101\b/, e.backtrace[0]) + end + + def test_with_location + erb = ERB.new("<% raise ::TestERB::MyError %>") + erb.location = ["test filename", 200] + e = assert_raise(MyError) { + erb.result + } + assert_match(/\Atest filename:201\b/, e.backtrace[0]) + end + + def test_html_escape + assert_equal(" !"\#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~", + ERB::Util.html_escape(" !\"\#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~")) + + assert_equal("", ERB::Util.html_escape("")) + assert_equal("abc", ERB::Util.html_escape("abc")) + assert_equal("<<", ERB::Util.html_escape("<\<")) + + assert_equal("", ERB::Util.html_escape(nil)) + assert_equal("123", ERB::Util.html_escape(123)) + end + + def test_concurrent_default_binding + template1 = 'one <%= ERB.new(template2).result %>' + + eval 'template2 = "two"', TOPLEVEL_BINDING + + bug7046 = '[ruby-core:47638]' + assert_equal("one two", ERB.new(template1).result, bug7046) + end +end + +class TestERBCore < Test::Unit::TestCase + def setup + @erb = ERB + end + + def test_core + _test_core(nil) + _test_core(0) + _test_core(1) + _test_core(2) + orig = $VERBOSE + begin + $VERBOSE = false + _test_core(3) + ensure + $VERBOSE = orig + end + end + + def _test_core(safe) + erb = @erb.new("hello") + assert_equal("hello", erb.result) + + erb = @erb.new("hello", safe, 0) + assert_equal("hello", erb.result) + + erb = @erb.new("hello", safe, 1) + assert_equal("hello", erb.result) + + erb = @erb.new("hello", safe, 2) + assert_equal("hello", erb.result) + + src = < +% n=0 +* <%= n %> +<% end %> +EOS + + ans = <') + assert_equal(ans.chomp, erb.result) + + ans = <') + assert_equal(ans, erb.result) + + ans = <') + assert_equal(ans.chomp, erb.result) + + ans = <') + assert_equal(ans, erb.result) + end + + class Foo; end + + def test_def_class + erb = @erb.new('hello') + cls = erb.def_class + assert_equal(Object, cls.superclass) + assert(cls.new.respond_to?('result')) + cls = erb.def_class(Foo) + assert_equal(Foo, cls.superclass) + assert(cls.new.respond_to?('result')) + cls = erb.def_class(Object, 'erb') + assert_equal(Object, cls.superclass) + assert(cls.new.respond_to?('erb')) + end + + def test_percent + src = < +EOS + assert_equal("1\n", ERB.new(src, nil, '%').result(binding)) + + src = < +EOS + ans = "\n" + assert_equal(ans, ERB.new(src, nil, '%').result(binding)) + + src = "<%\n%>" + # ans = "\n" + ans = "" + assert_equal(ans, ERB.new(src, nil, '%').result(binding)) + + src = <<%= n%> +EOS + assert_equal("1\n", ERB.new(src, nil, '%').result(binding)) + + src = < +%% %%><%%<%= i%><% +end%> +%%% +EOS + ans = <<%0 +% %%><%1 +%% +EOS + assert_equal(ans, ERB.new(src, nil, '%').result(binding)) + end + + def test_def_erb_method + klass = Class.new + klass.module_eval do + extend ERB::DefMethod + fname = File.join(File.dirname(File.expand_path(__FILE__)), 'hello.erb') + def_erb_method('hello', fname) + end + assert(klass.new.respond_to?('hello')) + + assert(! klass.new.respond_to?('hello_world')) + erb = @erb.new('hello, world') + klass.module_eval do + def_erb_method('hello_world', erb) + end + assert(klass.new.respond_to?('hello_world')) + end + + def test_def_method_without_filename + klass = Class.new + erb = ERB.new("<% raise ::TestERB::MyError %>") + erb.filename = "test filename" + assert(! klass.new.respond_to?('my_error')) + erb.def_method(klass, 'my_error') + e = assert_raise(::TestERB::MyError) { + klass.new.my_error + } + assert_match(/\A\(ERB\):1\b/, e.backtrace[0]) + end + + def test_def_method_with_fname + klass = Class.new + erb = ERB.new("<% raise ::TestERB::MyError %>") + erb.filename = "test filename" + assert(! klass.new.respond_to?('my_error')) + erb.def_method(klass, 'my_error', 'test fname') + e = assert_raise(::TestERB::MyError) { + klass.new.my_error + } + assert_match(/\Atest fname:1\b/, e.backtrace[0]) + end + + def test_escape + src = < +2.%%> : <%="%%>"%> +3. +% x = "foo" +<%=x%> +4. +%% print "foo" +5. +%% <%="foo"%> +6.<%=" +% print 'foo' +"%> +7.<%=" +%% print 'foo' +"%> +EOS + ans = < : %> +3. +foo +4. +% print "foo" +5. +% foo +6. +% print 'foo' + +7. +%% print 'foo' + +EOS + assert_equal(ans, ERB.new(src, nil, '%').result) + end + + def test_keep_lineno + src = < +% raise("lineno") +EOS + + erb = ERB.new(src, nil, '%') + begin + erb.result + assert(false) + rescue + assert_match(/\A\(erb\):4\b/, $@[0].to_s) + end + + src = < +Hello,\s +<% x = "World%%> +"%> +<%= x%> +EOS + + ans = <Hello,\s +World%> +EOS + assert_equal(ans, ERB.new(src, nil, '>').result) + + ans = < +Hello,\s + +World%> +EOS + assert_equal(ans, ERB.new(src, nil, '<>').result) + + ans = < +Hello,\s + +World%> + +EOS + assert_equal(ans, ERB.new(src).result) + + src = < +<%= x%> +<% raise("lineno") %> +EOS + + erb = ERB.new(src) + begin + erb.result + assert(false) + rescue + assert_match(/\A\(erb\):5\b/, $@[0].to_s) + end + + erb = ERB.new(src, nil, '>') + begin + erb.result + assert(false) + rescue + assert_match(/\A\(erb\):5\b/, $@[0].to_s) + end + + erb = ERB.new(src, nil, '<>') + begin + erb.result + assert(false) + rescue + assert_match(/\A\(erb\):5\b/, $@[0].to_s) + end + + src = < +<%= x %><%- x = nil -%>\s +<% raise("lineno") %> +EOS + + erb = ERB.new(src, nil, '-') + begin + erb.result + assert(false) + rescue + assert_match(/\A\(erb\):5\b/, $@[0].to_s) + end + + erb = ERB.new(src, nil, '%-') + begin + erb.result + assert(false) + rescue + assert_match(/\A\(erb\):5\b/, $@[0].to_s) + end + end + + def test_explicit + src = < +NotSkip <%- y = x -%> NotSkip +<% x.each do |w| -%> + <%- up = w.upcase -%> + * <%= up %> +<% end -%> + <%- z = nil -%> NotSkip <%- z = x %> + <%- z.each do |w| -%> + <%- down = w.downcase -%> + * <%= down %> + <%- up = w.upcase -%> + * <%= up %> + <%- end -%> +KeepNewLine <%- z = nil -%>\s +EOS + + ans = <%", nil, "%").result) + end +end + +class TestERBCoreWOStrScan < TestERBCore + def setup + @save_map = ERB::Compiler::Scanner.instance_variable_get('@scanner_map') + map = {[nil, false]=>ERB::Compiler::SimpleScanner} + ERB::Compiler::Scanner.instance_variable_set('@scanner_map', map) + super + end + + def teardown + ERB::Compiler::Scanner.instance_variable_set('@scanner_map', @save_map) + end +end diff --git a/jni/ruby/test/erb/test_erb_command.rb b/jni/ruby/test/erb/test_erb_command.rb new file mode 100644 index 0000000..abc8fdb --- /dev/null +++ b/jni/ruby/test/erb/test_erb_command.rb @@ -0,0 +1,11 @@ +# -*- coding: us-ascii -*- +require 'test/unit' + +class TestErbCommand < Test::Unit::TestCase + def test_var + assert_in_out_err(["-w", + File.expand_path("../../../bin/erb", __FILE__), + "var=hoge"], + "<%=var%>", ["hoge"]) + end +end diff --git a/jni/ruby/test/erb/test_erb_m17n.rb b/jni/ruby/test/erb/test_erb_m17n.rb new file mode 100644 index 0000000..f60dd10 --- /dev/null +++ b/jni/ruby/test/erb/test_erb_m17n.rb @@ -0,0 +1,123 @@ +# -*- coding: utf-8 -*- +require 'test/unit' +require 'erb' + +class TestERB < Test::Unit::TestCase + def test_result_encoding + erb = ERB.new("hello") + assert_equal __ENCODING__, erb.result.encoding + + erb = ERB.new("こんにちは".encode("EUC-JP")) + assert_equal Encoding::EUC_JP, erb.result.encoding + + erb = ERB.new("\xC4\xE3\xBA\xC3".force_encoding("EUC-CN")) + assert_equal Encoding::EUC_CN, erb.result.encoding + + erb = ERB.new("γεια σας".encode("ISO-8859-7")) + assert_equal Encoding::ISO_8859_7, erb.result.encoding + + assert_raise(ArgumentError, /ASCII compatible/) { + ERB.new("こんにちは".force_encoding("ISO-2022-JP")) # dummy encoding + } + end + + def test_generate_magic_comment + erb = ERB.new("hello") + assert_match(/#coding:UTF-8/, erb.src) + + erb = ERB.new("hello".force_encoding("EUC-JP")) + assert_match(/#coding:EUC-JP/, erb.src) + + erb = ERB.new("hello".force_encoding("ISO-8859-9")) + assert_match(/#coding:ISO-8859-9/, erb.src) + end + + def test_literal_encoding + erb = ERB.new("literal encoding is <%= 'hello'.encoding %>") + assert_match(/literal encoding is UTF-8/, erb.result) + + erb = ERB.new("literal encoding is <%= 'こんにちは'.encoding %>".encode("EUC-JP")) + assert_match(/literal encoding is EUC-JP/, erb.result) + + erb = ERB.new("literal encoding is <%= '\xC4\xE3\xBA\xC3'.encoding %>".force_encoding("EUC-CN")) + assert_match(/literal encoding is GB2312/, erb.result) + end + + def test___ENCODING__ + erb = ERB.new("__ENCODING__ is <%= __ENCODING__ %>") + assert_match(/__ENCODING__ is UTF-8/, erb.result) + + erb = ERB.new("__ENCODING__ is <%= __ENCODING__ %>".force_encoding("EUC-JP")) + assert_match(/__ENCODING__ is EUC-JP/, erb.result) + + erb = ERB.new("__ENCODING__ is <%= __ENCODING__ %>".force_encoding("Big5")) + assert_match(/__ENCODING__ is Big5/, erb.result) + end + + def test_recognize_magic_comment + erb = ERB.new(<<-EOS.encode("EUC-KR")) +<%# -*- coding: EUC-KR -*- %> +안녕하세요 + EOS + assert_match(/#coding:EUC-KR/, erb.src) + assert_equal Encoding::EUC_KR, erb.result.encoding + + erb = ERB.new(<<-EOS.encode("EUC-KR").force_encoding("ASCII-8BIT")) +<%#-*- coding: EUC-KR -*-%> +안녕하세요 + EOS + assert_match(/#coding:EUC-KR/, erb.src) + assert_equal Encoding::EUC_KR, erb.result.encoding + + erb = ERB.new(<<-EOS.encode("EUC-KR").force_encoding("ASCII-8BIT")) +<%# vim: tabsize=8 encoding=EUC-KR shiftwidth=2 expandtab %> +안녕하세요 + EOS + assert_match(/#coding:EUC-KR/, erb.src) + assert_equal Encoding::EUC_KR, erb.result.encoding + + erb = ERB.new(<<-EOS.encode("EUC-KR").force_encoding("ASCII-8BIT")) +<%#coding:EUC-KR %> +안녕하세요 + EOS + assert_match(/#coding:EUC-KR/, erb.src) + assert_equal Encoding::EUC_KR, erb.result.encoding + + erb = ERB.new(<<-EOS.encode("EUC-KR").force_encoding("EUC-JP")) +<%#coding:EUC-KR %> +안녕하세요 + EOS + assert_match(/#coding:EUC-KR/, erb.src) + assert_equal Encoding::EUC_KR, erb.result.encoding + end + + module M; end + def test_method_with_encoding + obj = Object.new + obj.extend(M) + + erb = ERB.new(<<-EOS.encode("EUC-JP").force_encoding("ASCII-8BIT")) +<%#coding:EUC-JP %> +literal encoding is <%= 'こんにちは'.encoding %> +__ENCODING__ is <%= __ENCODING__ %> + EOS + erb.def_method(M, :m_from_magic_comment) + + result = obj.m_from_magic_comment + assert_equal Encoding::EUC_JP, result.encoding + assert_match(/literal encoding is EUC-JP/, result) + assert_match(/__ENCODING__ is EUC-JP/, result) + + erb = ERB.new(<<-EOS.encode("EUC-KR")) +literal encoding is <%= '안녕하세요'.encoding %> +__ENCODING__ is <%= __ENCODING__ %> +EOS + erb.def_method(M, :m_from_eval_encoding) + result = obj.m_from_eval_encoding + assert_equal Encoding::EUC_KR, result.encoding + assert_match(/literal encoding is EUC-KR/, result) + assert_match(/__ENCODING__ is EUC-KR/, result) + end +end + +# vim:fileencoding=UTF-8 -- cgit v1.2.3-70-g09d2