servactory 2.0.0.rc3 → 2.0.0.rc4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/servactory/{methods/method.rb → actions/action.rb} +2 -2
- data/lib/servactory/{methods/aliases_for_make → actions/aliases}/collection.rb +2 -2
- data/lib/servactory/{methods/method_collection.rb → actions/collection.rb} +3 -3
- data/lib/servactory/{methods → actions}/dsl.rb +8 -8
- data/lib/servactory/{methods/shortcuts_for_make → actions/shortcuts}/collection.rb +2 -2
- data/lib/servactory/actions/stages/collection.rb +20 -0
- data/lib/servactory/actions/stages/stage.rb +30 -0
- data/lib/servactory/{methods → actions}/tools/runner.rb +1 -1
- data/lib/servactory/{methods → actions}/workspace.rb +2 -2
- data/lib/servactory/base.rb +1 -1
- data/lib/servactory/configuration/dsl.rb +2 -2
- data/lib/servactory/configuration/factory.rb +5 -5
- data/lib/servactory/configuration/setup.rb +4 -4
- data/lib/servactory/context/workspace/inputs.rb +7 -5
- data/lib/servactory/dsl.rb +1 -1
- data/lib/servactory/inputs/input.rb +3 -3
- data/lib/servactory/internals/internal.rb +3 -3
- data/lib/servactory/maintenance/attributes/option.rb +13 -7
- data/lib/servactory/maintenance/validations/object_schema.rb +1 -1
- data/lib/servactory/maintenance/validations/types.rb +26 -9
- data/lib/servactory/outputs/output.rb +3 -3
- data/lib/servactory/version.rb +1 -1
- metadata +19 -19
- data/lib/servactory/methods/stage.rb +0 -28
- data/lib/servactory/methods/stage_collection.rb +0 -18
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 83987eae2d3539d8eb196d0dd08d13ffee8449050d297794577933e8e5735e98
|
4
|
+
data.tar.gz: e35002ff20d061cc257c9e8ff99a8fd258f784ac19abce0d7c8f5c7a2c46f683
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 43268e0c7630e1eacd10efaf852eb0d26cbb5e30b4a4e5395202e67b4e9246dd2b92775da9318ced39cbd407aa714e4b89f151b6f2bc6164dab7bda722d84085
|
7
|
+
data.tar.gz: 999194eaeb288a7919d1177a46acac0ad35d07c039b7feb088140141ae9c34eb069cce39c5aaa22033bae0f9df7dc7981a8eb9c78bededfe0df540d97e7bb649
|
@@ -1,8 +1,8 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module Servactory
|
4
|
-
module
|
5
|
-
class
|
4
|
+
module Actions
|
5
|
+
class Collection
|
6
6
|
extend Forwardable
|
7
7
|
def_delegators :@collection, :<<, :each, :sort_by
|
8
8
|
|
@@ -11,7 +11,7 @@ module Servactory
|
|
11
11
|
end
|
12
12
|
|
13
13
|
def sorted_by_position
|
14
|
-
|
14
|
+
Collection.new(sort_by(&:position))
|
15
15
|
end
|
16
16
|
end
|
17
17
|
end
|
@@ -1,7 +1,7 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module Servactory
|
4
|
-
module
|
4
|
+
module Actions
|
5
5
|
module DSL
|
6
6
|
def self.included(base)
|
7
7
|
base.extend(ClassMethods)
|
@@ -18,7 +18,7 @@ module Servactory
|
|
18
18
|
private
|
19
19
|
|
20
20
|
def stage(&block)
|
21
|
-
@current_stage = Stage.new(position: next_position)
|
21
|
+
@current_stage = Stages::Stage.new(position: next_position)
|
22
22
|
|
23
23
|
instance_eval(&block)
|
24
24
|
|
@@ -56,9 +56,9 @@ module Servactory
|
|
56
56
|
def make(name, position: nil, **options)
|
57
57
|
position = position.presence || next_position
|
58
58
|
|
59
|
-
current_stage = @current_stage.presence || Stage.new(position: position)
|
59
|
+
current_stage = @current_stage.presence || Stages::Stage.new(position: position)
|
60
60
|
|
61
|
-
current_stage.methods <<
|
61
|
+
current_stage.methods << Action.new(
|
62
62
|
name,
|
63
63
|
position: position,
|
64
64
|
**options
|
@@ -68,9 +68,9 @@ module Servactory
|
|
68
68
|
end
|
69
69
|
|
70
70
|
def method_missing(name, *args, &block)
|
71
|
-
return method_missing_for_aliases_for_make(name, *args, &block) if config.
|
71
|
+
return method_missing_for_aliases_for_make(name, *args, &block) if config.action_aliases.include?(name)
|
72
72
|
|
73
|
-
return method_missing_for_shortcuts_for_make(name, *args, &block) if config.
|
73
|
+
return method_missing_for_shortcuts_for_make(name, *args, &block) if config.action_shortcuts.include?(name)
|
74
74
|
|
75
75
|
super
|
76
76
|
end
|
@@ -93,7 +93,7 @@ module Servactory
|
|
93
93
|
end
|
94
94
|
|
95
95
|
def respond_to_missing?(name, *)
|
96
|
-
config.
|
96
|
+
config.action_aliases.include?(name) || config.action_shortcuts.include?(name) || super
|
97
97
|
end
|
98
98
|
|
99
99
|
def next_position
|
@@ -101,7 +101,7 @@ module Servactory
|
|
101
101
|
end
|
102
102
|
|
103
103
|
def collection_of_stages
|
104
|
-
@collection_of_stages ||=
|
104
|
+
@collection_of_stages ||= Stages::Collection.new
|
105
105
|
end
|
106
106
|
end
|
107
107
|
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Servactory
|
4
|
+
module Actions
|
5
|
+
module Stages
|
6
|
+
class Collection
|
7
|
+
extend Forwardable
|
8
|
+
def_delegators :@collection, :<<, :each, :merge, :sort_by, :size, :empty?
|
9
|
+
|
10
|
+
def initialize(collection = Set.new)
|
11
|
+
@collection = collection
|
12
|
+
end
|
13
|
+
|
14
|
+
def sorted_by_position
|
15
|
+
Collection.new(sort_by(&:position))
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Servactory
|
4
|
+
module Actions
|
5
|
+
module Stages
|
6
|
+
class Stage
|
7
|
+
attr_accessor :position,
|
8
|
+
:wrapper,
|
9
|
+
:rollback,
|
10
|
+
:condition,
|
11
|
+
:is_condition_opposite
|
12
|
+
|
13
|
+
def initialize(position:, wrapper: nil, rollback: nil, condition: nil)
|
14
|
+
@position = position
|
15
|
+
@wrapper = wrapper
|
16
|
+
@rollback = rollback
|
17
|
+
@condition = condition
|
18
|
+
end
|
19
|
+
|
20
|
+
def next_method_position
|
21
|
+
methods.size + 1
|
22
|
+
end
|
23
|
+
|
24
|
+
def methods
|
25
|
+
@methods ||= Collection.new
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -1,14 +1,14 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module Servactory
|
4
|
-
module
|
4
|
+
module Actions
|
5
5
|
module Workspace
|
6
6
|
private
|
7
7
|
|
8
8
|
def call!(collection_of_stages:, **)
|
9
9
|
super
|
10
10
|
|
11
|
-
Servactory::
|
11
|
+
Servactory::Actions::Tools::Runner.run!(self, collection_of_stages)
|
12
12
|
end
|
13
13
|
end
|
14
14
|
end
|
data/lib/servactory/base.rb
CHANGED
@@ -21,8 +21,8 @@ module Servactory
|
|
21
21
|
|
22
22
|
child.config.input_option_helpers = config.input_option_helpers
|
23
23
|
|
24
|
-
child.config.
|
25
|
-
child.config.
|
24
|
+
child.config.action_aliases = config.action_aliases
|
25
|
+
child.config.action_shortcuts = config.action_shortcuts
|
26
26
|
end
|
27
27
|
|
28
28
|
def config
|
@@ -28,19 +28,19 @@ module Servactory
|
|
28
28
|
end
|
29
29
|
|
30
30
|
def hash_mode_class_names(hash_mode_class_names)
|
31
|
-
@config.
|
31
|
+
@config.hash_mode_class_names.merge(hash_mode_class_names)
|
32
32
|
end
|
33
33
|
|
34
34
|
def input_option_helpers(input_option_helpers)
|
35
35
|
@config.input_option_helpers.merge(input_option_helpers)
|
36
36
|
end
|
37
37
|
|
38
|
-
def
|
39
|
-
@config.
|
38
|
+
def action_aliases(action_aliases)
|
39
|
+
@config.action_aliases.merge(action_aliases)
|
40
40
|
end
|
41
41
|
|
42
|
-
def
|
43
|
-
@config.
|
42
|
+
def action_shortcuts(action_shortcuts)
|
43
|
+
@config.action_shortcuts.merge(action_shortcuts)
|
44
44
|
end
|
45
45
|
end
|
46
46
|
end
|
@@ -10,8 +10,8 @@ module Servactory
|
|
10
10
|
:collection_mode_class_names,
|
11
11
|
:hash_mode_class_names,
|
12
12
|
:input_option_helpers,
|
13
|
-
:
|
14
|
-
:
|
13
|
+
:action_aliases,
|
14
|
+
:action_shortcuts
|
15
15
|
|
16
16
|
def initialize # rubocop:disable Metrics/MethodLength
|
17
17
|
@input_error_class = Servactory::Errors::InputError
|
@@ -29,8 +29,8 @@ module Servactory
|
|
29
29
|
@input_option_helpers =
|
30
30
|
Servactory::Maintenance::Attributes::OptionHelpersCollection.new(default_input_option_helpers)
|
31
31
|
|
32
|
-
@
|
33
|
-
@
|
32
|
+
@action_aliases = Servactory::Actions::Aliases::Collection.new
|
33
|
+
@action_shortcuts = Servactory::Actions::Shortcuts::Collection.new
|
34
34
|
end
|
35
35
|
|
36
36
|
private
|
@@ -48,7 +48,9 @@ module Servactory
|
|
48
48
|
|
49
49
|
input.value = input.default if input.optional? && input.value.blank?
|
50
50
|
|
51
|
-
|
51
|
+
if input.hash_mode?
|
52
|
+
input.value = prepare_hash_values_inside(object: input.value, schema: input.schema.fetch(:is))
|
53
|
+
end
|
52
54
|
|
53
55
|
input_prepare = input.prepare.fetch(:in, nil)
|
54
56
|
input.value = input_prepare.call(value: input.value) if input_prepare.present?
|
@@ -60,7 +62,7 @@ module Servactory
|
|
60
62
|
end
|
61
63
|
end
|
62
64
|
|
63
|
-
def
|
65
|
+
def prepare_hash_values_inside(object:, schema:) # rubocop:disable Metrics/MethodLength
|
64
66
|
return object unless object.respond_to?(:fetch)
|
65
67
|
|
66
68
|
schema.to_h do |schema_key, schema_value|
|
@@ -68,12 +70,12 @@ module Servactory
|
|
68
70
|
|
69
71
|
result =
|
70
72
|
if attribute_type == Hash
|
71
|
-
|
73
|
+
prepare_hash_values_inside(
|
72
74
|
object: object.fetch(schema_key, {}),
|
73
75
|
schema: schema_value.except(*RESERVED_ATTRIBUTES)
|
74
76
|
)
|
75
77
|
else
|
76
|
-
|
78
|
+
fetch_hash_values_from(
|
77
79
|
value: object.fetch(schema_key, {}),
|
78
80
|
schema_value: schema_value,
|
79
81
|
attribute_required: schema_value.fetch(:required, true)
|
@@ -84,7 +86,7 @@ module Servactory
|
|
84
86
|
end
|
85
87
|
end
|
86
88
|
|
87
|
-
def
|
89
|
+
def fetch_hash_values_from(value:, schema_value:, attribute_required:)
|
88
90
|
return value if attribute_required
|
89
91
|
return value if value.present?
|
90
92
|
|
data/lib/servactory/dsl.rb
CHANGED
@@ -68,7 +68,7 @@ module Servactory
|
|
68
68
|
add_types_option_with(type)
|
69
69
|
add_default_option_with(options)
|
70
70
|
add_collection_option_with(type, options)
|
71
|
-
|
71
|
+
add_hash_option_with(type, options)
|
72
72
|
|
73
73
|
# Check Class: Servactory::Inputs::Validations::Inclusion
|
74
74
|
add_inclusion_option_with(options)
|
@@ -161,7 +161,7 @@ module Servactory
|
|
161
161
|
)
|
162
162
|
end
|
163
163
|
|
164
|
-
def
|
164
|
+
def add_hash_option_with(type, options) # rubocop:disable Metrics/MethodLength
|
165
165
|
collection_of_options << Servactory::Maintenance::Attributes::Option.new(
|
166
166
|
name: :schema,
|
167
167
|
attribute: self,
|
@@ -178,8 +178,8 @@ module Servactory
|
|
178
178
|
)
|
179
179
|
],
|
180
180
|
need_for_checks: false,
|
181
|
+
body_key: :is,
|
181
182
|
body_fallback: {},
|
182
|
-
with_advanced_mode: false,
|
183
183
|
**options
|
184
184
|
)
|
185
185
|
end
|
@@ -37,7 +37,7 @@ module Servactory
|
|
37
37
|
# Check Class: Servactory::Internals::Validations::Type
|
38
38
|
add_types_option_with(type)
|
39
39
|
add_collection_option_with(type, options)
|
40
|
-
|
40
|
+
add_hash_option_with(type, options)
|
41
41
|
end
|
42
42
|
|
43
43
|
def add_types_option_with(type)
|
@@ -71,7 +71,7 @@ module Servactory
|
|
71
71
|
)
|
72
72
|
end
|
73
73
|
|
74
|
-
def
|
74
|
+
def add_hash_option_with(type, options) # rubocop:disable Metrics/MethodLength
|
75
75
|
collection_of_options << Servactory::Maintenance::Attributes::Option.new(
|
76
76
|
name: :schema,
|
77
77
|
attribute: self,
|
@@ -83,8 +83,8 @@ module Servactory
|
|
83
83
|
)
|
84
84
|
],
|
85
85
|
need_for_checks: false,
|
86
|
+
body_key: :is,
|
86
87
|
body_fallback: {},
|
87
|
-
with_advanced_mode: false,
|
88
88
|
**options
|
89
89
|
)
|
90
90
|
end
|
@@ -75,6 +75,7 @@ module Servactory
|
|
75
75
|
)
|
76
76
|
end
|
77
77
|
|
78
|
+
# rubocop:disable Metrics/MethodLength
|
78
79
|
def prepare_advanced_for(
|
79
80
|
body:,
|
80
81
|
body_key:,
|
@@ -82,17 +83,22 @@ module Servactory
|
|
82
83
|
body_fallback:
|
83
84
|
)
|
84
85
|
if body.is_a?(Hash)
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
86
|
+
if @name == :schema && body.fetch(body_key, nil).nil?
|
87
|
+
DEFAULT_BODY.call(key: body_key, body: body)
|
88
|
+
else
|
89
|
+
message = body.fetch(:message, nil)
|
90
|
+
|
91
|
+
DEFAULT_BODY.call(
|
92
|
+
key: body_key,
|
93
|
+
body: body.fetch(body_key, message.present? ? body_value : body_fallback),
|
94
|
+
message: message
|
95
|
+
)
|
96
|
+
end
|
92
97
|
else
|
93
98
|
DEFAULT_BODY.call(key: body_key, body: body)
|
94
99
|
end
|
95
100
|
end
|
101
|
+
# rubocop:enable Metrics/MethodLength
|
96
102
|
|
97
103
|
def prepare_methods_for(attribute)
|
98
104
|
attribute.instance_eval(define_methods_template) if define_methods_template.present?
|
@@ -17,7 +17,11 @@ module Servactory
|
|
17
17
|
collection_message = attribute.consists_of.fetch(:message)
|
18
18
|
|
19
19
|
if collection_message.is_a?(Proc)
|
20
|
-
collection_message.call(
|
20
|
+
collection_message.call(
|
21
|
+
"#{attribute_system_name}_name": attribute.name,
|
22
|
+
expected_type: expected_type,
|
23
|
+
given_type: given_type
|
24
|
+
)
|
21
25
|
elsif collection_message.is_a?(String) && collection_message.present?
|
22
26
|
collection_message
|
23
27
|
elsif value.is_a?(attribute.types.fetch(0, Array))
|
@@ -38,14 +42,27 @@ module Servactory
|
|
38
42
|
)
|
39
43
|
end
|
40
44
|
elsif attribute.hash_mode? && key_name.present?
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
45
|
+
hash_message = attribute.schema.fetch(:message)
|
46
|
+
|
47
|
+
if hash_message.is_a?(Proc)
|
48
|
+
hash_message.call(
|
49
|
+
"#{attribute_system_name}_name": attribute.name,
|
50
|
+
key_name: key_name,
|
51
|
+
expected_type: expected_type,
|
52
|
+
given_type: given_type
|
53
|
+
)
|
54
|
+
elsif hash_message.is_a?(String) && hash_message.present?
|
55
|
+
hash_message
|
56
|
+
else
|
57
|
+
I18n.t(
|
58
|
+
"servactory.#{attribute_system_name.to_s.pluralize}.checks.type.default_error.for_hash.wrong_element_type", # rubocop:disable Layout/LineLength
|
59
|
+
service_class_name: service_class_name,
|
60
|
+
"#{attribute_system_name}_name": attribute.name,
|
61
|
+
key_name: key_name,
|
62
|
+
expected_type: expected_type,
|
63
|
+
given_type: given_type
|
64
|
+
)
|
65
|
+
end
|
49
66
|
else
|
50
67
|
I18n.t(
|
51
68
|
"servactory.#{attribute_system_name.to_s.pluralize}.checks.type.default_error.default",
|
@@ -37,7 +37,7 @@ module Servactory
|
|
37
37
|
# Check Class: Servactory::Outputs::Validations::Type
|
38
38
|
add_types_option_with(type)
|
39
39
|
add_collection_option_with(type, options)
|
40
|
-
|
40
|
+
add_hash_option_with(type, options)
|
41
41
|
end
|
42
42
|
|
43
43
|
def add_types_option_with(type)
|
@@ -71,7 +71,7 @@ module Servactory
|
|
71
71
|
)
|
72
72
|
end
|
73
73
|
|
74
|
-
def
|
74
|
+
def add_hash_option_with(type, options) # rubocop:disable Metrics/MethodLength
|
75
75
|
collection_of_options << Servactory::Maintenance::Attributes::Option.new(
|
76
76
|
name: :schema,
|
77
77
|
attribute: self,
|
@@ -83,8 +83,8 @@ module Servactory
|
|
83
83
|
)
|
84
84
|
],
|
85
85
|
need_for_checks: false,
|
86
|
+
body_key: :is,
|
86
87
|
body_fallback: {},
|
87
|
-
with_advanced_mode: false,
|
88
88
|
**options
|
89
89
|
)
|
90
90
|
end
|
data/lib/servactory/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: servactory
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.0.0.
|
4
|
+
version: 2.0.0.rc4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Anton Sokolov
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-10-
|
11
|
+
date: 2023-10-28 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activesupport
|
@@ -30,14 +30,14 @@ dependencies:
|
|
30
30
|
requirements:
|
31
31
|
- - "~>"
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version: '1.
|
33
|
+
version: '1.14'
|
34
34
|
type: :runtime
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
38
|
- - "~>"
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version: '1.
|
40
|
+
version: '1.14'
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: zeitwerk
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
@@ -114,28 +114,28 @@ dependencies:
|
|
114
114
|
requirements:
|
115
115
|
- - "~>"
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version: '1.
|
117
|
+
version: '1.57'
|
118
118
|
type: :development
|
119
119
|
prerelease: false
|
120
120
|
version_requirements: !ruby/object:Gem::Requirement
|
121
121
|
requirements:
|
122
122
|
- - "~>"
|
123
123
|
- !ruby/object:Gem::Version
|
124
|
-
version: '1.
|
124
|
+
version: '1.57'
|
125
125
|
- !ruby/object:Gem::Dependency
|
126
126
|
name: rubocop-performance
|
127
127
|
requirement: !ruby/object:Gem::Requirement
|
128
128
|
requirements:
|
129
129
|
- - "~>"
|
130
130
|
- !ruby/object:Gem::Version
|
131
|
-
version: '1.
|
131
|
+
version: '1.19'
|
132
132
|
type: :development
|
133
133
|
prerelease: false
|
134
134
|
version_requirements: !ruby/object:Gem::Requirement
|
135
135
|
requirements:
|
136
136
|
- - "~>"
|
137
137
|
- !ruby/object:Gem::Version
|
138
|
-
version: '1.
|
138
|
+
version: '1.19'
|
139
139
|
- !ruby/object:Gem::Dependency
|
140
140
|
name: rubocop-rake
|
141
141
|
requirement: !ruby/object:Gem::Requirement
|
@@ -156,14 +156,14 @@ dependencies:
|
|
156
156
|
requirements:
|
157
157
|
- - "~>"
|
158
158
|
- !ruby/object:Gem::Version
|
159
|
-
version: '2.
|
159
|
+
version: '2.24'
|
160
160
|
type: :development
|
161
161
|
prerelease: false
|
162
162
|
version_requirements: !ruby/object:Gem::Requirement
|
163
163
|
requirements:
|
164
164
|
- - "~>"
|
165
165
|
- !ruby/object:Gem::Version
|
166
|
-
version: '2.
|
166
|
+
version: '2.24'
|
167
167
|
- !ruby/object:Gem::Dependency
|
168
168
|
name: steep
|
169
169
|
requirement: !ruby/object:Gem::Requirement
|
@@ -204,6 +204,15 @@ files:
|
|
204
204
|
- config/locales/en.yml
|
205
205
|
- config/locales/ru.yml
|
206
206
|
- lib/servactory.rb
|
207
|
+
- lib/servactory/actions/action.rb
|
208
|
+
- lib/servactory/actions/aliases/collection.rb
|
209
|
+
- lib/servactory/actions/collection.rb
|
210
|
+
- lib/servactory/actions/dsl.rb
|
211
|
+
- lib/servactory/actions/shortcuts/collection.rb
|
212
|
+
- lib/servactory/actions/stages/collection.rb
|
213
|
+
- lib/servactory/actions/stages/stage.rb
|
214
|
+
- lib/servactory/actions/tools/runner.rb
|
215
|
+
- lib/servactory/actions/workspace.rb
|
207
216
|
- lib/servactory/base.rb
|
208
217
|
- lib/servactory/configuration/dsl.rb
|
209
218
|
- lib/servactory/configuration/factory.rb
|
@@ -254,15 +263,6 @@ files:
|
|
254
263
|
- lib/servactory/maintenance/validations/collection.rb
|
255
264
|
- lib/servactory/maintenance/validations/object_schema.rb
|
256
265
|
- lib/servactory/maintenance/validations/types.rb
|
257
|
-
- lib/servactory/methods/aliases_for_make/collection.rb
|
258
|
-
- lib/servactory/methods/dsl.rb
|
259
|
-
- lib/servactory/methods/method.rb
|
260
|
-
- lib/servactory/methods/method_collection.rb
|
261
|
-
- lib/servactory/methods/shortcuts_for_make/collection.rb
|
262
|
-
- lib/servactory/methods/stage.rb
|
263
|
-
- lib/servactory/methods/stage_collection.rb
|
264
|
-
- lib/servactory/methods/tools/runner.rb
|
265
|
-
- lib/servactory/methods/workspace.rb
|
266
266
|
- lib/servactory/outputs/collection.rb
|
267
267
|
- lib/servactory/outputs/dsl.rb
|
268
268
|
- lib/servactory/outputs/output.rb
|
@@ -1,28 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
module Servactory
|
4
|
-
module Methods
|
5
|
-
class Stage
|
6
|
-
attr_accessor :position,
|
7
|
-
:wrapper,
|
8
|
-
:rollback,
|
9
|
-
:condition,
|
10
|
-
:is_condition_opposite
|
11
|
-
|
12
|
-
def initialize(position:, wrapper: nil, rollback: nil, condition: nil)
|
13
|
-
@position = position
|
14
|
-
@wrapper = wrapper
|
15
|
-
@rollback = rollback
|
16
|
-
@condition = condition
|
17
|
-
end
|
18
|
-
|
19
|
-
def next_method_position
|
20
|
-
methods.size + 1
|
21
|
-
end
|
22
|
-
|
23
|
-
def methods
|
24
|
-
@methods ||= MethodCollection.new
|
25
|
-
end
|
26
|
-
end
|
27
|
-
end
|
28
|
-
end
|
@@ -1,18 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
module Servactory
|
4
|
-
module Methods
|
5
|
-
class StageCollection
|
6
|
-
extend Forwardable
|
7
|
-
def_delegators :@collection, :<<, :each, :merge, :sort_by, :size, :empty?
|
8
|
-
|
9
|
-
def initialize(collection = Set.new)
|
10
|
-
@collection = collection
|
11
|
-
end
|
12
|
-
|
13
|
-
def sorted_by_position
|
14
|
-
StageCollection.new(sort_by(&:position))
|
15
|
-
end
|
16
|
-
end
|
17
|
-
end
|
18
|
-
end
|