spec/args/paragraph_spec.rb in squib-0.8.0 vs spec/args/paragraph_spec.rb in squib-0.9.0
- old
+ new
@@ -1,153 +1,153 @@
-require 'spec_helper'
-require 'squib/args/paragraph'
-require 'squib/constants'
-
-describe Squib::Args::Paragraph do
- subject(:para) { Squib::Args::Paragraph.new('FooFont 32') }
-
- context 'str validator' do
- it 'converts everything to string' do
- para.load!( {str: 5} )
- expect(para.str).to eq ['5']
- end
- end
-
- context 'font validator' do
- it 'uses deck font by default' do
- para.load!( {} )
- expect(para.font).to eq ['FooFont 32']
- end
-
- it 'uses system default font when deck font is :default' do
- para = Squib::Args::Paragraph.new(:default)
- para.load!( {} )
- expect(para.font).to eq [Squib::SYSTEM_DEFAULTS[:default_font]]
- end
-
- it 'uses specified font when given' do
- para.load!( {font: 'MyFont 8'})
- expect(para.font).to eq ['MyFont 8']
- end
- end
-
- context 'align validator' do
- it 'converts to pango left' do
- para.load!( { align: :left } )
- expect(para.align).to eq [Pango::ALIGN_LEFT]
- end
-
- it 'converts to pango right' do
- para.load!( { align: :RIGHT } )
- expect(para.align).to eq [Pango::ALIGN_RIGHT]
- end
-
- it 'converts to pango center' do
- para.load!( { align: 'center' } )
- expect(para.align).to eq [Pango::ALIGN_CENTER]
- end
-
- it 'raises an exception on anything else' do
- expect { para.load!( { align: 'foo' } ) }.to raise_error(ArgumentError, 'align must be one of: center, left, right')
- end
- end
-
- context 'wrap validator' do
- it 'converts to pango wrap word' do
- para.load!( { wrap: 'word'} )
- expect(para.wrap).to eq [Pango::WRAP_WORD]
- end
-
- it 'converts to pango wrap char' do
- para.load!( { wrap: 'WORD_ChAr'} )
- expect(para.wrap).to eq [Pango::WRAP_WORD_CHAR]
- end
-
- it 'converts to pango wrap char on true' do
- para.load!( { wrap: true} )
- expect(para.wrap).to eq [Pango::WRAP_WORD_CHAR]
- end
-
- it 'converts to pango wrap char with false' do
- para.load!( { wrap: false} )
- expect(para.wrap).to eq [Pango::WRAP_CHAR]
- end
-
- it 'raises an exception on anything else' do
- expect { para.load!( {wrap: 'foo' }) }.to raise_error(ArgumentError, 'wrap must be one of: word, char, word_char, true, or false')
- end
- end
-
- context 'ellipsize validator' do
- it 'converts to pango on none and false' do
- para.load!( { ellipsize: 'none'} )
- expect(para.ellipsize).to eq [Pango::Layout::ELLIPSIZE_NONE]
- end
-
- it 'converts to pango with start' do
- para.load!( { ellipsize: :StArt} )
- expect(para.ellipsize).to eq [Pango::Layout::ELLIPSIZE_START]
- end
-
- it 'converts to pango middle' do
- para.load!( { ellipsize: 'middle'} )
- expect(para.ellipsize).to eq [Pango::Layout::ELLIPSIZE_MIDDLE]
- end
-
- it 'converts to pango end' do
- para.load!( { ellipsize: 'END'} )
- expect(para.ellipsize).to eq [Pango::Layout::ELLIPSIZE_END]
- end
-
- it 'raises an exception on anything else' do
- expect { para.load!( {ellipsize: 'foo' }) }.to raise_error(ArgumentError, 'ellipsize must be one of: none, start, middle, end, true, or false')
- end
- end
-
- context 'justify validator' do
- it 'allows nil' do
- para.load!( { justify: nil} )
- expect(para.justify).to eq [nil]
- end
-
- it 'can be true' do
- para.load!( { justify: true} )
- expect(para.justify).to eq [true]
- end
-
- it 'can be false' do
- para.load!( { justify: false} )
- expect(para.justify).to eq [false]
- end
-
- it 'raises an exception on anything else' do
- expect { para.load!( {justify: 'false' }) }.to raise_error(ArgumentError, 'justify must be one of: nil, true, or false')
- end
- end
-
- context 'spacing validator' do
- it 'allows nil' do
- para.load!( { spacing: nil} )
- expect(para.spacing).to eq [nil]
- end
- it 'is converted to Pango space' do
- para.load!( { spacing: 519} )
- expect(para.spacing).to eq [Pango::SCALE * 519.0]
- end
-
- it 'raises an exception if not a float' do
- expect { para.load!( {spacing: /foo/ }) }.to raise_error(ArgumentError, 'spacing must be a number or nil')
- end
- end
-
- context 'valign validator' do
- it 'converts top' do
- para.load!( { valign: :top} )
- expect(para.valign).to eq ['top']
- end
-
- it 'raises an exception if not one of the three' do
- expect { para.load!( {valign: 'foo' }) }.to raise_error(ArgumentError, 'valign must be one of: top, middle, bottom')
- end
- end
-
+require 'spec_helper'
+require 'squib/args/paragraph'
+require 'squib/constants'
+
+describe Squib::Args::Paragraph do
+ subject(:para) { Squib::Args::Paragraph.new('FooFont 32') }
+
+ context 'str validator' do
+ it 'converts everything to string' do
+ para.load!( {str: 5} )
+ expect(para.str).to eq ['5']
+ end
+ end
+
+ context 'font validator' do
+ it 'uses deck font by default' do
+ para.load!( {} )
+ expect(para.font).to eq ['FooFont 32']
+ end
+
+ it 'uses system default font when deck font is :default' do
+ para = Squib::Args::Paragraph.new(:default)
+ para.load!( {} )
+ expect(para.font).to eq [Squib::DEFAULT_FONT]
+ end
+
+ it 'uses specified font when given' do
+ para.load!( {font: 'MyFont 8'})
+ expect(para.font).to eq ['MyFont 8']
+ end
+ end
+
+ context 'align validator' do
+ it 'converts to pango left' do
+ para.load!( { align: :left } )
+ expect(para.align).to eq [Pango::ALIGN_LEFT]
+ end
+
+ it 'converts to pango right' do
+ para.load!( { align: :RIGHT } )
+ expect(para.align).to eq [Pango::ALIGN_RIGHT]
+ end
+
+ it 'converts to pango center' do
+ para.load!( { align: 'center' } )
+ expect(para.align).to eq [Pango::ALIGN_CENTER]
+ end
+
+ it 'raises an exception on anything else' do
+ expect { para.load!( { align: 'foo' } ) }.to raise_error(ArgumentError, 'align must be one of: center, left, right')
+ end
+ end
+
+ context 'wrap validator' do
+ it 'converts to pango wrap word' do
+ para.load!( { wrap: 'word'} )
+ expect(para.wrap).to eq [Pango::WRAP_WORD]
+ end
+
+ it 'converts to pango wrap char' do
+ para.load!( { wrap: 'WORD_ChAr'} )
+ expect(para.wrap).to eq [Pango::WRAP_WORD_CHAR]
+ end
+
+ it 'converts to pango wrap char on true' do
+ para.load!( { wrap: true} )
+ expect(para.wrap).to eq [Pango::WRAP_WORD_CHAR]
+ end
+
+ it 'converts to pango wrap char with false' do
+ para.load!( { wrap: false} )
+ expect(para.wrap).to eq [Pango::WRAP_CHAR]
+ end
+
+ it 'raises an exception on anything else' do
+ expect { para.load!( {wrap: 'foo' }) }.to raise_error(ArgumentError, 'wrap must be one of: word, char, word_char, true, or false')
+ end
+ end
+
+ context 'ellipsize validator' do
+ it 'converts to pango on none and false' do
+ para.load!( { ellipsize: 'none'} )
+ expect(para.ellipsize).to eq [Pango::Layout::ELLIPSIZE_NONE]
+ end
+
+ it 'converts to pango with start' do
+ para.load!( { ellipsize: :StArt} )
+ expect(para.ellipsize).to eq [Pango::Layout::ELLIPSIZE_START]
+ end
+
+ it 'converts to pango middle' do
+ para.load!( { ellipsize: 'middle'} )
+ expect(para.ellipsize).to eq [Pango::Layout::ELLIPSIZE_MIDDLE]
+ end
+
+ it 'converts to pango end' do
+ para.load!( { ellipsize: 'END'} )
+ expect(para.ellipsize).to eq [Pango::Layout::ELLIPSIZE_END]
+ end
+
+ it 'raises an exception on anything else' do
+ expect { para.load!( {ellipsize: 'foo' }) }.to raise_error(ArgumentError, 'ellipsize must be one of: none, start, middle, end, true, or false')
+ end
+ end
+
+ context 'justify validator' do
+ it 'allows nil' do
+ para.load!( { justify: nil} )
+ expect(para.justify).to eq [nil]
+ end
+
+ it 'can be true' do
+ para.load!( { justify: true} )
+ expect(para.justify).to eq [true]
+ end
+
+ it 'can be false' do
+ para.load!( { justify: false} )
+ expect(para.justify).to eq [false]
+ end
+
+ it 'raises an exception on anything else' do
+ expect { para.load!( {justify: 'false' }) }.to raise_error(ArgumentError, 'justify must be one of: nil, true, or false')
+ end
+ end
+
+ context 'spacing validator' do
+ it 'allows nil' do
+ para.load!( { spacing: nil} )
+ expect(para.spacing).to eq [nil]
+ end
+ it 'is converted to Pango space' do
+ para.load!( { spacing: 519} )
+ expect(para.spacing).to eq [Pango::SCALE * 519.0]
+ end
+
+ it 'raises an exception if not a float' do
+ expect { para.load!( {spacing: /foo/ }) }.to raise_error(ArgumentError, 'spacing must be a number or nil')
+ end
+ end
+
+ context 'valign validator' do
+ it 'converts top' do
+ para.load!( { valign: :top} )
+ expect(para.valign).to eq ['top']
+ end
+
+ it 'raises an exception if not one of the three' do
+ expect { para.load!( {valign: 'foo' }) }.to raise_error(ArgumentError, 'valign must be one of: top, middle, bottom')
+ end
+ end
+
end
\ No newline at end of file