Sha256: 8892c7b47ca642597a8e301b66e54f45b9bb9e9baca30a9dbf2f6caed89df02e

Contents?: true

Size: 1.34 KB

Versions: 3

Compression:

Stored size: 1.34 KB

Contents

require 'helper'

class HtmlSafeString < String
  def html_safe?
    true
  end
end

describe Temple::Filters::Escapable do
  before do
    @filter = Temple::Filters::Escapable.new
  end

  it 'should handle escape expressions' do
    @filter.call([:escape, true,
                  [:multi,
                   [:static, "a < b"],
                   [:dynamic, "ruby_method"]]
    ]).should.equal [:multi,
      [:static, "a &lt; b"],
      [:dynamic, "Temple::Utils.escape_html((ruby_method))"],
    ]
  end

  it 'should keep codes intact' do
    exp = [:multi, [:code, 'foo']]
    @filter.call(exp).should.equal exp
  end

  it 'should keep statics intact' do
    exp = [:multi, [:static, '<']]
    @filter.call(exp).should.equal exp
  end

  it 'should keep dynamic intact' do
    exp = [:multi, [:dynamic, 'foo']]
    @filter.call(exp).should.equal exp
  end

  it 'should have use_html_safe option' do
    filter = Temple::Filters::Escapable.new(:use_html_safe => true)
    filter.call([:escape, true,
      [:static, HtmlSafeString.new("a < b")]
    ]).should.equal [:static, "a < b"]
  end

  it 'should support censoring' do
    filter = Temple::Filters::Escapable.new(:escape_code => '(%s).gsub("Temple sucks", "Temple rocks")')
    filter.call([:escape, true,
      [:static, "~~ Temple sucks ~~"]
    ]).should.equal [:static, "~~ Temple rocks ~~"]
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
temple-0.3.2 test/filters/test_escapable.rb
temple-0.3.1 test/filters/test_escapable.rb
temple-0.3.0 test/filters/test_escapable.rb