]> git.wincent.com - wikitext.git/blob - spec/link_encoding_spec.rb
Teach sanitizer to trim trailing whitespace
[wikitext.git] / spec / link_encoding_spec.rb
1 #!/usr/bin/env ruby
2 # Copyright 2007-2008 Wincent Colaiuta
3 # This program is free software: you can redistribute it and/or modify
4 # it under the terms of the GNU General Public License as published by
5 # the Free Software Foundation, either version 3 of the License, or
6 # (at your option) any later version.
7 #
8 # This program is distributed in the hope that it will be useful,
9 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11 # GNU General Public License for more details.
12 #
13 # You should have received a copy of the GNU General Public License
14 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
15
16 require File.join(File.dirname(__FILE__), 'spec_helper.rb')
17 require 'wikitext'
18 require 'uri'
19
20 describe Wikitext, 'encoding a link target' do
21   it 'should complain if passed nil' do
22     lambda { Wikitext::Parser.encode_link_target(nil) }.should raise_error
23   end
24
25   it 'should do nothing on zero-length input' do
26     Wikitext::Parser.encode_link_target('').should == ''
27   end
28
29   it 'should convert embedded spaces into "%20"' do
30     Wikitext::Parser.encode_link_target('hello world').should == 'hello%20world'
31   end
32
33   it 'should eat leading spaces' do
34     Wikitext::Parser.encode_link_target(' hello world').should == 'hello%20world'
35     Wikitext::Parser.encode_link_target('  hello world').should == 'hello%20world'
36     Wikitext::Parser.encode_link_target('   hello world').should == 'hello%20world'
37     Wikitext::Parser.encode_link_target('    hello world').should == 'hello%20world'
38   end
39
40   it 'should eat trailing spaces' do
41     Wikitext::Parser.encode_link_target('hello world ').should == 'hello%20world'
42     Wikitext::Parser.encode_link_target('hello world  ').should == 'hello%20world'
43     Wikitext::Parser.encode_link_target('hello world   ').should == 'hello%20world'
44     Wikitext::Parser.encode_link_target('hello world    ').should == 'hello%20world'
45   end
46
47   it 'should eat leading and trailing spaces combined' do
48     Wikitext::Parser.encode_link_target('    hello world ').should == 'hello%20world'
49     Wikitext::Parser.encode_link_target('   hello world  ').should == 'hello%20world'
50     Wikitext::Parser.encode_link_target('  hello world   ').should == 'hello%20world'
51     Wikitext::Parser.encode_link_target(' hello world    ').should == 'hello%20world'
52   end
53
54   it 'should return nothing for input consisting entirely of spaces' do
55     Wikitext::Parser.encode_link_target(' ').should == ''
56     Wikitext::Parser.encode_link_target('  ').should == ''
57     Wikitext::Parser.encode_link_target('   ').should == ''
58     Wikitext::Parser.encode_link_target('    ').should == ''
59   end
60
61   it 'should convert reserved symbols into percent escapes' do
62     Wikitext::Parser.encode_link_target('http://www.apple.com/q?foo').should == 'http%3a%2f%2fwww.apple.com%2fq%3ffoo'
63   end
64
65   it 'should convert non-ASCII into UTF-8 and then apply percent escapes' do
66     Wikitext::Parser.encode_link_target('cañon').should == 'ca%c3%b1on'
67   end
68
69   it 'should handle mixed scenarios (commas, double-quotes and UTF-8)' do
70     Wikitext::Parser.encode_link_target('foo, "bar" & baz €').should == 'foo%2c%20%22bar%22%20%26%20baz%20%e2%82%ac'
71   end
72
73   it 'should get the same answer as URI.escape' do
74     reserved = Regexp.new("[^#{URI::PATTERN::UNRESERVED}]")
75     ['foo bar', 'http://www.google.com/search?q=hello&foo=bar', '€'].each do |string|
76       Wikitext::Parser.encode_link_target(string).should == URI.escape(string, reserved).downcase
77     end
78   end
79 end
80