shoes-dsl 4.0.0.pre2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/CHANGELOG +84 -0
- data/Gemfile +24 -0
- data/Guardfile +11 -0
- data/LICENSE +31 -0
- data/README.md +201 -0
- data/ext/install/Rakefile +29 -0
- data/ext/install/shoes.bat +9 -0
- data/fonts/Coolvetica.ttf +0 -0
- data/fonts/Lacuna.ttf +0 -0
- data/lib/shoes/animation.rb +56 -0
- data/lib/shoes/app.rb +131 -0
- data/lib/shoes/arc.rb +25 -0
- data/lib/shoes/background.rb +24 -0
- data/lib/shoes/border.rb +24 -0
- data/lib/shoes/builtin_methods.rb +77 -0
- data/lib/shoes/button.rb +30 -0
- data/lib/shoes/check_button.rb +44 -0
- data/lib/shoes/color.rb +385 -0
- data/lib/shoes/common/background_element.rb +9 -0
- data/lib/shoes/common/changeable.rb +34 -0
- data/lib/shoes/common/clickable.rb +24 -0
- data/lib/shoes/common/inspect.rb +14 -0
- data/lib/shoes/common/positioning.rb +30 -0
- data/lib/shoes/common/registration.rb +33 -0
- data/lib/shoes/common/remove.rb +10 -0
- data/lib/shoes/common/state.rb +18 -0
- data/lib/shoes/common/style.rb +152 -0
- data/lib/shoes/common/style_normalizer.rb +16 -0
- data/lib/shoes/common/ui_element.rb +11 -0
- data/lib/shoes/common/visibility.rb +40 -0
- data/lib/shoes/configuration.rb +96 -0
- data/lib/shoes/dialog.rb +27 -0
- data/lib/shoes/dimension.rb +239 -0
- data/lib/shoes/dimensions.rb +209 -0
- data/lib/shoes/download.rb +121 -0
- data/lib/shoes/dsl.rb +591 -0
- data/lib/shoes/font.rb +49 -0
- data/lib/shoes/gradient.rb +31 -0
- data/lib/shoes/image.rb +29 -0
- data/lib/shoes/image_pattern.rb +12 -0
- data/lib/shoes/input_box.rb +60 -0
- data/lib/shoes/internal_app.rb +219 -0
- data/lib/shoes/key_event.rb +17 -0
- data/lib/shoes/line.rb +87 -0
- data/lib/shoes/link.rb +59 -0
- data/lib/shoes/link_hover.rb +5 -0
- data/lib/shoes/list_box.rb +50 -0
- data/lib/shoes/logger.rb +66 -0
- data/lib/shoes/logger/ruby.rb +18 -0
- data/lib/shoes/mock.rb +31 -0
- data/lib/shoes/mock/animation.rb +8 -0
- data/lib/shoes/mock/app.rb +47 -0
- data/lib/shoes/mock/arc.rb +9 -0
- data/lib/shoes/mock/background.rb +10 -0
- data/lib/shoes/mock/border.rb +7 -0
- data/lib/shoes/mock/button.rb +10 -0
- data/lib/shoes/mock/check.rb +25 -0
- data/lib/shoes/mock/clickable.rb +8 -0
- data/lib/shoes/mock/common_methods.rb +12 -0
- data/lib/shoes/mock/dialog.rb +13 -0
- data/lib/shoes/mock/download.rb +18 -0
- data/lib/shoes/mock/font.rb +17 -0
- data/lib/shoes/mock/image.rb +13 -0
- data/lib/shoes/mock/image_pattern.rb +9 -0
- data/lib/shoes/mock/input_box.rb +30 -0
- data/lib/shoes/mock/keypress.rb +10 -0
- data/lib/shoes/mock/keyrelease.rb +10 -0
- data/lib/shoes/mock/line.rb +14 -0
- data/lib/shoes/mock/link.rb +12 -0
- data/lib/shoes/mock/list_box.rb +19 -0
- data/lib/shoes/mock/oval.rb +12 -0
- data/lib/shoes/mock/progress.rb +10 -0
- data/lib/shoes/mock/radio.rb +27 -0
- data/lib/shoes/mock/rect.rb +14 -0
- data/lib/shoes/mock/shape.rb +20 -0
- data/lib/shoes/mock/slot.rb +16 -0
- data/lib/shoes/mock/sound.rb +8 -0
- data/lib/shoes/mock/star.rb +14 -0
- data/lib/shoes/mock/text_block.rb +36 -0
- data/lib/shoes/mock/timer.rb +8 -0
- data/lib/shoes/not_implemented_error.rb +4 -0
- data/lib/shoes/oval.rb +20 -0
- data/lib/shoes/point.rb +54 -0
- data/lib/shoes/progress.rb +25 -0
- data/lib/shoes/radio.rb +16 -0
- data/lib/shoes/rect.rb +21 -0
- data/lib/shoes/renamed_delegate.rb +15 -0
- data/lib/shoes/shape.rb +158 -0
- data/lib/shoes/slot.rb +271 -0
- data/lib/shoes/slot_contents.rb +50 -0
- data/lib/shoes/sound.rb +18 -0
- data/lib/shoes/span.rb +16 -0
- data/lib/shoes/star.rb +45 -0
- data/lib/shoes/text.rb +24 -0
- data/lib/shoes/text_block.rb +143 -0
- data/lib/shoes/text_block_dimensions.rb +52 -0
- data/lib/shoes/timer.rb +12 -0
- data/lib/shoes/url.rb +44 -0
- data/lib/shoes/version.rb +3 -0
- data/lib/shoes/widget.rb +69 -0
- data/manifests/common.rb +34 -0
- data/manifests/shoes-dsl.rb +34 -0
- data/shoes-dsl.gemspec +19 -0
- data/spec/code_coverage.rb +14 -0
- data/spec/shoes/animation_spec.rb +65 -0
- data/spec/shoes/app_spec.rb +484 -0
- data/spec/shoes/arc_spec.rb +51 -0
- data/spec/shoes/background_spec.rb +53 -0
- data/spec/shoes/border_spec.rb +47 -0
- data/spec/shoes/builtin_methods_spec.rb +110 -0
- data/spec/shoes/button_spec.rb +44 -0
- data/spec/shoes/check_spec.rb +35 -0
- data/spec/shoes/cli_spec.rb +15 -0
- data/spec/shoes/color_spec.rb +408 -0
- data/spec/shoes/common/inspect_spec.rb +26 -0
- data/spec/shoes/common/remove_spec.rb +38 -0
- data/spec/shoes/common/style_normalizer_spec.rb +28 -0
- data/spec/shoes/common/style_spec.rb +147 -0
- data/spec/shoes/configuration_spec.rb +36 -0
- data/spec/shoes/constants_spec.rb +38 -0
- data/spec/shoes/dialog_spec.rb +163 -0
- data/spec/shoes/dimension_spec.rb +407 -0
- data/spec/shoes/dimensions_spec.rb +837 -0
- data/spec/shoes/download_spec.rb +142 -0
- data/spec/shoes/flow_spec.rb +133 -0
- data/spec/shoes/font_spec.rb +37 -0
- data/spec/shoes/framework_learning_spec.rb +30 -0
- data/spec/shoes/gradient_spec.rb +32 -0
- data/spec/shoes/helpers/fake_element.rb +17 -0
- data/spec/shoes/helpers/inspect_helpers.rb +5 -0
- data/spec/shoes/helpers/sample17_helper.rb +66 -0
- data/spec/shoes/image_spec.rb +49 -0
- data/spec/shoes/images/shoe.jpg +0 -0
- data/spec/shoes/input_box_spec.rb +80 -0
- data/spec/shoes/integration_spec.rb +20 -0
- data/spec/shoes/internal_app_spec.rb +141 -0
- data/spec/shoes/keypress_spec.rb +11 -0
- data/spec/shoes/keyrelease_spec.rb +12 -0
- data/spec/shoes/line_spec.rb +49 -0
- data/spec/shoes/link_spec.rb +105 -0
- data/spec/shoes/list_box_spec.rb +74 -0
- data/spec/shoes/logger/ruby_spec.rb +8 -0
- data/spec/shoes/logger_spec.rb +45 -0
- data/spec/shoes/oval_spec.rb +24 -0
- data/spec/shoes/point_spec.rb +71 -0
- data/spec/shoes/progress_spec.rb +54 -0
- data/spec/shoes/radio_spec.rb +32 -0
- data/spec/shoes/rect_spec.rb +39 -0
- data/spec/shoes/renamed_delegate_spec.rb +70 -0
- data/spec/shoes/shape_spec.rb +95 -0
- data/spec/shoes/shared_examples/button.rb +6 -0
- data/spec/shoes/shared_examples/changeable.rb +26 -0
- data/spec/shoes/shared_examples/clickable.rb +5 -0
- data/spec/shoes/shared_examples/common_methods.rb +35 -0
- data/spec/shoes/shared_examples/dimensions.rb +32 -0
- data/spec/shoes/shared_examples/dsl.rb +44 -0
- data/spec/shoes/shared_examples/dsl/animate.rb +29 -0
- data/spec/shoes/shared_examples/dsl/arc.rb +45 -0
- data/spec/shoes/shared_examples/dsl/background.rb +26 -0
- data/spec/shoes/shared_examples/dsl/border.rb +10 -0
- data/spec/shoes/shared_examples/dsl/button.rb +5 -0
- data/spec/shoes/shared_examples/dsl/cap.rb +6 -0
- data/spec/shoes/shared_examples/dsl/check.rb +11 -0
- data/spec/shoes/shared_examples/dsl/edit_box.rb +8 -0
- data/spec/shoes/shared_examples/dsl/edit_line.rb +8 -0
- data/spec/shoes/shared_examples/dsl/editable_element.rb +29 -0
- data/spec/shoes/shared_examples/dsl/fill.rb +27 -0
- data/spec/shoes/shared_examples/dsl/flow.rb +15 -0
- data/spec/shoes/shared_examples/dsl/gradient.rb +62 -0
- data/spec/shoes/shared_examples/dsl/image.rb +21 -0
- data/spec/shoes/shared_examples/dsl/line.rb +9 -0
- data/spec/shoes/shared_examples/dsl/nofill.rb +6 -0
- data/spec/shoes/shared_examples/dsl/nostroke.rb +6 -0
- data/spec/shoes/shared_examples/dsl/oval.rb +88 -0
- data/spec/shoes/shared_examples/dsl/pattern.rb +34 -0
- data/spec/shoes/shared_examples/dsl/progress.rb +7 -0
- data/spec/shoes/shared_examples/dsl/rect.rb +92 -0
- data/spec/shoes/shared_examples/dsl/rgb.rb +26 -0
- data/spec/shoes/shared_examples/dsl/shape.rb +21 -0
- data/spec/shoes/shared_examples/dsl/star.rb +48 -0
- data/spec/shoes/shared_examples/dsl/stroke.rb +30 -0
- data/spec/shoes/shared_examples/dsl/strokewidth.rb +19 -0
- data/spec/shoes/shared_examples/dsl/style.rb +32 -0
- data/spec/shoes/shared_examples/dsl/text_elements.rb +81 -0
- data/spec/shoes/shared_examples/dsl/video.rb +5 -0
- data/spec/shoes/shared_examples/dsl_app_context.rb +8 -0
- data/spec/shoes/shared_examples/hover_leave.rb +11 -0
- data/spec/shoes/shared_examples/parent.rb +6 -0
- data/spec/shoes/shared_examples/scroll.rb +41 -0
- data/spec/shoes/shared_examples/shared_element_method.rb +60 -0
- data/spec/shoes/shared_examples/slot.rb +331 -0
- data/spec/shoes/shared_examples/state.rb +19 -0
- data/spec/shoes/shared_examples/style.rb +82 -0
- data/spec/shoes/slot_spec.rb +130 -0
- data/spec/shoes/sound_spec.rb +15 -0
- data/spec/shoes/span_spec.rb +112 -0
- data/spec/shoes/spec_helper.rb +24 -0
- data/spec/shoes/stack_spec.rb +79 -0
- data/spec/shoes/star_spec.rb +31 -0
- data/spec/shoes/text_block_dimensions_spec.rb +75 -0
- data/spec/shoes/text_block_spec.rb +270 -0
- data/spec/shoes/url_spec.rb +68 -0
- data/spec/shoes/widget_spec.rb +70 -0
- data/spec/shoes_spec.rb +44 -0
- data/spec/spec_helper.rb +18 -0
- data/static/Shoes.icns +0 -0
- data/static/shoes-icon.png +0 -0
- 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
|