cuke_modeler 1.5.0 → 3.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +341 -0
- data/LICENSE.txt +1 -1
- data/README.md +22 -15
- data/cuke_modeler.gemspec +15 -9
- data/lib/cuke_modeler/adapters/gherkin_10_adapter.rb +12 -0
- data/lib/cuke_modeler/adapters/gherkin_11_adapter.rb +12 -0
- data/lib/cuke_modeler/adapters/gherkin_12_adapter.rb +12 -0
- data/lib/cuke_modeler/adapters/gherkin_13_adapter.rb +12 -0
- data/lib/cuke_modeler/adapters/gherkin_14_adapter.rb +12 -0
- data/lib/cuke_modeler/adapters/{gherkin_6_adapter.rb → gherkin_9_adapter.rb} +75 -64
- data/lib/cuke_modeler/containing.rb +3 -0
- data/lib/cuke_modeler/described.rb +1 -0
- data/lib/cuke_modeler/models/background.rb +1 -1
- data/lib/cuke_modeler/models/cell.rb +1 -1
- data/lib/cuke_modeler/models/comment.rb +1 -1
- data/lib/cuke_modeler/models/directory.rb +2 -2
- data/lib/cuke_modeler/models/doc_string.rb +1 -1
- data/lib/cuke_modeler/models/example.rb +1 -1
- data/lib/cuke_modeler/models/feature.rb +1 -1
- data/lib/cuke_modeler/models/feature_file.rb +2 -2
- data/lib/cuke_modeler/models/outline.rb +1 -1
- data/lib/cuke_modeler/models/row.rb +1 -1
- data/lib/cuke_modeler/models/scenario.rb +1 -1
- data/lib/cuke_modeler/models/step.rb +32 -3
- data/lib/cuke_modeler/models/table.rb +1 -1
- data/lib/cuke_modeler/models/tag.rb +1 -1
- data/lib/cuke_modeler/named.rb +1 -0
- data/lib/cuke_modeler/nested.rb +1 -0
- data/lib/cuke_modeler/parsed.rb +1 -0
- data/lib/cuke_modeler/parsing.rb +89 -94
- data/lib/cuke_modeler/sourceable.rb +1 -0
- data/lib/cuke_modeler/stepped.rb +1 -0
- data/lib/cuke_modeler/taggable.rb +1 -0
- data/lib/cuke_modeler/version.rb +1 -1
- data/testing/cucumber/features/analysis/step_comparison.feature +25 -0
- data/testing/cucumber/features/analysis/test_comparison.feature +1 -1
- metadata +56 -142
- data/.gitignore +0 -18
- data/.simplecov +0 -7
- data/.travis.yml +0 -60
- data/Gemfile +0 -36
- data/History.md +0 -196
- data/Rakefile +0 -63
- data/appveyor.yml +0 -61
- data/lib/cuke_modeler/adapters/gherkin_2_adapter.rb +0 -273
- data/lib/cuke_modeler/adapters/gherkin_3_adapter.rb +0 -296
- data/lib/cuke_modeler/adapters/gherkin_4_adapter.rb +0 -308
- data/testing/cucumber/step_definitions/action_steps.rb +0 -13
- data/testing/cucumber/step_definitions/background_steps.rb +0 -1
- data/testing/cucumber/step_definitions/directory_steps.rb +0 -6
- data/testing/cucumber/step_definitions/doc_string_steps.rb +0 -1
- data/testing/cucumber/step_definitions/feature_file_steps.rb +0 -16
- data/testing/cucumber/step_definitions/feature_steps.rb +0 -7
- data/testing/cucumber/step_definitions/modeling_steps.rb +0 -44
- data/testing/cucumber/step_definitions/setup_steps.rb +0 -32
- data/testing/cucumber/step_definitions/step_steps.rb +0 -3
- data/testing/cucumber/step_definitions/table_steps.rb +0 -1
- data/testing/cucumber/step_definitions/tag_steps.rb +0 -3
- data/testing/cucumber/step_definitions/verification_steps.rb +0 -173
- data/testing/cucumber/support/env.rb +0 -30
- data/testing/dialect_helper.rb +0 -48
- data/testing/file_helper.rb +0 -47
- data/testing/gemfiles/gherkin2.gemfile +0 -32
- data/testing/gemfiles/gherkin3.gemfile +0 -26
- data/testing/gemfiles/gherkin4.gemfile +0 -27
- data/testing/gemfiles/gherkin5.gemfile +0 -27
- data/testing/gemfiles/gherkin6.gemfile +0 -10
- data/testing/rspec/spec/integration/background_integration_spec.rb +0 -442
- data/testing/rspec/spec/integration/cell_integration_spec.rb +0 -335
- data/testing/rspec/spec/integration/comment_integration_spec.rb +0 -177
- data/testing/rspec/spec/integration/directory_integration_spec.rb +0 -218
- data/testing/rspec/spec/integration/doc_string_integration_spec.rb +0 -402
- data/testing/rspec/spec/integration/example_integration_spec.rb +0 -741
- data/testing/rspec/spec/integration/feature_file_integration_spec.rb +0 -272
- data/testing/rspec/spec/integration/feature_integration_spec.rb +0 -650
- data/testing/rspec/spec/integration/gherkin_2_adapter_spec.rb +0 -166
- data/testing/rspec/spec/integration/gherkin_3_adapter_spec.rb +0 -166
- data/testing/rspec/spec/integration/gherkin_4_adapter_spec.rb +0 -165
- data/testing/rspec/spec/integration/gherkin_6_adapter_spec.rb +0 -166
- data/testing/rspec/spec/integration/model_integration_spec.rb +0 -15
- data/testing/rspec/spec/integration/nested_integration_spec.rb +0 -91
- data/testing/rspec/spec/integration/outline_integration_spec.rb +0 -624
- data/testing/rspec/spec/integration/parsing_integration_spec.rb +0 -122
- data/testing/rspec/spec/integration/row_integration_spec.rb +0 -291
- data/testing/rspec/spec/integration/scenario_integration_spec.rb +0 -479
- data/testing/rspec/spec/integration/shared/models_integration_specs.rb +0 -18
- data/testing/rspec/spec/integration/step_integration_spec.rb +0 -475
- data/testing/rspec/spec/integration/table_integration_spec.rb +0 -337
- data/testing/rspec/spec/integration/tag_integration_spec.rb +0 -259
- data/testing/rspec/spec/spec_helper.rb +0 -122
- data/testing/rspec/spec/unit/background_unit_spec.rb +0 -83
- data/testing/rspec/spec/unit/cell_unit_spec.rb +0 -68
- data/testing/rspec/spec/unit/comment_unit_spec.rb +0 -68
- data/testing/rspec/spec/unit/described_unit_spec.rb +0 -23
- data/testing/rspec/spec/unit/directory_unit_spec.rb +0 -127
- data/testing/rspec/spec/unit/doc_string_unit_spec.rb +0 -100
- data/testing/rspec/spec/unit/example_unit_spec.rb +0 -133
- data/testing/rspec/spec/unit/feature_file_unit_spec.rb +0 -125
- data/testing/rspec/spec/unit/feature_unit_spec.rb +0 -157
- data/testing/rspec/spec/unit/model_unit_spec.rb +0 -15
- data/testing/rspec/spec/unit/named_unit_spec.rb +0 -23
- data/testing/rspec/spec/unit/nested_unit_spec.rb +0 -43
- data/testing/rspec/spec/unit/outline_unit_spec.rb +0 -117
- data/testing/rspec/spec/unit/parsed_unit_spec.rb +0 -27
- data/testing/rspec/spec/unit/parsing_unit_spec.rb +0 -54
- data/testing/rspec/spec/unit/row_unit_spec.rb +0 -68
- data/testing/rspec/spec/unit/scenario_unit_spec.rb +0 -86
- data/testing/rspec/spec/unit/shared/bare_bones_models_unit_specs.rb +0 -14
- data/testing/rspec/spec/unit/shared/containing_models_unit_specs.rb +0 -127
- data/testing/rspec/spec/unit/shared/described_models_unit_specs.rb +0 -38
- data/testing/rspec/spec/unit/shared/keyworded_models_unit_specs.rb +0 -58
- data/testing/rspec/spec/unit/shared/models_unit_specs.rb +0 -15
- data/testing/rspec/spec/unit/shared/named_models_unit_specs.rb +0 -39
- data/testing/rspec/spec/unit/shared/nested_models_unit_specs.rb +0 -51
- data/testing/rspec/spec/unit/shared/parsed_models_unit_specs.rb +0 -39
- data/testing/rspec/spec/unit/shared/prepopulated_models_unit_specs.rb +0 -18
- data/testing/rspec/spec/unit/shared/sourced_models_unit_specs.rb +0 -39
- data/testing/rspec/spec/unit/shared/stepped_models_unit_specs.rb +0 -46
- data/testing/rspec/spec/unit/shared/stringifiable_models_unit_specs.rb +0 -18
- data/testing/rspec/spec/unit/shared/tagged_models_unit_specs.rb +0 -72
- data/testing/rspec/spec/unit/sourceable_unit_spec.rb +0 -27
- data/testing/rspec/spec/unit/step_unit_spec.rb +0 -109
- data/testing/rspec/spec/unit/stepped_unit_spec.rb +0 -23
- data/testing/rspec/spec/unit/table_unit_spec.rb +0 -77
- data/testing/rspec/spec/unit/tag_unit_spec.rb +0 -68
- data/testing/rspec/spec/unit/taggable_unit_spec.rb +0 -69
- data/testing/test_languages.json +0 -45
- data/todo.txt +0 -24
@@ -1,127 +0,0 @@
|
|
1
|
-
require "#{File.dirname(__FILE__)}/../../spec_helper"
|
2
|
-
|
3
|
-
shared_examples_for 'a containing model' do
|
4
|
-
|
5
|
-
# clazz must be defined by the calling file
|
6
|
-
|
7
|
-
let(:model) { clazz.new }
|
8
|
-
|
9
|
-
|
10
|
-
it 'has children' do
|
11
|
-
expect(model).to respond_to(:children)
|
12
|
-
end
|
13
|
-
|
14
|
-
it 'returns a collection of children' do
|
15
|
-
expect(model.children).to be_an(Array)
|
16
|
-
end
|
17
|
-
|
18
|
-
it 'does not return objects for children that it does not have' do
|
19
|
-
# Ensuring an empty, childless model
|
20
|
-
model = clazz.new
|
21
|
-
|
22
|
-
expect(model.children).to_not include(nil)
|
23
|
-
end
|
24
|
-
|
25
|
-
it 'can execute code on all models in its model tree' do
|
26
|
-
expect(model).to respond_to(:each_model)
|
27
|
-
end
|
28
|
-
|
29
|
-
it 'can execute code on all of its descendants' do
|
30
|
-
expect(model).to respond_to(:each_descendant)
|
31
|
-
end
|
32
|
-
|
33
|
-
|
34
|
-
context 'without children' do
|
35
|
-
|
36
|
-
let(:parent_model) do
|
37
|
-
m = clazz.new
|
38
|
-
|
39
|
-
# Not all models have a name, so making sure that this one does
|
40
|
-
def m.name
|
41
|
-
'top level model'
|
42
|
-
end
|
43
|
-
|
44
|
-
# Redefining what children are returned for the model rather than fiddling with all of the different kinds of child models that various model classes have
|
45
|
-
def m.children
|
46
|
-
[]
|
47
|
-
end
|
48
|
-
|
49
|
-
m
|
50
|
-
end
|
51
|
-
|
52
|
-
|
53
|
-
it 'executes the provided code on each descendant of the model' do
|
54
|
-
names = []
|
55
|
-
|
56
|
-
parent_model.each_descendant do |descendant_model|
|
57
|
-
names << descendant_model.name
|
58
|
-
end
|
59
|
-
|
60
|
-
expect(names).to be_empty
|
61
|
-
end
|
62
|
-
|
63
|
-
it 'executes the provided code on each model in its tree' do
|
64
|
-
names = []
|
65
|
-
|
66
|
-
parent_model.each_model do |model_node|
|
67
|
-
names << model_node.name
|
68
|
-
end
|
69
|
-
|
70
|
-
expect(names).to match_array(['top level model'])
|
71
|
-
end
|
72
|
-
|
73
|
-
end
|
74
|
-
|
75
|
-
|
76
|
-
context 'with children' do
|
77
|
-
|
78
|
-
let(:parent_model) do
|
79
|
-
m = clazz.new
|
80
|
-
|
81
|
-
# Not all models have a name, so making sure that this one does
|
82
|
-
def m.name
|
83
|
-
'top level model'
|
84
|
-
end
|
85
|
-
|
86
|
-
# Redefining what children are returned for the model rather than fiddling with all of the different kinds of child models that various model classes have
|
87
|
-
def m.children
|
88
|
-
containing_model_stub = Struct.new(:name, :children)
|
89
|
-
non_containing_model_stub = Struct.new(:name)
|
90
|
-
nested_child_object = containing_model_stub.new('grandchild object', [])
|
91
|
-
nested_child_object.extend(CukeModeler::Containing)
|
92
|
-
|
93
|
-
non_containing_child_object = non_containing_model_stub.new('child object 1')
|
94
|
-
|
95
|
-
child_object_with_children = containing_model_stub.new('child object 2', [nested_child_object])
|
96
|
-
child_object_with_children.extend(CukeModeler::Containing)
|
97
|
-
|
98
|
-
[non_containing_child_object, child_object_with_children]
|
99
|
-
end
|
100
|
-
|
101
|
-
m
|
102
|
-
end
|
103
|
-
|
104
|
-
|
105
|
-
it 'executes the provided code on each descendant of the model' do
|
106
|
-
names = []
|
107
|
-
|
108
|
-
parent_model.each_descendant do |descendant_model|
|
109
|
-
names << descendant_model.name
|
110
|
-
end
|
111
|
-
|
112
|
-
expect(names).to match_array(['child object 1', 'child object 2', 'grandchild object'])
|
113
|
-
end
|
114
|
-
|
115
|
-
it 'executes the provided code on each model in its tree' do
|
116
|
-
names = []
|
117
|
-
|
118
|
-
parent_model.each_model do |model_node|
|
119
|
-
names << model_node.name
|
120
|
-
end
|
121
|
-
|
122
|
-
expect(names).to match_array(['top level model', 'child object 1', 'child object 2', 'grandchild object'])
|
123
|
-
end
|
124
|
-
|
125
|
-
end
|
126
|
-
|
127
|
-
end
|
@@ -1,38 +0,0 @@
|
|
1
|
-
require "#{File.dirname(__FILE__)}/../../spec_helper"
|
2
|
-
|
3
|
-
shared_examples_for 'a described model' do
|
4
|
-
|
5
|
-
# clazz must be defined by the calling file
|
6
|
-
|
7
|
-
let(:model) { clazz.new }
|
8
|
-
|
9
|
-
|
10
|
-
it 'has a description' do
|
11
|
-
expect(model).to respond_to(:description)
|
12
|
-
end
|
13
|
-
|
14
|
-
it 'can change its description' do
|
15
|
-
expect(model).to respond_to(:description=)
|
16
|
-
|
17
|
-
model.description = :some_description
|
18
|
-
expect(model.description).to eq(:some_description)
|
19
|
-
model.description = :some_other_description
|
20
|
-
expect(model.description).to eq(:some_other_description)
|
21
|
-
end
|
22
|
-
|
23
|
-
|
24
|
-
describe 'abstract instantiation' do
|
25
|
-
|
26
|
-
context 'a new described object' do
|
27
|
-
|
28
|
-
let(:model) { clazz.new }
|
29
|
-
|
30
|
-
it 'starts with no description' do
|
31
|
-
expect(model.description).to be_nil
|
32
|
-
end
|
33
|
-
|
34
|
-
end
|
35
|
-
|
36
|
-
end
|
37
|
-
|
38
|
-
end
|
@@ -1,58 +0,0 @@
|
|
1
|
-
require "#{File.dirname(__FILE__)}/../../spec_helper"
|
2
|
-
|
3
|
-
|
4
|
-
shared_examples_for 'a keyworded model' do
|
5
|
-
|
6
|
-
# clazz must be defined by the calling file
|
7
|
-
|
8
|
-
let(:model) { clazz.new }
|
9
|
-
|
10
|
-
|
11
|
-
it 'has a keyword' do
|
12
|
-
expect(model).to respond_to(:keyword)
|
13
|
-
end
|
14
|
-
|
15
|
-
it 'can change its keyword' do
|
16
|
-
expect(model).to respond_to(:keyword=)
|
17
|
-
|
18
|
-
model.keyword = :some_keyword
|
19
|
-
expect(model.keyword).to eq(:some_keyword)
|
20
|
-
model.keyword = :some_other_keyword
|
21
|
-
expect(model.keyword).to eq(:some_other_keyword)
|
22
|
-
end
|
23
|
-
|
24
|
-
|
25
|
-
describe 'abstract instantiation' do
|
26
|
-
|
27
|
-
context 'a new object' do
|
28
|
-
|
29
|
-
let(:model) { clazz.new }
|
30
|
-
|
31
|
-
|
32
|
-
it 'starts with no keyword' do
|
33
|
-
expect(model.keyword).to be_nil
|
34
|
-
end
|
35
|
-
|
36
|
-
end
|
37
|
-
|
38
|
-
end
|
39
|
-
|
40
|
-
|
41
|
-
describe 'model output' do
|
42
|
-
|
43
|
-
context 'from abstract instantiation' do
|
44
|
-
|
45
|
-
let(:model) { clazz.new }
|
46
|
-
|
47
|
-
|
48
|
-
it 'can output a model that has only a keyword' do
|
49
|
-
model.keyword = 'foo'
|
50
|
-
|
51
|
-
expect { model.to_s }.to_not raise_error
|
52
|
-
end
|
53
|
-
|
54
|
-
end
|
55
|
-
|
56
|
-
end
|
57
|
-
|
58
|
-
end
|
@@ -1,15 +0,0 @@
|
|
1
|
-
require "#{File.dirname(__FILE__)}/../../spec_helper"
|
2
|
-
|
3
|
-
shared_examples_for 'a model' do
|
4
|
-
|
5
|
-
describe 'common behavior' do
|
6
|
-
|
7
|
-
it_should_behave_like 'a bare bones model'
|
8
|
-
it_should_behave_like 'a prepopulated model'
|
9
|
-
it_should_behave_like 'a nested model'
|
10
|
-
it_should_behave_like 'a containing model'
|
11
|
-
it_should_behave_like 'a stringifiable model'
|
12
|
-
|
13
|
-
end
|
14
|
-
|
15
|
-
end
|
@@ -1,39 +0,0 @@
|
|
1
|
-
require "#{File.dirname(__FILE__)}/../../spec_helper"
|
2
|
-
|
3
|
-
shared_examples_for 'a named model' do
|
4
|
-
|
5
|
-
# clazz must be defined by the calling file
|
6
|
-
|
7
|
-
let(:model) { clazz.new }
|
8
|
-
|
9
|
-
|
10
|
-
it 'has a name' do
|
11
|
-
expect(model).to respond_to(:name)
|
12
|
-
end
|
13
|
-
|
14
|
-
it 'can change its name' do
|
15
|
-
expect(model).to respond_to(:name=)
|
16
|
-
|
17
|
-
model.name = :some_name
|
18
|
-
expect(model.name).to eq(:some_name)
|
19
|
-
model.name = :some_other_name
|
20
|
-
expect(model.name).to eq(:some_other_name)
|
21
|
-
end
|
22
|
-
|
23
|
-
|
24
|
-
describe 'abstract instantiation' do
|
25
|
-
|
26
|
-
context 'a new named object' do
|
27
|
-
|
28
|
-
let(:model) { clazz.new }
|
29
|
-
|
30
|
-
|
31
|
-
it 'starts with no name' do
|
32
|
-
expect(model.name).to be_nil
|
33
|
-
end
|
34
|
-
|
35
|
-
end
|
36
|
-
|
37
|
-
end
|
38
|
-
|
39
|
-
end
|
@@ -1,51 +0,0 @@
|
|
1
|
-
require "#{File.dirname(__FILE__)}/../../spec_helper"
|
2
|
-
|
3
|
-
shared_examples_for 'a nested model' do
|
4
|
-
|
5
|
-
# clazz must be defined by the calling file
|
6
|
-
|
7
|
-
let(:nested_model) { clazz.new }
|
8
|
-
|
9
|
-
|
10
|
-
it 'has a parent model' do
|
11
|
-
expect(nested_model).to respond_to(:parent_model)
|
12
|
-
end
|
13
|
-
|
14
|
-
it 'can change its parent model' do
|
15
|
-
expect(nested_model).to respond_to(:parent_model=)
|
16
|
-
|
17
|
-
nested_model.parent_model = :some_parent_model
|
18
|
-
expect(nested_model.parent_model).to eq(:some_parent_model)
|
19
|
-
nested_model.parent_model = :some_other_parent_model
|
20
|
-
expect(nested_model.parent_model).to eq(:some_other_parent_model)
|
21
|
-
end
|
22
|
-
|
23
|
-
|
24
|
-
describe 'abstract instantiation' do
|
25
|
-
|
26
|
-
context 'a new nested object' do
|
27
|
-
|
28
|
-
let(:nested_model) { clazz.new }
|
29
|
-
|
30
|
-
|
31
|
-
it 'starts with no parent model' do
|
32
|
-
expect(nested_model.parent_model).to be_nil
|
33
|
-
end
|
34
|
-
|
35
|
-
end
|
36
|
-
|
37
|
-
end
|
38
|
-
|
39
|
-
it 'has access to its ancestors' do
|
40
|
-
expect(nested_model).to respond_to(:get_ancestor)
|
41
|
-
end
|
42
|
-
|
43
|
-
it 'gets an ancestor based on type' do
|
44
|
-
expect(clazz.instance_method(:get_ancestor).arity).to eq(1)
|
45
|
-
end
|
46
|
-
|
47
|
-
it 'raises and exception if an unknown ancestor type is requested' do
|
48
|
-
expect { nested_model.get_ancestor(:bad_ancestor_type) }.to raise_exception(ArgumentError)
|
49
|
-
end
|
50
|
-
|
51
|
-
end
|
@@ -1,39 +0,0 @@
|
|
1
|
-
require "#{File.dirname(__FILE__)}/../../spec_helper"
|
2
|
-
|
3
|
-
shared_examples_for 'a parsed model' do
|
4
|
-
|
5
|
-
# clazz must be defined by the calling file
|
6
|
-
|
7
|
-
let(:model) { clazz.new }
|
8
|
-
|
9
|
-
|
10
|
-
it 'can access its original parsing data' do
|
11
|
-
expect(model).to respond_to(:parsing_data)
|
12
|
-
end
|
13
|
-
|
14
|
-
it 'can change its parsing data' do
|
15
|
-
expect(model).to respond_to(:parsing_data=)
|
16
|
-
|
17
|
-
model.parsing_data = :some_parsing_data
|
18
|
-
expect(model.parsing_data).to eq(:some_parsing_data)
|
19
|
-
model.parsing_data = :some_other_parsing_data
|
20
|
-
expect(model.parsing_data).to eq(:some_other_parsing_data)
|
21
|
-
end
|
22
|
-
|
23
|
-
|
24
|
-
describe 'abstract instantiation' do
|
25
|
-
|
26
|
-
context 'a new parsed object' do
|
27
|
-
|
28
|
-
let(:model) { clazz.new }
|
29
|
-
|
30
|
-
|
31
|
-
it 'starts with no parsing data' do
|
32
|
-
expect(model.parsing_data).to be_nil
|
33
|
-
end
|
34
|
-
|
35
|
-
end
|
36
|
-
|
37
|
-
end
|
38
|
-
|
39
|
-
end
|
@@ -1,18 +0,0 @@
|
|
1
|
-
require "#{File.dirname(__FILE__)}/../../spec_helper"
|
2
|
-
|
3
|
-
shared_examples_for 'a prepopulated model' do
|
4
|
-
|
5
|
-
# clazz must be defined by the calling file
|
6
|
-
|
7
|
-
let(:model) { clazz.new }
|
8
|
-
|
9
|
-
|
10
|
-
it 'can take text from which to populate itself' do
|
11
|
-
expect(clazz.instance_method(:initialize).arity).to_not eq(0)
|
12
|
-
end
|
13
|
-
|
14
|
-
it 'will complain if given non-text input' do
|
15
|
-
expect { clazz.new(:not_a_string) }.to raise_error(ArgumentError, 'Can only create models from Strings but was given a Symbol.')
|
16
|
-
end
|
17
|
-
|
18
|
-
end
|
@@ -1,39 +0,0 @@
|
|
1
|
-
require "#{File.dirname(__FILE__)}/../../spec_helper"
|
2
|
-
|
3
|
-
shared_examples_for 'a sourced model' do
|
4
|
-
|
5
|
-
# clazz must be defined by the calling file
|
6
|
-
|
7
|
-
let(:model) { clazz.new }
|
8
|
-
|
9
|
-
|
10
|
-
it 'has a source line' do
|
11
|
-
expect(model).to respond_to(:source_line)
|
12
|
-
end
|
13
|
-
|
14
|
-
it 'can change its source line' do
|
15
|
-
expect(model).to respond_to(:source_line=)
|
16
|
-
|
17
|
-
model.source_line = :some_source_line
|
18
|
-
expect(model.source_line).to eq(:some_source_line)
|
19
|
-
model.source_line = :some_other_source_line
|
20
|
-
expect(model.source_line).to eq(:some_other_source_line)
|
21
|
-
end
|
22
|
-
|
23
|
-
|
24
|
-
describe 'abstract instantiation' do
|
25
|
-
|
26
|
-
context 'a new sourced object' do
|
27
|
-
|
28
|
-
let(:model) { clazz.new }
|
29
|
-
|
30
|
-
|
31
|
-
it 'starts with no source line' do
|
32
|
-
expect(model.source_line).to be_nil
|
33
|
-
end
|
34
|
-
|
35
|
-
end
|
36
|
-
|
37
|
-
end
|
38
|
-
|
39
|
-
end
|
@@ -1,46 +0,0 @@
|
|
1
|
-
require "#{File.dirname(__FILE__)}/../../spec_helper"
|
2
|
-
|
3
|
-
shared_examples_for 'a stepped model' do
|
4
|
-
|
5
|
-
# clazz must be defined by the calling file
|
6
|
-
|
7
|
-
let(:model) { clazz.new }
|
8
|
-
|
9
|
-
|
10
|
-
it 'has steps' do
|
11
|
-
expect(model).to respond_to(:steps)
|
12
|
-
end
|
13
|
-
|
14
|
-
it 'can change its steps' do
|
15
|
-
expect(model).to respond_to(:steps=)
|
16
|
-
|
17
|
-
model.steps = :some_steps
|
18
|
-
expect(model.steps).to eq(:some_steps)
|
19
|
-
model.steps = :some_other_steps
|
20
|
-
expect(model.steps).to eq(:some_other_steps)
|
21
|
-
end
|
22
|
-
|
23
|
-
|
24
|
-
describe 'abstract instantiation' do
|
25
|
-
|
26
|
-
context 'a new stepped object' do
|
27
|
-
|
28
|
-
let(:model) { clazz.new }
|
29
|
-
|
30
|
-
|
31
|
-
it 'starts with no steps' do
|
32
|
-
expect(model.steps).to eq([])
|
33
|
-
end
|
34
|
-
|
35
|
-
end
|
36
|
-
|
37
|
-
end
|
38
|
-
|
39
|
-
it 'contains steps' do
|
40
|
-
steps = [:step_1, :step_2, :step_3]
|
41
|
-
model.steps = steps
|
42
|
-
|
43
|
-
steps.each { |step| expect(model.children).to include(step) }
|
44
|
-
end
|
45
|
-
|
46
|
-
end
|