shoes-dsl 4.0.0.pre2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (209) hide show
  1. checksums.yaml +7 -0
  2. data/CHANGELOG +84 -0
  3. data/Gemfile +24 -0
  4. data/Guardfile +11 -0
  5. data/LICENSE +31 -0
  6. data/README.md +201 -0
  7. data/ext/install/Rakefile +29 -0
  8. data/ext/install/shoes.bat +9 -0
  9. data/fonts/Coolvetica.ttf +0 -0
  10. data/fonts/Lacuna.ttf +0 -0
  11. data/lib/shoes/animation.rb +56 -0
  12. data/lib/shoes/app.rb +131 -0
  13. data/lib/shoes/arc.rb +25 -0
  14. data/lib/shoes/background.rb +24 -0
  15. data/lib/shoes/border.rb +24 -0
  16. data/lib/shoes/builtin_methods.rb +77 -0
  17. data/lib/shoes/button.rb +30 -0
  18. data/lib/shoes/check_button.rb +44 -0
  19. data/lib/shoes/color.rb +385 -0
  20. data/lib/shoes/common/background_element.rb +9 -0
  21. data/lib/shoes/common/changeable.rb +34 -0
  22. data/lib/shoes/common/clickable.rb +24 -0
  23. data/lib/shoes/common/inspect.rb +14 -0
  24. data/lib/shoes/common/positioning.rb +30 -0
  25. data/lib/shoes/common/registration.rb +33 -0
  26. data/lib/shoes/common/remove.rb +10 -0
  27. data/lib/shoes/common/state.rb +18 -0
  28. data/lib/shoes/common/style.rb +152 -0
  29. data/lib/shoes/common/style_normalizer.rb +16 -0
  30. data/lib/shoes/common/ui_element.rb +11 -0
  31. data/lib/shoes/common/visibility.rb +40 -0
  32. data/lib/shoes/configuration.rb +96 -0
  33. data/lib/shoes/dialog.rb +27 -0
  34. data/lib/shoes/dimension.rb +239 -0
  35. data/lib/shoes/dimensions.rb +209 -0
  36. data/lib/shoes/download.rb +121 -0
  37. data/lib/shoes/dsl.rb +591 -0
  38. data/lib/shoes/font.rb +49 -0
  39. data/lib/shoes/gradient.rb +31 -0
  40. data/lib/shoes/image.rb +29 -0
  41. data/lib/shoes/image_pattern.rb +12 -0
  42. data/lib/shoes/input_box.rb +60 -0
  43. data/lib/shoes/internal_app.rb +219 -0
  44. data/lib/shoes/key_event.rb +17 -0
  45. data/lib/shoes/line.rb +87 -0
  46. data/lib/shoes/link.rb +59 -0
  47. data/lib/shoes/link_hover.rb +5 -0
  48. data/lib/shoes/list_box.rb +50 -0
  49. data/lib/shoes/logger.rb +66 -0
  50. data/lib/shoes/logger/ruby.rb +18 -0
  51. data/lib/shoes/mock.rb +31 -0
  52. data/lib/shoes/mock/animation.rb +8 -0
  53. data/lib/shoes/mock/app.rb +47 -0
  54. data/lib/shoes/mock/arc.rb +9 -0
  55. data/lib/shoes/mock/background.rb +10 -0
  56. data/lib/shoes/mock/border.rb +7 -0
  57. data/lib/shoes/mock/button.rb +10 -0
  58. data/lib/shoes/mock/check.rb +25 -0
  59. data/lib/shoes/mock/clickable.rb +8 -0
  60. data/lib/shoes/mock/common_methods.rb +12 -0
  61. data/lib/shoes/mock/dialog.rb +13 -0
  62. data/lib/shoes/mock/download.rb +18 -0
  63. data/lib/shoes/mock/font.rb +17 -0
  64. data/lib/shoes/mock/image.rb +13 -0
  65. data/lib/shoes/mock/image_pattern.rb +9 -0
  66. data/lib/shoes/mock/input_box.rb +30 -0
  67. data/lib/shoes/mock/keypress.rb +10 -0
  68. data/lib/shoes/mock/keyrelease.rb +10 -0
  69. data/lib/shoes/mock/line.rb +14 -0
  70. data/lib/shoes/mock/link.rb +12 -0
  71. data/lib/shoes/mock/list_box.rb +19 -0
  72. data/lib/shoes/mock/oval.rb +12 -0
  73. data/lib/shoes/mock/progress.rb +10 -0
  74. data/lib/shoes/mock/radio.rb +27 -0
  75. data/lib/shoes/mock/rect.rb +14 -0
  76. data/lib/shoes/mock/shape.rb +20 -0
  77. data/lib/shoes/mock/slot.rb +16 -0
  78. data/lib/shoes/mock/sound.rb +8 -0
  79. data/lib/shoes/mock/star.rb +14 -0
  80. data/lib/shoes/mock/text_block.rb +36 -0
  81. data/lib/shoes/mock/timer.rb +8 -0
  82. data/lib/shoes/not_implemented_error.rb +4 -0
  83. data/lib/shoes/oval.rb +20 -0
  84. data/lib/shoes/point.rb +54 -0
  85. data/lib/shoes/progress.rb +25 -0
  86. data/lib/shoes/radio.rb +16 -0
  87. data/lib/shoes/rect.rb +21 -0
  88. data/lib/shoes/renamed_delegate.rb +15 -0
  89. data/lib/shoes/shape.rb +158 -0
  90. data/lib/shoes/slot.rb +271 -0
  91. data/lib/shoes/slot_contents.rb +50 -0
  92. data/lib/shoes/sound.rb +18 -0
  93. data/lib/shoes/span.rb +16 -0
  94. data/lib/shoes/star.rb +45 -0
  95. data/lib/shoes/text.rb +24 -0
  96. data/lib/shoes/text_block.rb +143 -0
  97. data/lib/shoes/text_block_dimensions.rb +52 -0
  98. data/lib/shoes/timer.rb +12 -0
  99. data/lib/shoes/url.rb +44 -0
  100. data/lib/shoes/version.rb +3 -0
  101. data/lib/shoes/widget.rb +69 -0
  102. data/manifests/common.rb +34 -0
  103. data/manifests/shoes-dsl.rb +34 -0
  104. data/shoes-dsl.gemspec +19 -0
  105. data/spec/code_coverage.rb +14 -0
  106. data/spec/shoes/animation_spec.rb +65 -0
  107. data/spec/shoes/app_spec.rb +484 -0
  108. data/spec/shoes/arc_spec.rb +51 -0
  109. data/spec/shoes/background_spec.rb +53 -0
  110. data/spec/shoes/border_spec.rb +47 -0
  111. data/spec/shoes/builtin_methods_spec.rb +110 -0
  112. data/spec/shoes/button_spec.rb +44 -0
  113. data/spec/shoes/check_spec.rb +35 -0
  114. data/spec/shoes/cli_spec.rb +15 -0
  115. data/spec/shoes/color_spec.rb +408 -0
  116. data/spec/shoes/common/inspect_spec.rb +26 -0
  117. data/spec/shoes/common/remove_spec.rb +38 -0
  118. data/spec/shoes/common/style_normalizer_spec.rb +28 -0
  119. data/spec/shoes/common/style_spec.rb +147 -0
  120. data/spec/shoes/configuration_spec.rb +36 -0
  121. data/spec/shoes/constants_spec.rb +38 -0
  122. data/spec/shoes/dialog_spec.rb +163 -0
  123. data/spec/shoes/dimension_spec.rb +407 -0
  124. data/spec/shoes/dimensions_spec.rb +837 -0
  125. data/spec/shoes/download_spec.rb +142 -0
  126. data/spec/shoes/flow_spec.rb +133 -0
  127. data/spec/shoes/font_spec.rb +37 -0
  128. data/spec/shoes/framework_learning_spec.rb +30 -0
  129. data/spec/shoes/gradient_spec.rb +32 -0
  130. data/spec/shoes/helpers/fake_element.rb +17 -0
  131. data/spec/shoes/helpers/inspect_helpers.rb +5 -0
  132. data/spec/shoes/helpers/sample17_helper.rb +66 -0
  133. data/spec/shoes/image_spec.rb +49 -0
  134. data/spec/shoes/images/shoe.jpg +0 -0
  135. data/spec/shoes/input_box_spec.rb +80 -0
  136. data/spec/shoes/integration_spec.rb +20 -0
  137. data/spec/shoes/internal_app_spec.rb +141 -0
  138. data/spec/shoes/keypress_spec.rb +11 -0
  139. data/spec/shoes/keyrelease_spec.rb +12 -0
  140. data/spec/shoes/line_spec.rb +49 -0
  141. data/spec/shoes/link_spec.rb +105 -0
  142. data/spec/shoes/list_box_spec.rb +74 -0
  143. data/spec/shoes/logger/ruby_spec.rb +8 -0
  144. data/spec/shoes/logger_spec.rb +45 -0
  145. data/spec/shoes/oval_spec.rb +24 -0
  146. data/spec/shoes/point_spec.rb +71 -0
  147. data/spec/shoes/progress_spec.rb +54 -0
  148. data/spec/shoes/radio_spec.rb +32 -0
  149. data/spec/shoes/rect_spec.rb +39 -0
  150. data/spec/shoes/renamed_delegate_spec.rb +70 -0
  151. data/spec/shoes/shape_spec.rb +95 -0
  152. data/spec/shoes/shared_examples/button.rb +6 -0
  153. data/spec/shoes/shared_examples/changeable.rb +26 -0
  154. data/spec/shoes/shared_examples/clickable.rb +5 -0
  155. data/spec/shoes/shared_examples/common_methods.rb +35 -0
  156. data/spec/shoes/shared_examples/dimensions.rb +32 -0
  157. data/spec/shoes/shared_examples/dsl.rb +44 -0
  158. data/spec/shoes/shared_examples/dsl/animate.rb +29 -0
  159. data/spec/shoes/shared_examples/dsl/arc.rb +45 -0
  160. data/spec/shoes/shared_examples/dsl/background.rb +26 -0
  161. data/spec/shoes/shared_examples/dsl/border.rb +10 -0
  162. data/spec/shoes/shared_examples/dsl/button.rb +5 -0
  163. data/spec/shoes/shared_examples/dsl/cap.rb +6 -0
  164. data/spec/shoes/shared_examples/dsl/check.rb +11 -0
  165. data/spec/shoes/shared_examples/dsl/edit_box.rb +8 -0
  166. data/spec/shoes/shared_examples/dsl/edit_line.rb +8 -0
  167. data/spec/shoes/shared_examples/dsl/editable_element.rb +29 -0
  168. data/spec/shoes/shared_examples/dsl/fill.rb +27 -0
  169. data/spec/shoes/shared_examples/dsl/flow.rb +15 -0
  170. data/spec/shoes/shared_examples/dsl/gradient.rb +62 -0
  171. data/spec/shoes/shared_examples/dsl/image.rb +21 -0
  172. data/spec/shoes/shared_examples/dsl/line.rb +9 -0
  173. data/spec/shoes/shared_examples/dsl/nofill.rb +6 -0
  174. data/spec/shoes/shared_examples/dsl/nostroke.rb +6 -0
  175. data/spec/shoes/shared_examples/dsl/oval.rb +88 -0
  176. data/spec/shoes/shared_examples/dsl/pattern.rb +34 -0
  177. data/spec/shoes/shared_examples/dsl/progress.rb +7 -0
  178. data/spec/shoes/shared_examples/dsl/rect.rb +92 -0
  179. data/spec/shoes/shared_examples/dsl/rgb.rb +26 -0
  180. data/spec/shoes/shared_examples/dsl/shape.rb +21 -0
  181. data/spec/shoes/shared_examples/dsl/star.rb +48 -0
  182. data/spec/shoes/shared_examples/dsl/stroke.rb +30 -0
  183. data/spec/shoes/shared_examples/dsl/strokewidth.rb +19 -0
  184. data/spec/shoes/shared_examples/dsl/style.rb +32 -0
  185. data/spec/shoes/shared_examples/dsl/text_elements.rb +81 -0
  186. data/spec/shoes/shared_examples/dsl/video.rb +5 -0
  187. data/spec/shoes/shared_examples/dsl_app_context.rb +8 -0
  188. data/spec/shoes/shared_examples/hover_leave.rb +11 -0
  189. data/spec/shoes/shared_examples/parent.rb +6 -0
  190. data/spec/shoes/shared_examples/scroll.rb +41 -0
  191. data/spec/shoes/shared_examples/shared_element_method.rb +60 -0
  192. data/spec/shoes/shared_examples/slot.rb +331 -0
  193. data/spec/shoes/shared_examples/state.rb +19 -0
  194. data/spec/shoes/shared_examples/style.rb +82 -0
  195. data/spec/shoes/slot_spec.rb +130 -0
  196. data/spec/shoes/sound_spec.rb +15 -0
  197. data/spec/shoes/span_spec.rb +112 -0
  198. data/spec/shoes/spec_helper.rb +24 -0
  199. data/spec/shoes/stack_spec.rb +79 -0
  200. data/spec/shoes/star_spec.rb +31 -0
  201. data/spec/shoes/text_block_dimensions_spec.rb +75 -0
  202. data/spec/shoes/text_block_spec.rb +270 -0
  203. data/spec/shoes/url_spec.rb +68 -0
  204. data/spec/shoes/widget_spec.rb +70 -0
  205. data/spec/shoes_spec.rb +44 -0
  206. data/spec/spec_helper.rb +18 -0
  207. data/static/Shoes.icns +0 -0
  208. data/static/shoes-icon.png +0 -0
  209. metadata +354 -0
@@ -0,0 +1,19 @@
1
+ shared_examples_for "object with state" do
2
+ let(:input_opts) { {:state => "disabled"} }
3
+
4
+ it "should initialize" do
5
+ expect(subject.state).to eq("disabled")
6
+ end
7
+
8
+ it "should enable" do
9
+ expect(subject.gui).to receive(:enabled).with(true)
10
+ subject.state = nil
11
+ expect(subject.state).to eq(nil)
12
+ end
13
+
14
+ it "should disable" do
15
+ expect(subject.gui).to receive(:enabled).with(false)
16
+ subject.state = "disabled"
17
+ expect(subject.state).to eq("disabled")
18
+ end
19
+ end
@@ -0,0 +1,82 @@
1
+ shared_examples_for "object with style" do
2
+
3
+ def uses_app_default?(key)
4
+ if defined? self.class::STYLES
5
+ subject.style[key] && !subject.class::STYLES[key]
6
+ else
7
+ subject.style[key]
8
+ end
9
+ end
10
+
11
+ describe 'using app-level styles' do
12
+
13
+ it 'initially uses app defaults' do
14
+ app.style.each do |key, value|
15
+ expect(subject.style[key]).to eq(value) if uses_app_default? key
16
+ end
17
+ end
18
+
19
+ it 'overwrites app defaults' do
20
+ subject.style(fill: '#fff')
21
+ expect(subject.style[:fill]).not_to eq(app.style[:fill])
22
+ end
23
+ end
24
+
25
+ describe 'using element-level styles' do
26
+ let(:arg_styles) { {jellybean: 'blueberry'} }
27
+
28
+ it 'uses element defaults' do
29
+ user_facing_app.style(subject.class, jellybean: 'pumpkin')
30
+ expect(subject_without_style.style[:jellybean]).to eq('pumpkin')
31
+ end
32
+
33
+ it 'overwrites element defaults' do
34
+ user_facing_app.style(subject.class, jellybean: 'pumpkin')
35
+ expect(subject_with_style.style[:jellybean]).to eq('blueberry')
36
+ end
37
+ end
38
+
39
+ describe 'using the style method' do
40
+
41
+ it "merges new styles" do
42
+ old_style = subject.style
43
+ subject.style(left: 100, top: 50)
44
+ expect(subject.style).to eq(old_style.merge(left: 100, top: 50))
45
+ end
46
+
47
+ it 'calls update_style when the style is changed' do
48
+ allow(subject).to receive(:update_style)
49
+ subject.style left: 50
50
+ expect(subject).to have_received(:update_style)
51
+ end
52
+
53
+ it 'does not call update_style when style is called without args' do
54
+ allow(subject).to receive(:update_style)
55
+ subject.style
56
+ expect(subject).not_to have_received(:update_style)
57
+ end
58
+
59
+ it 'does not call update_style when style is unchanged' do
60
+ allow(subject).to receive(:update_style)
61
+ old_left = subject.style[:left]
62
+ subject.style(left: old_left)
63
+ expect(subject).not_to have_received(:update_style)
64
+ end
65
+ end
66
+
67
+ describe 'using setters and getters' do
68
+
69
+ it 'has a style setter for all styles' do
70
+ subject.supported_styles.each do |style|
71
+ expect(subject).to respond_to("#{style}=".to_sym)
72
+ end
73
+ end
74
+
75
+ it 'has a style getter for all styles' do
76
+ subject.supported_styles.each do |style|
77
+ expect(subject).to respond_to("#{style}".to_sym)
78
+ end
79
+ end
80
+ end
81
+
82
+ end
@@ -0,0 +1,130 @@
1
+ require 'shoes/spec_helper'
2
+
3
+ describe Shoes::Slot do
4
+ include_context "dsl app"
5
+ let(:parent) { app }
6
+
7
+ let(:left) { 44 }
8
+ let(:top) { 66 }
9
+ let(:width) { 111 }
10
+ let(:height) { 333 }
11
+ let(:input_opts) { {left: left, top: top, width: width, height: height} }
12
+ subject(:slot) { Shoes::Slot.new(app, parent, input_opts) }
13
+
14
+ it_behaves_like "object with dimensions"
15
+
16
+ it_behaves_like "object with style" do
17
+ let(:subject_without_style) { Shoes::Slot.new(app, parent) }
18
+ let(:subject_with_style) { Shoes::Slot.new(app, parent, arg_styles) }
19
+ end
20
+
21
+ describe "relative dimensions from parent" do
22
+ subject { Shoes::Slot.new(app, parent, relative_opts) }
23
+ it_behaves_like "object with relative dimensions"
24
+ end
25
+
26
+ describe "negative dimensions" do
27
+ subject { Shoes::Slot.new(app, parent, negative_opts) }
28
+ it_behaves_like "object with negative dimensions"
29
+ end
30
+
31
+ describe '#clear' do
32
+
33
+ def add_text_block
34
+ Shoes::TextBlock.new app, slot, ['text']
35
+ end
36
+
37
+ before :each do
38
+ 10.times do
39
+ add_text_block
40
+ end
41
+ end
42
+
43
+ it 'sends remove to all children' do
44
+ subject.contents.each do |element|
45
+ expect(element).to receive(:remove).and_call_original
46
+ end
47
+ subject.clear
48
+ end
49
+
50
+ it 'removes everything' do
51
+ subject.clear
52
+ expect(subject.contents).to be_empty
53
+ end
54
+
55
+ describe 'with a block' do
56
+ before :each do
57
+ subject.clear {add_text_block}
58
+ end
59
+
60
+ it 'has one element afterwards' do
61
+ expect(subject.contents.size).to eq 1
62
+ end
63
+ end
64
+
65
+ end
66
+
67
+ describe '#remove_child' do
68
+ let(:element) {Shoes::FakeElement.new subject}
69
+
70
+ before :each do
71
+ subject.add_child element
72
+ end
73
+
74
+ it 'removes the element' do
75
+ subject.remove_child element
76
+ expect(subject.contents).to be_empty
77
+ end
78
+
79
+ describe '2 elements' do
80
+ let(:element2) {Shoes::FakeElement.new subject}
81
+
82
+ before :each do
83
+ subject.add_child element2
84
+ subject.remove_child element
85
+ end
86
+
87
+ it 'has one element remaining' do
88
+ expect(subject.contents.size).to eq 1
89
+ end
90
+
91
+ it 'has the second element remaining' do
92
+ expect(subject.contents).to include element2
93
+ end
94
+ end
95
+ end
96
+
97
+ describe "hover" do
98
+ let(:callable) { double("block", call: nil) }
99
+ let(:block) { Proc.new { callable.call } }
100
+
101
+ it "doesn't need hover proc to be called" do
102
+ expect(callable).to_not receive(:call)
103
+ subject.mouse_hovered
104
+ end
105
+
106
+ it "calls block on mouse_hovered" do
107
+ expect(callable).to receive(:call)
108
+
109
+ subject.hover(block)
110
+ subject.mouse_hovered
111
+ end
112
+ end
113
+
114
+ describe "leave" do
115
+ let(:callable) { double("block", call: nil) }
116
+ let(:block) { Proc.new { callable.call } }
117
+
118
+ it "doesn't need leave proc to be called" do
119
+ expect(callable).to_not receive(:call)
120
+ subject.mouse_left
121
+ end
122
+
123
+ it "calls block on mouse_left" do
124
+ expect(callable).to receive(:call)
125
+
126
+ subject.leave(block)
127
+ subject.mouse_left
128
+ end
129
+ end
130
+ end
@@ -0,0 +1,15 @@
1
+ require 'shoes/spec_helper'
2
+
3
+ describe Shoes::Sound do
4
+ let(:parent) { double("parent") }
5
+ let(:filepath) { "../../samples/sounds/61847__simon-rue__boink-v3.wav" }
6
+ subject { Shoes::Sound.new(parent, filepath) }
7
+
8
+ its(:filepath) { should eq(filepath) }
9
+ its(:parent) { should be(parent) }
10
+
11
+ it "delegates play to gui" do
12
+ expect(subject.gui).to receive(:play)
13
+ subject.play
14
+ end
15
+ end
@@ -0,0 +1,112 @@
1
+ require 'shoes/spec_helper'
2
+
3
+ describe Shoes::Span do
4
+ let(:app) { Shoes::App.new }
5
+ let(:style) { {} }
6
+ let(:text) { ['test'] }
7
+ subject(:span) { Shoes::Span.new(text, style) }
8
+
9
+ describe 'span' do
10
+ include InspectHelpers
11
+
12
+ it 'sets style to Span block' do
13
+ expect(app.style[:strikethrough]).not_to be_truthy
14
+
15
+ style = { strikethrough: true }
16
+ result = app.span('test', style)
17
+ expect(result.style[:strikethrough]).to be_truthy
18
+
19
+ expect(app.style[:strikethrough]).not_to be_truthy
20
+ end
21
+
22
+ it 'displays text for #to_s' do
23
+ expect(span.to_s).to eq(text.join)
24
+ end
25
+
26
+ it 'displays (Shoes::Span:0x01234567 "text") for #inspect' do
27
+ expect(span.inspect).to match(/[(]Shoes::Span:#{shoes_object_id_pattern} "#{text.join}"[)]/)
28
+ end
29
+ end
30
+
31
+ describe 'Looking up styles of the parent text' do
32
+ let(:white) {Shoes::COLORS[:white]}
33
+ let(:red) {Shoes::COLORS[:red]}
34
+ it 'does not try to merge with parent style when there are none' do
35
+ parent = double 'parent'
36
+ span.parent_text = parent
37
+ expect {span.style}.to_not raise_error()
38
+ end
39
+
40
+ it 'merges with the styles of the parent text' do
41
+ parent = double 'parent', style: {stroke: white}
42
+ span.parent_text = parent
43
+ expect(span.style[:stroke]).to eq(white)
44
+ end
45
+
46
+ describe 'with own style' do
47
+ let(:style) {{stroke: red}}
48
+ it 'prefers own values over parent text values' do
49
+ parent = double 'parent', style: {stroke: white}
50
+ span.parent_text = parent
51
+ expect(span.style[:stroke]).to eq(red)
52
+ end
53
+ end
54
+ end
55
+
56
+ describe 'setting the text block a span belongs to' do
57
+ it 'can set it' do
58
+ text_block = double 'text block'
59
+ subject.text_block = text_block
60
+ expect(subject.text_block).to eq text_block
61
+ end
62
+ end
63
+
64
+ describe 'code' do
65
+ it 'sets font to Lucida Console' do
66
+ result = app.code 'test'
67
+ expect(result.style[:font]).to eq(('Lucida Console'))
68
+ end
69
+ end
70
+
71
+ describe 'del' do
72
+ it 'sets strikethrough to true' do
73
+ result = app.del 'test'
74
+ expect(result.style[:strikethrough]).to be_truthy
75
+ end
76
+ end
77
+
78
+ describe 'em' do
79
+ it 'sets emphasis to true' do
80
+ result = app.em 'test'
81
+ expect(result.style[:emphasis]).to be_truthy
82
+ end
83
+ end
84
+
85
+ describe 'ins' do
86
+ it 'sets underline to true' do
87
+ result = app.ins 'test'
88
+ expect(result.style[:underline]).to be_truthy
89
+ end
90
+ end
91
+
92
+ describe 'sub' do
93
+ it 'sets rise to -10 and multiplies font size by 0.8' do
94
+ result = app.sub 'test'
95
+ expect(result.style[:rise]).to eq(-10)
96
+ end
97
+ end
98
+
99
+ describe 'sup' do
100
+ it 'sets rise to 10 and multiplies font size by 0.8' do
101
+ result = app.sup 'test'
102
+ expect(result.style[:rise]).to eq(10)
103
+ end
104
+ end
105
+
106
+ describe 'strong' do
107
+ it 'sets weight to true' do
108
+ result = app.strong 'test'
109
+ expect(result.style[:weight]).to be_truthy
110
+ end
111
+ end
112
+ end
@@ -0,0 +1,24 @@
1
+ require 'spec_helper'
2
+
3
+ def it_styles_with(*styles)
4
+ supported_styles = unpack_styles(styles)
5
+ spec_styles(supported_styles)
6
+ end
7
+
8
+ def unpack_styles(styles)
9
+ supported_styles = []
10
+ styles.each do |style|
11
+ if Shoes::Common::Style::STYLE_GROUPS[style]
12
+ Shoes::Common::Style::STYLE_GROUPS[style].each{|style| supported_styles << style}
13
+ else
14
+ supported_styles << style
15
+ end
16
+ end
17
+ supported_styles
18
+ end
19
+
20
+ def spec_styles(supported_styles)
21
+ supported_styles.each do |style|
22
+ it_behaves_like "object that styles with #{style}"
23
+ end
24
+ end
@@ -0,0 +1,79 @@
1
+ require 'shoes/spec_helper'
2
+ require 'shoes/helpers/fake_element'
3
+
4
+ describe Shoes::Stack do
5
+ include_context "dsl app"
6
+
7
+ subject(:stack) { Shoes::Stack.new(app, app, input_opts) }
8
+
9
+ it_behaves_like "Slot"
10
+
11
+ describe 'Context' do
12
+
13
+ class ContextObject
14
+ def initialize(app)
15
+ @app = app
16
+ end
17
+
18
+ def check_self_inside_stack
19
+ inside_stack = nil
20
+ @app.stack do inside_stack = self end
21
+ inside_stack
22
+ end
23
+ end
24
+
25
+ it 'does not change the context' do
26
+ app = Shoes.app do ; end
27
+ context_object = ContextObject.new app
28
+ inside_stack = context_object.check_self_inside_stack
29
+ expect(inside_stack).to be context_object
30
+ end
31
+ end
32
+
33
+ describe 'positioning' do
34
+ it_behaves_like 'positioning through :_position'
35
+ it_behaves_like 'positions the first element in the top left'
36
+ it_behaves_like 'arranges elements underneath each other'
37
+
38
+ describe 'small stack height' do
39
+ let(:input_opts){{height: element.height + 10}}
40
+ it_behaves_like 'set height and contents alignment'
41
+ end
42
+
43
+ describe 'big stack height' do
44
+ let(:input_opts){{height: 1000}}
45
+ it_behaves_like 'set height and contents alignment'
46
+ end
47
+
48
+ describe 'with margin' do
49
+ let(:input_opts){{margin: 27}}
50
+ it_behaves_like 'taking care of margin'
51
+ end
52
+ end
53
+
54
+ describe 'scrolling' do
55
+ include_context "scroll"
56
+ subject { Shoes::Stack.new(app, parent, opts) }
57
+
58
+ context 'when scrollable' do
59
+ let(:scroll) { true }
60
+
61
+ it_behaves_like "scrollable slot"
62
+
63
+ context 'when content overflows' do
64
+ include_context "overflowing content"
65
+ it_behaves_like "scrollable slot with overflowing content"
66
+ end
67
+ end
68
+
69
+ context 'when slot is not scrollable' do
70
+ let(:scroll) { false }
71
+
72
+ its(:scroll) { should be_falsey }
73
+
74
+ it "initializes scroll_top to 0" do
75
+ expect(subject.scroll_top).to eq(0)
76
+ end
77
+ end
78
+ end
79
+ end