shoes-swt 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/lib/shoes/swt.rb +118 -0
- data/lib/shoes/swt/animation.rb +46 -0
- data/lib/shoes/swt/app.rb +314 -0
- data/lib/shoes/swt/arc.rb +71 -0
- data/lib/shoes/swt/background.rb +41 -0
- data/lib/shoes/swt/border.rb +41 -0
- data/lib/shoes/swt/button.rb +18 -0
- data/lib/shoes/swt/check.rb +14 -0
- data/lib/shoes/swt/check_button.rb +19 -0
- data/lib/shoes/swt/color.rb +49 -0
- data/lib/shoes/swt/color_factory.rb +32 -0
- data/lib/shoes/swt/common/child.rb +16 -0
- data/lib/shoes/swt/common/clickable.rb +68 -0
- data/lib/shoes/swt/common/container.rb +28 -0
- data/lib/shoes/swt/common/fill.rb +38 -0
- data/lib/shoes/swt/common/painter.rb +92 -0
- data/lib/shoes/swt/common/painter_updates_position.rb +12 -0
- data/lib/shoes/swt/common/remove.rb +30 -0
- data/lib/shoes/swt/common/resource.rb +29 -0
- data/lib/shoes/swt/common/selection_listener.rb +14 -0
- data/lib/shoes/swt/common/stroke.rb +42 -0
- data/lib/shoes/swt/common/update_position.rb +15 -0
- data/lib/shoes/swt/common/visibility.rb +13 -0
- data/lib/shoes/swt/dialog.rb +90 -0
- data/lib/shoes/swt/disposed_protection.rb +23 -0
- data/lib/shoes/swt/download.rb +24 -0
- data/lib/shoes/swt/font.rb +32 -0
- data/lib/shoes/swt/gradient.rb +92 -0
- data/lib/shoes/swt/image.rb +128 -0
- data/lib/shoes/swt/image_pattern.rb +31 -0
- data/lib/shoes/swt/input_box.rb +73 -0
- data/lib/shoes/swt/key_listener.rb +145 -0
- data/lib/shoes/swt/line.rb +60 -0
- data/lib/shoes/swt/link.rb +31 -0
- data/lib/shoes/swt/link_segment.rb +111 -0
- data/lib/shoes/swt/list_box.rb +48 -0
- data/lib/shoes/swt/mouse_move_listener.rb +67 -0
- data/lib/shoes/swt/oval.rb +52 -0
- data/lib/shoes/swt/progress.rb +35 -0
- data/lib/shoes/swt/radio.rb +29 -0
- data/lib/shoes/swt/radio_group.rb +54 -0
- data/lib/shoes/swt/rect.rb +30 -0
- data/lib/shoes/swt/rect_painter.rb +23 -0
- data/lib/shoes/swt/redrawing_aspect.rb +123 -0
- data/lib/shoes/swt/shape.rb +133 -0
- data/lib/shoes/swt/shoes_layout.rb +43 -0
- data/lib/shoes/swt/slot.rb +39 -0
- data/lib/shoes/swt/sound.rb +119 -0
- data/lib/shoes/swt/star.rb +50 -0
- data/lib/shoes/swt/support/jl1.0.1.jar +0 -0
- data/lib/shoes/swt/support/jogg-0.0.7.jar +0 -0
- data/lib/shoes/swt/support/jorbis-0.0.15.jar +0 -0
- data/lib/shoes/swt/support/log4j-1.2.16.jar +0 -0
- data/lib/shoes/swt/support/mp3spi1.9.5.jar +0 -0
- data/lib/shoes/swt/support/tritonus_share.jar +0 -0
- data/lib/shoes/swt/support/vorbisspi1.0.3.jar +0 -0
- data/lib/shoes/swt/swt_button.rb +56 -0
- data/lib/shoes/swt/text_block.rb +124 -0
- data/lib/shoes/swt/text_block/centered_text_segment.rb +22 -0
- data/lib/shoes/swt/text_block/cursor_painter.rb +53 -0
- data/lib/shoes/swt/text_block/fitter.rb +212 -0
- data/lib/shoes/swt/text_block/painter.rb +47 -0
- data/lib/shoes/swt/text_block/text_font_factory.rb +50 -0
- data/lib/shoes/swt/text_block/text_segment.rb +108 -0
- data/lib/shoes/swt/text_block/text_segment_collection.rb +160 -0
- data/lib/shoes/swt/text_block/text_style_factory.rb +88 -0
- data/lib/shoes/swt/timer.rb +19 -0
- data/lib/shoes/swt/tooling/leak_hunter.rb +35 -0
- data/lib/shoes/swt/version.rb +5 -0
- data/manifests/common.rb +34 -0
- data/manifests/shoes-swt.rb +29 -0
- data/shoes-swt.gemspec +24 -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/spec/swt_shoes/animation_spec.rb +86 -0
- data/spec/swt_shoes/app_spec.rb +84 -0
- data/spec/swt_shoes/arc_spec.rb +103 -0
- data/spec/swt_shoes/background_spec.rb +67 -0
- data/spec/swt_shoes/border_spec.rb +52 -0
- data/spec/swt_shoes/button_spec.rb +101 -0
- data/spec/swt_shoes/check_spec.rb +28 -0
- data/spec/swt_shoes/color_factory_spec.rb +49 -0
- data/spec/swt_shoes/color_spec.rb +67 -0
- data/spec/swt_shoes/common/painter_spec.rb +49 -0
- data/spec/swt_shoes/common/remove_spec.rb +53 -0
- data/spec/swt_shoes/configuration_spec.rb +12 -0
- data/spec/swt_shoes/dialog_spec.rb +106 -0
- data/spec/swt_shoes/disposed_protection_spec.rb +49 -0
- data/spec/swt_shoes/flow_spec.rb +36 -0
- data/spec/swt_shoes/font_spec.rb +33 -0
- data/spec/swt_shoes/gradient_spec.rb +31 -0
- data/spec/swt_shoes/image_pattern_spec.rb +35 -0
- data/spec/swt_shoes/image_spec.rb +100 -0
- data/spec/swt_shoes/input_box_spec.rb +116 -0
- data/spec/swt_shoes/integration_spec.rb +27 -0
- data/spec/swt_shoes/key_listener_spec.rb +325 -0
- data/spec/swt_shoes/line_spec.rb +49 -0
- data/spec/swt_shoes/link_segment_spec.rb +120 -0
- data/spec/swt_shoes/link_spec.rb +54 -0
- data/spec/swt_shoes/list_box_spec.rb +56 -0
- data/spec/swt_shoes/minimal.png +0 -0
- data/spec/swt_shoes/mouse_move_listener_spec.rb +123 -0
- data/spec/swt_shoes/oval_spec.rb +51 -0
- data/spec/swt_shoes/progress_spec.rb +44 -0
- data/spec/swt_shoes/radio_group_spec.rb +73 -0
- data/spec/swt_shoes/radio_spec.rb +56 -0
- data/spec/swt_shoes/rect_painter_spec.rb +45 -0
- data/spec/swt_shoes/rect_spec.rb +19 -0
- data/spec/swt_shoes/shape_spec.rb +84 -0
- data/spec/swt_shoes/shared_examples/button.rb +21 -0
- data/spec/swt_shoes/shared_examples/clickable.rb +85 -0
- data/spec/swt_shoes/shared_examples/movable.rb +36 -0
- data/spec/swt_shoes/shared_examples/paintable.rb +7 -0
- data/spec/swt_shoes/shared_examples/painter.rb +83 -0
- data/spec/swt_shoes/shared_examples/pattern.rb +32 -0
- data/spec/swt_shoes/shared_examples/removable.rb +41 -0
- data/spec/swt_shoes/shared_examples/swt_app_context.rb +23 -0
- data/spec/swt_shoes/shared_examples/visibility.rb +15 -0
- data/spec/swt_shoes/shell_control_listener_spec.rb +23 -0
- data/spec/swt_shoes/slot_spec.rb +24 -0
- data/spec/swt_shoes/sound.rb +10 -0
- data/spec/swt_shoes/spec_helper.rb +31 -0
- data/spec/swt_shoes/star_spec.rb +47 -0
- data/spec/swt_shoes/text_block/centered_text_segment_spec.rb +16 -0
- data/spec/swt_shoes/text_block/cursor_painter_spec.rb +120 -0
- data/spec/swt_shoes/text_block/fitter_spec.rb +213 -0
- data/spec/swt_shoes/text_block/painter_spec.rb +212 -0
- data/spec/swt_shoes/text_block/text_font_factory_spec.rb +40 -0
- data/spec/swt_shoes/text_block/text_segment_collection_spec.rb +256 -0
- data/spec/swt_shoes/text_block/text_segment_spec.rb +135 -0
- data/spec/swt_shoes/text_block_spec.rb +199 -0
- metadata +496 -0
@@ -0,0 +1,26 @@
|
|
1
|
+
shared_examples "an element that can respond to change" do
|
2
|
+
describe "when passing a block to the constructor" do
|
3
|
+
it "should notify the block of change events" do
|
4
|
+
expect(input_block).to receive(:call).with(subject)
|
5
|
+
subject.call_change_listeners
|
6
|
+
end
|
7
|
+
end
|
8
|
+
|
9
|
+
describe "when setting up a callback with #change" do
|
10
|
+
it "should notify the callback of change events" do
|
11
|
+
called = false
|
12
|
+
subject.change do |element|
|
13
|
+
called = true
|
14
|
+
end
|
15
|
+
subject.call_change_listeners
|
16
|
+
expect(called).to be_truthy
|
17
|
+
end
|
18
|
+
|
19
|
+
it "should pass the element itself to the callback" do
|
20
|
+
subject.change do |element|
|
21
|
+
expect(element).to eq(subject)
|
22
|
+
end
|
23
|
+
subject.call_change_listeners
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
shared_examples_for "movable object" do
|
2
|
+
it "moves" do
|
3
|
+
subject.instance_variable_set(:@app, app)
|
4
|
+
expect(subject.move(300, 200)).to eq(subject)
|
5
|
+
expect(subject.left).to eq(300)
|
6
|
+
expect(subject.top).to eq(200)
|
7
|
+
end
|
8
|
+
|
9
|
+
describe "displacing" do
|
10
|
+
it "displaces backend object" do
|
11
|
+
expect(subject.gui).to receive(:update_position)
|
12
|
+
subject.displace(300, 200)
|
13
|
+
end
|
14
|
+
|
15
|
+
it "does not change reported values of #left and #top" do
|
16
|
+
# no error from calling set location with nil values due to unset values
|
17
|
+
allow(subject.gui).to receive :update_position
|
18
|
+
original_left = subject.left
|
19
|
+
original_top = subject.top
|
20
|
+
subject.displace(300, 200)
|
21
|
+
expect(subject.left).to eq(original_left)
|
22
|
+
expect(subject.top).to eq(original_top)
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
shared_examples_for "left, top as center" do | *params |
|
28
|
+
let(:centered_object) { described_class.new(app, parent, left, top, width, height, *params, :center => true) }
|
29
|
+
it "should now be located somewhere" do
|
30
|
+
expect(centered_object.left).to eq(left-(width/2))
|
31
|
+
expect(centered_object.top).to eq(top-(height/2))
|
32
|
+
expect(centered_object.width).to eq(width)
|
33
|
+
expect(centered_object.height).to eq(height)
|
34
|
+
end
|
35
|
+
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
shared_examples_for "object with dimensions" do
|
2
|
+
it "should initialize" do
|
3
|
+
expect(subject.left).to eq(left)
|
4
|
+
expect(subject.top).to eq(top)
|
5
|
+
expect(subject.width).to eq(width)
|
6
|
+
expect(subject.height).to eq(height)
|
7
|
+
end
|
8
|
+
end
|
9
|
+
|
10
|
+
shared_examples_for "object with relative dimensions" do
|
11
|
+
let(:relative_width) { 0.5 }
|
12
|
+
let(:relative_height) { 0.5 }
|
13
|
+
let(:relative_opts) { {left: left, top: top, width: relative_width, height: relative_height} }
|
14
|
+
|
15
|
+
it "should initialize based on parent dimensions" do
|
16
|
+
expect(subject.left).to eq left
|
17
|
+
expect(subject.top).to eq top
|
18
|
+
expect(subject.width).to be_within(1).of(parent.element_width / 2)
|
19
|
+
expect(subject.height).to be_within(1).of(parent.element_height / 2)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
shared_examples_for "object with negative dimensions" do
|
24
|
+
let(:negative_opts) { {left: left, top: top, width: -width, height: -height} }
|
25
|
+
|
26
|
+
it "should initialize based on parent dimensions" do
|
27
|
+
expect(subject.left).to eq(left)
|
28
|
+
expect(subject.top).to eq(top)
|
29
|
+
expect(subject.width).to eq(parent.element_width - width)
|
30
|
+
expect(subject.height).to eq(parent.element_height - height)
|
31
|
+
end
|
32
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
# Shared examples for Shoes::App and Shoes::Slot (flow and stack).
|
2
|
+
# If DSL methods can be called with multiple number of arguments,
|
3
|
+
# and if they set certain defaults, then that what needs to be tested
|
4
|
+
# here.
|
5
|
+
# There are individual specs for the different Shoes elements, so
|
6
|
+
# we don't need to test how they work in details. Here we just test that
|
7
|
+
# the DSL methods construct elements correctly.
|
8
|
+
shared_examples "DSL container" do
|
9
|
+
let(:dsl) { app }
|
10
|
+
|
11
|
+
%w[
|
12
|
+
animate
|
13
|
+
arc
|
14
|
+
background
|
15
|
+
button
|
16
|
+
border
|
17
|
+
cap
|
18
|
+
check
|
19
|
+
edit_box
|
20
|
+
edit_line
|
21
|
+
fill
|
22
|
+
flow
|
23
|
+
gradient
|
24
|
+
image
|
25
|
+
line
|
26
|
+
nofill
|
27
|
+
nostroke
|
28
|
+
oval
|
29
|
+
pattern
|
30
|
+
progress
|
31
|
+
rect
|
32
|
+
rgb
|
33
|
+
shape
|
34
|
+
star
|
35
|
+
stroke
|
36
|
+
strokewidth
|
37
|
+
style
|
38
|
+
video
|
39
|
+
].each do |method|
|
40
|
+
include_examples "#{method} DSL method"
|
41
|
+
end
|
42
|
+
|
43
|
+
include_examples "text element DSL methods"
|
44
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
shared_examples_for "animate DSL method" do
|
2
|
+
context "defaults" do
|
3
|
+
let(:animation) { dsl.animate {} }
|
4
|
+
|
5
|
+
it "is a Shoes::Animation" do
|
6
|
+
expect(animation).to be_an_instance_of(Shoes::Animation)
|
7
|
+
end
|
8
|
+
|
9
|
+
it "framerate is 10" do
|
10
|
+
expect(animation.framerate).to eq 10
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
context "with numeric argument" do
|
15
|
+
let(:animation) { dsl.animate(13) {} }
|
16
|
+
|
17
|
+
it "sets framerate" do
|
18
|
+
expect(animation.framerate).to eq(13)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
context "with hash argument" do
|
23
|
+
let(:animation) { dsl.animate(:framerate => 17) {} }
|
24
|
+
|
25
|
+
it "sets framerate" do
|
26
|
+
expect(animation.framerate).to eq(17)
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
shared_context "style context" do
|
2
|
+
let(:fill_color) { Shoes::COLORS.fetch(:tomato) }
|
3
|
+
let(:stroke_color) { Shoes::COLORS.fetch(:chartreuse) }
|
4
|
+
|
5
|
+
before :each do
|
6
|
+
subject.fill fill_color
|
7
|
+
subject.stroke stroke_color
|
8
|
+
end
|
9
|
+
end
|
10
|
+
|
11
|
+
shared_examples_for "persistent stroke" do
|
12
|
+
include_context "style context"
|
13
|
+
|
14
|
+
it "passes to element" do
|
15
|
+
expect(element.stroke).to eq(stroke_color)
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
shared_examples_for "persistent fill" do
|
20
|
+
include_context "style context"
|
21
|
+
|
22
|
+
it "passes to element" do
|
23
|
+
expect(element.fill).to eq(fill_color)
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
shared_examples_for "arc DSL method" do
|
28
|
+
let(:arc) { dsl.arc(13, 44, 200, 300, 0, Shoes::TWO_PI) }
|
29
|
+
|
30
|
+
it "creates a Shoes::Arc" do
|
31
|
+
expect(arc).to be_an_instance_of(Shoes::Arc)
|
32
|
+
end
|
33
|
+
|
34
|
+
it "raises an ArgumentError" do
|
35
|
+
expect { dsl.arc(30) }.to raise_exception(ArgumentError)
|
36
|
+
end
|
37
|
+
|
38
|
+
it_behaves_like "persistent fill" do
|
39
|
+
let(:element) { arc }
|
40
|
+
end
|
41
|
+
|
42
|
+
it_behaves_like "persistent stroke" do
|
43
|
+
let(:element) { arc }
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
shared_examples_for "background DSL method" do
|
2
|
+
context "with a valid hex string" do
|
3
|
+
it "sets color" do
|
4
|
+
background = subject.background("#fff")
|
5
|
+
expect(background.fill).to eq(Shoes::COLORS[:white])
|
6
|
+
end
|
7
|
+
end
|
8
|
+
|
9
|
+
context "with an invalid hex string" do
|
10
|
+
it 'raises an argument error' do
|
11
|
+
expect{ subject.background('#ffq') }.to raise_error('Bad hex color: #ffq')
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
context 'with no valid image' do
|
16
|
+
it 'ignores the background' do
|
17
|
+
expect{ subject.background('fake-shoes.jpg') }.not_to raise_error
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
context 'with a valid image' do
|
22
|
+
it 'creates a Shoes::Background' do
|
23
|
+
expect(subject.background('static/shoes-icon.png')).to be_an_instance_of(Shoes::Background)
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,11 @@
|
|
1
|
+
shared_examples_for 'check DSL method' do
|
2
|
+
let(:checkbox) { dsl.check }
|
3
|
+
|
4
|
+
it 'should be a checkbox' do
|
5
|
+
expect(checkbox).to be_instance_of Shoes::Check
|
6
|
+
end
|
7
|
+
|
8
|
+
it 'should be unchecked by default' do
|
9
|
+
expect(checkbox.checked?).to be_falsey
|
10
|
+
end
|
11
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
shared_examples_for "editable element" do
|
2
|
+
subject { super.public_send(dsl_method, *args) }
|
3
|
+
|
4
|
+
describe "with no arguments" do
|
5
|
+
let(:args) { [] }
|
6
|
+
its(:text) { should == '' }
|
7
|
+
its(:width) { should == klazz::STYLES[:width] }
|
8
|
+
its(:height) { should == klazz::STYLES[:height] }
|
9
|
+
end
|
10
|
+
|
11
|
+
describe "with a single text argument" do
|
12
|
+
let(:args) { ['Hello text here'] }
|
13
|
+
|
14
|
+
its(:text) { should == 'Hello text here' }
|
15
|
+
end
|
16
|
+
|
17
|
+
describe "with a style hash" do
|
18
|
+
let(:args) { [{width: 100, height: 50}] }
|
19
|
+
|
20
|
+
its(:text) { should == '' }
|
21
|
+
end
|
22
|
+
|
23
|
+
describe "with a text argument and a style hash" do
|
24
|
+
let(:args) { ['Hello text here', {width: 100, height: 50}] }
|
25
|
+
its(:text) { should == 'Hello text here' }
|
26
|
+
its(:width) { should == 100 }
|
27
|
+
its(:height) { should == 50 }
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
shared_examples_for "fill DSL method" do
|
2
|
+
let(:color) { Shoes::COLORS.fetch :tomato }
|
3
|
+
|
4
|
+
it "returns a color" do
|
5
|
+
expect(dsl.fill(color).class).to eq(Shoes::Color)
|
6
|
+
end
|
7
|
+
|
8
|
+
# This works differently on a container than on a normal element
|
9
|
+
it "sets on receiver" do
|
10
|
+
dsl.fill color
|
11
|
+
expect(dsl.style[:fill]).to eq(color)
|
12
|
+
end
|
13
|
+
|
14
|
+
it "applies to subsequently created objects" do
|
15
|
+
dsl.fill color
|
16
|
+
oval = dsl.oval(10, 10, 100, 100)
|
17
|
+
expect(oval.fill).to eq(color)
|
18
|
+
end
|
19
|
+
|
20
|
+
context "with hex string" do
|
21
|
+
let(:color) { "#fff" }
|
22
|
+
|
23
|
+
it "sets the color" do
|
24
|
+
expect(dsl.fill(color)).to eq(Shoes::COLORS[:white])
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
shared_examples_for "flow DSL method" do
|
2
|
+
let(:flow) {dsl.flow}
|
3
|
+
|
4
|
+
it "creates a Shoes::Flow" do
|
5
|
+
expect(flow).to be_an_instance_of(Shoes::Flow)
|
6
|
+
end
|
7
|
+
|
8
|
+
it 'reports an instance of Shoes::App when asked for its app' do
|
9
|
+
expect(flow.app.class).to eq Shoes::App
|
10
|
+
end
|
11
|
+
|
12
|
+
it 'reports an object that responds to stack when asked for its app' do
|
13
|
+
expect(flow.app).to respond_to :stack
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,62 @@
|
|
1
|
+
shared_examples_for "creating gradient" do
|
2
|
+
it "returns correct gradient according to #to_s" do
|
3
|
+
expect(gradient.to_s).to eq("(Shoes::Gradient)")
|
4
|
+
end
|
5
|
+
|
6
|
+
it "returns correct gradient according to #inspect" do
|
7
|
+
expect(gradient.inspect).to match("[(]Shoes::Gradient:#{shoes_object_id_pattern} rgb[(]255, 0, 0[)]->rgb[(]0, 0, 255[)][)]")
|
8
|
+
end
|
9
|
+
end
|
10
|
+
|
11
|
+
shared_examples_for "gradient DSL method" do
|
12
|
+
context "with colors" do
|
13
|
+
include InspectHelpers
|
14
|
+
|
15
|
+
let(:red) { Shoes::Color.new(255, 0, 0) }
|
16
|
+
let(:blue) { Shoes::Color.new(0, 0, 255) }
|
17
|
+
|
18
|
+
context "two separate" do
|
19
|
+
it_behaves_like "creating gradient" do
|
20
|
+
let(:gradient) { dsl.gradient(red, blue) }
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
context "as range" do
|
25
|
+
it_behaves_like "creating gradient" do
|
26
|
+
let(:gradient) { dsl.gradient(red..blue) }
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
context "with strings" do
|
32
|
+
include InspectHelpers
|
33
|
+
|
34
|
+
let(:red) { "#f00" }
|
35
|
+
let(:blue) { "#00f" }
|
36
|
+
|
37
|
+
context "two separate" do
|
38
|
+
it_behaves_like "creating gradient" do
|
39
|
+
let(:gradient) { dsl.gradient(red, blue) }
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
context "as range" do
|
44
|
+
it_behaves_like "creating gradient" do
|
45
|
+
let(:gradient) { dsl.gradient(red..blue) }
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
context "with gradient" do
|
51
|
+
include InspectHelpers
|
52
|
+
|
53
|
+
it_behaves_like "creating gradient" do
|
54
|
+
let(:gradient_arg) { dsl.gradient("#f00", "#00f") }
|
55
|
+
let(:gradient) { dsl.gradient(gradient_arg) }
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
it "fails on bad input" do
|
60
|
+
expect { dsl.gradient(100) }.to raise_error(ArgumentError)
|
61
|
+
end
|
62
|
+
end
|