-
Notifications
You must be signed in to change notification settings - Fork 49
/
west_european_spec.rb
115 lines (99 loc) · 3.11 KB
/
west_european_spec.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# encoding: utf-8
#
require 'spec_helper'
describe Picky::CharacterSubstituters::WestEuropean do
let(:substituter) { described_class.new.tap { |s| s.substitute '' } }
# A bit of metaprogramming to help with the myriads of its.
#
def self.it_should_substitute special_character, normal_character
it "should substitute #{special_character} with #{normal_character}" do
substituter.substitute(special_character).should == normal_character
end
end
def self.it_should_not_substitute special_character
it "should not substitute #{special_character}" do
substituter.substitute(special_character).should == special_character
end
end
# Speed spec at the top since the order of the describes made the
# speed spec trip. And not on mushrooms either.
#
describe "speed" do
it "is fast" do
substituter.substitute 'ä' # Prerun
result = performance_of { substituter.substitute('ä') }
result.should < 0.00009
end
it "is fast" do
result = performance_of { substituter.substitute('abcdefghijklmnopqrstuvwxyz1234567890') }
result.should < 0.00015
end
end
describe 'to_s' do
it 'outputs correctly' do
substituter.to_s.should == 'Picky::CharacterSubstituters::WestEuropean'
end
end
describe "normal characters" do
it_should_not_substitute('abcdefghijklmnopqrstuvwxyz1234567890')
end
describe "situations" do
it_should_substitute 'Peter Müller', 'Peter Mueller'
it_should_substitute 'Lüchinger', 'Luechinger'
# it_should_substitute 'LÜCHINGER', 'LUECHINGER'
end
describe "umlauts" do
it_should_substitute 'ä', 'ae'
it_should_substitute 'Ä', 'Ae'
it_should_substitute 'ë', 'e'
it_should_substitute 'Ë', 'E'
it_should_substitute 'ï', 'i'
it_should_substitute 'Ï', 'I'
it_should_substitute 'ö', 'oe'
it_should_substitute 'Ö', 'Oe'
it_should_substitute 'ü', 'ue'
it_should_substitute 'Ü', 'Ue'
end
describe "acute" do
it_should_substitute 'á', 'a'
it_should_substitute 'Á', 'A'
it_should_substitute 'é', 'e'
it_should_substitute 'É', 'E'
it_should_substitute 'í', 'i'
it_should_substitute 'ó', 'o'
end
describe "grave" do
it_should_substitute 'à', 'a'
it_should_substitute 'À', 'A'
it_should_substitute 'è', 'e'
it_should_substitute 'È', 'E'
it_should_substitute 'ì', 'i'
it_should_substitute 'ò', 'o'
end
describe "circonflex" do
it_should_substitute 'â', 'a'
it_should_substitute 'ê', 'e'
it_should_substitute 'Ê', 'E'
it_should_substitute 'î', 'i'
it_should_substitute 'Î', 'I'
it_should_substitute 'ô', 'o'
it_should_substitute 'Ô', 'O'
it_should_substitute 'û', 'u'
end
describe "cedilla" do
it_should_substitute 'ç', 'c'
it_should_substitute 'Ç', 'C'
end
describe "ligatures" do
it_should_substitute 'ß', 'ss'
# it_should_substitute 'Æ', 'AE'
end
describe "norse" do
# it_should_substitute 'ø', 'o'
it_should_substitute 'å', 'a'
it_should_substitute 'Å', 'A'
end
describe "diacritic" do
it_should_substitute 'ñ', 'n'
end
end