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 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263
|
# encoding: UTF-8
shared_examples_for "documentation on faces" do
defined?(Attrs) or
Attrs = [:summary, :description, :examples, :short_description, :notes, :author]
defined?(SingleLineAttrs) or
SingleLineAttrs = [:summary, :author]
# Simple, procedural tests that apply to a bunch of methods.
Attrs.each do |attr|
it "should accept a #{attr}" do
expect { subject.send("#{attr}=", "hello") }.not_to raise_error
subject.send(attr).should == "hello"
end
it "should accept a long (single line) value for #{attr}" do
text = "I never know when to stop with the word banana" + ("na" * 1000)
expect { subject.send("#{attr}=", text) }.to_not raise_error
subject.send(attr).should == text
end
end
Attrs.each do |getter|
setter = "#{getter}=".to_sym
context "#{getter}" do
it "should strip leading whitespace on a single line" do
subject.send(setter, " death to whitespace")
subject.send(getter).should == "death to whitespace"
end
it "should strip trailing whitespace on a single line" do
subject.send(setter, "death to whitespace ")
subject.send(getter).should == "death to whitespace"
end
it "should strip whitespace at both ends at once" do
subject.send(setter, " death to whitespace ")
subject.send(getter).should == "death to whitespace"
end
multiline_text = "with\nnewlines"
if SingleLineAttrs.include? getter then
it "should not accept multiline values" do
expect { subject.send(setter, multiline_text) }.
to raise_error ArgumentError, /#{getter} should be a single line/
subject.send(getter).should be_nil
end
else
it "should accept multiline values" do
expect { subject.send(setter, multiline_text) }.not_to raise_error
subject.send(getter).should == multiline_text
end
[1, 2, 4, 7, 25].each do |length|
context "#{length} chars indent" do
indent = ' ' * length
it "should strip leading whitespace on multiple lines" do
text = "this\nis\the\final\outcome"
subject.send(setter, text.gsub(/^/, indent))
subject.send(getter).should == text
end
it "should not remove formatting whitespace, only global indent" do
text = "this\n is\n the\n ultimate\ntest"
subject.send(setter, text.gsub(/^/, indent))
subject.send(getter).should == text
end
end
end
it "should strip whitespace with a blank line" do
subject.send(setter, " this\n\n should outdent")
subject.send(getter).should == "this\n\nshould outdent"
end
end
end
end
describe "#short_description" do
it "should return the set value if set after description" do
subject.description = "hello\ngoodbye"
subject.short_description = "whatever"
subject.short_description.should == "whatever"
end
it "should return the set value if set before description" do
subject.short_description = "whatever"
subject.description = "hello\ngoodbye"
subject.short_description.should == "whatever"
end
it "should return nothing if not set and no description" do
subject.short_description.should be_nil
end
it "should return the first paragraph of description if not set (where it is one line long)" do
subject.description = "hello"
subject.short_description.should == subject.description
end
it "should return the first paragraph of description if not set (where there is no paragraph break)" do
subject.description = "hello\ngoodbye"
subject.short_description.should == subject.description
end
it "should return the first paragraph of description if not set (where there is a paragraph break)" do
subject.description = "hello\ngoodbye\n\nmore\ntext\nhere\n\nfinal\nparagraph"
subject.short_description.should == "hello\ngoodbye"
end
it "should trim a very, very long first paragraph and add ellipsis" do
line = "this is a very, very, very long long line full of text\n"
subject.description = line * 20 + "\n\nwhatever, dude."
subject.short_description.should == (line * 5).chomp + ' [...]'
end
it "should trim a very very long only paragraph even if it is followed by a new paragraph" do
line = "this is a very, very, very long long line full of text\n"
subject.description = line * 20
subject.short_description.should == (line * 5).chomp + ' [...]'
end
end
describe "multiple authors" do
authors = %w{John Paul George Ringo}
context "in the DSL" do
it "should support multiple authors" do
authors.each {|name| subject.author name }
subject.authors.should =~ authors
subject.author.should == authors.join("\n")
end
it "should reject author as an array" do
expect { subject.author ["Foo", "Bar"] }.
to raise_error ArgumentError, /author must be a string/
end
end
context "#author=" do
it "should accept a single name" do
subject.author = "Fred"
subject.author.should == "Fred"
end
it "should accept an array of names" do
subject.author = authors
subject.authors.should =~ authors
subject.author.should == authors.join("\n")
end
it "should not append when set multiple times" do
subject.author = "Fred"
subject.author = "John"
subject.author.should == "John"
end
it "should reject arrays with embedded newlines" do
expect { subject.author = ["Fred\nJohn"] }.
to raise_error ArgumentError, /author should be a single line/
end
end
end
describe "#license" do
it "should default to reserving rights" do
subject.license.should =~ /All Rights Reserved/
end
it "should accept an arbitrary license string on the object" do
subject.license = "foo"
subject.license.should == "foo"
end
it "should accept symbols to specify existing licenses..."
end
describe "#copyright" do
it "should fail with just a name" do
expect { subject.copyright("invalid") }.
to raise_error ArgumentError, /copyright takes the owners names, then the years covered/
end
[1997, "1997"].each do |year|
it "should accept an entity name and a #{year.class.name} year" do
subject.copyright("me", year)
subject.copyright.should =~ /\bme\b/
subject.copyright.should =~ /#{year}/
end
it "should accept multiple entity names and a #{year.class.name} year" do
subject.copyright ["me", "you"], year
subject.copyright.should =~ /\bme\b/
subject.copyright.should =~ /\byou\b/
subject.copyright.should =~ /#{year}/
end
end
["1997-2003", "1997 - 2003", 1997..2003].each do |range|
it "should accept a #{range.class.name} range of years" do
subject.copyright("me", range)
subject.copyright.should =~ /\bme\b/
subject.copyright.should =~ /1997-2003/
end
it "should accept a #{range.class.name} range of years" do
subject.copyright ["me", "you"], range
subject.copyright.should =~ /\bme\b/
subject.copyright.should =~ /\byou\b/
subject.copyright.should =~ /1997-2003/
end
end
[[1997, 2003], ["1997", 2003], ["1997", "2003"]].each do |input|
it "should accept the set of years #{input.inspect} in an array" do
subject.copyright "me", input
subject.copyright.should =~ /\bme\b/
subject.copyright.should =~ /1997, 2003/
end
it "should accept the set of years #{input.inspect} in an array" do
subject.copyright ["me", "you"], input
subject.copyright.should =~ /\bme\b/
subject.copyright.should =~ /\byou\b/
subject.copyright.should =~ /1997, 2003/
end
end
it "should warn if someone does math accidentally on the range of years" do
expect { subject.copyright "me", 1997-2003 }.
to raise_error ArgumentError, /copyright with a year before 1970 is very strange; did you accidentally add or subtract two years\?/
end
it "should accept complex copyright years" do
years = [1997, 1999, 2000..2002, 2005].reverse
subject.copyright "me", years
subject.copyright.should =~ /\bme\b/
subject.copyright.should =~ /1997, 1999, 2000-2002, 2005/
end
end
# Things that are automatically generated.
[:name, :options, :synopsis].each do |attr|
describe "##{attr}" do
it "should not allow you to set #{attr}" do
subject.should_not respond_to :"#{attr}="
end
it "should have a #{attr}" do
subject.send(attr).should_not be_nil
end
it "'s #{attr} should not be empty..." do
subject.send(attr).should_not == ''
end
end
end
end
|