summaryrefslogtreecommitdiff
path: root/spec/rubyspec/library/erb/result_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/rubyspec/library/erb/result_spec.rb')
-rw-r--r--spec/rubyspec/library/erb/result_spec.rb86
1 files changed, 86 insertions, 0 deletions
diff --git a/spec/rubyspec/library/erb/result_spec.rb b/spec/rubyspec/library/erb/result_spec.rb
new file mode 100644
index 0000000000..bc429da381
--- /dev/null
+++ b/spec/rubyspec/library/erb/result_spec.rb
@@ -0,0 +1,86 @@
+require 'erb'
+require File.expand_path('../../../spec_helper', __FILE__)
+
+describe "ERB#result" do
+
+
+ it "return the result of compiled ruby code" do
+ input = <<'END'
+<ul>
+<% for item in list %>
+ <li><%= item %>
+<% end %>
+</ul>
+END
+ expected = <<'END'
+<ul>
+
+ <li>AAA
+
+ <li>BBB
+
+ <li>CCC
+
+</ul>
+END
+ erb = ERB.new(input)
+ list = %w[AAA BBB CCC]
+ actual = erb.result(binding)
+ actual.should == expected
+ end
+
+
+ it "share local variables" do
+ input = "<% var = 456 %>"
+ expected = 456
+ var = 123
+ ERB.new(input).result(binding)
+ var.should == expected
+ end
+
+
+ it "is not able to h() or u() unless including ERB::Util" do
+ input = "<%=h '<>' %>"
+ lambda {
+ ERB.new(input).result()
+ }.should raise_error(NameError)
+ end
+
+
+ it "is able to h() or u() if ERB::Util is included" do
+ class MyERB1
+ include ERB::Util
+ def main
+ input = "<%=h '<>' %>"
+ return ERB.new(input).result(binding)
+ end
+ end
+ expected = '&lt;&gt;'
+ actual = MyERB1.new.main()
+ actual.should == expected
+ end
+
+
+ it "use TOPLEVEL_BINDING if binding is not passed" do
+ class MyERB2
+ include ERB::Util
+ def main1
+ #input = "<%= binding.to_s %>"
+ input = "<%= _xxx_var_ %>"
+ return ERB.new(input).result()
+ end
+ def main2
+ input = "<%=h '<>' %>"
+ return ERB.new(input).result()
+ end
+ end
+
+ eval '_xxx_var_ = 123', TOPLEVEL_BINDING
+ expected = '123'
+ MyERB2.new.main1().should == expected
+
+ lambda {
+ MyERB2.new.main2()
+ }.should raise_error(NameError)
+ end
+end