stack_master 0.0.2 → 0.0.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +6 -6
- data/lib/stack_master/commands/outputs.rb +1 -0
- data/lib/stack_master/commands/validate.rb +1 -1
- data/lib/stack_master/config.rb +16 -2
- data/lib/stack_master/parameter_resolver.rb +5 -1
- data/lib/stack_master/version.rb +1 -1
- data/spec/stack_master/commands/validate_spec.rb +2 -1
- data/spec/stack_master/config_spec.rb +16 -0
- data/stack_master.gemspec +1 -1
- metadata +6 -6
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 5a3ed3d56cf859f61ca5a72f89d42cfefea0cd0d
|
4
|
+
data.tar.gz: af141896b5817e2ff3a30b3811c3b3fedb1cade9
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 13e318d63d1a51aa9c379a571694cf43bc640aabc9e55d4cc0fb6570d0e44031609cd463fb655805620c39e60877d816d79a4ad6f1fbb909df652bdb27a3ebb1
|
7
|
+
data.tar.gz: 5fa3fad8464793c9d2d91738095e3e22e09d4029fcff28888f46f9fa30b92ff576761ad0db3df7ce74bc86d2c6237f9ff6813a2b9d81874008bc8659e99d691a
|
data/README.md
CHANGED
@@ -175,12 +175,12 @@ web_ami:
|
|
175
175
|
stack_master help # Display up to date docs on the commands available
|
176
176
|
stack_master init # Initialises a directory structure and stack_master.yml file
|
177
177
|
stack_master list # Lists stack definitions
|
178
|
-
stack_master apply
|
179
|
-
stack_master diff
|
180
|
-
stack_master delete
|
181
|
-
stack_master events
|
182
|
-
stack_master outputs
|
183
|
-
stack_master resources
|
178
|
+
stack_master apply <region-or-alias> <stack-name> # Create or update a stack
|
179
|
+
stack_master diff <region-or-alias> <stack-name> # Display a stack tempalte and parameter diff
|
180
|
+
stack_master delete <region-or-alias> <stack-name> # Delete a stack
|
181
|
+
stack_master events <region-or-alias> <stack-name> # Display events for a stack
|
182
|
+
stack_master outputs <region-or-alias> <stack-name> # Display outputs for a stack
|
183
|
+
stack_master resources <region-or-alias> <stack-name> # Display outputs for a stack
|
184
184
|
stack_master status # Displays the status of each stack
|
185
185
|
```
|
186
186
|
|
data/lib/stack_master/config.rb
CHANGED
@@ -4,8 +4,9 @@ require 'active_support/core_ext/object/deep_dup'
|
|
4
4
|
module StackMaster
|
5
5
|
class Config
|
6
6
|
def self.load!(config_file = 'stack_master.yml')
|
7
|
-
|
8
|
-
|
7
|
+
resolved_config_file = search_up_and_chdir(config_file)
|
8
|
+
config = YAML.load(File.read(resolved_config_file))
|
9
|
+
base_dir = File.dirname(File.expand_path(resolved_config_file))
|
9
10
|
new(config, base_dir)
|
10
11
|
end
|
11
12
|
|
@@ -15,6 +16,19 @@ module StackMaster
|
|
15
16
|
:region_defaults,
|
16
17
|
:region_aliases
|
17
18
|
|
19
|
+
def self.search_up_and_chdir(config_file)
|
20
|
+
return config_file unless File.dirname(config_file) == "."
|
21
|
+
|
22
|
+
dir = Dir.pwd
|
23
|
+
parent_dir = File.expand_path("..", Dir.pwd)
|
24
|
+
while parent_dir != dir && !File.exists?(File.join(dir, config_file))
|
25
|
+
dir = parent_dir
|
26
|
+
parent_dir = File.expand_path("..", dir)
|
27
|
+
end
|
28
|
+
|
29
|
+
File.join(dir, config_file)
|
30
|
+
end
|
31
|
+
|
18
32
|
def initialize(config, base_dir)
|
19
33
|
@config = config
|
20
34
|
@base_dir = base_dir
|
@@ -16,7 +16,11 @@ module StackMaster
|
|
16
16
|
|
17
17
|
def resolve
|
18
18
|
@parameters.reduce({}) do |parameters, (key, value)|
|
19
|
-
|
19
|
+
begin
|
20
|
+
parameters[key] = resolve_parameter_value(value)
|
21
|
+
rescue InvalidParameter
|
22
|
+
raise InvalidParameter, "Unable to resolve parameter #{key.inspect} value causing error: #{$!.message}"
|
23
|
+
end
|
20
24
|
parameters
|
21
25
|
end
|
22
26
|
end
|
data/lib/stack_master/version.rb
CHANGED
@@ -1,9 +1,10 @@
|
|
1
1
|
RSpec.describe StackMaster::Commands::Validate do
|
2
2
|
|
3
|
-
subject(:validate) { described_class.new(config, stack_definition) }
|
3
|
+
subject(:validate) { described_class.new(config, stack_definition, options) }
|
4
4
|
let(:config) { instance_double(StackMaster::Config) }
|
5
5
|
let(:region) { "us-east-1" }
|
6
6
|
let(:stack_name) { "mystack" }
|
7
|
+
let(:options) { }
|
7
8
|
let(:stack_definition) do
|
8
9
|
StackMaster::StackDefinition.new(
|
9
10
|
region: region,
|
@@ -15,6 +15,22 @@ RSpec.describe StackMaster::Config do
|
|
15
15
|
)
|
16
16
|
}
|
17
17
|
|
18
|
+
context ".load!" do
|
19
|
+
it "fails to load the config if no stack_master.yml in parent directories" do
|
20
|
+
expect { StackMaster::Config.load!('stack_master.yml') }.to raise_error Errno::ENOENT
|
21
|
+
end
|
22
|
+
|
23
|
+
it "searches up the tree for stack master yaml" do
|
24
|
+
begin
|
25
|
+
orig_dir = Dir.pwd
|
26
|
+
Dir.chdir './spec/fixtures/templates'
|
27
|
+
expect(StackMaster::Config.load!('stack_master.yml')).to_not be_nil
|
28
|
+
ensure
|
29
|
+
Dir.chdir orig_dir
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
18
34
|
it 'returns an object that can find stack definitions' do
|
19
35
|
stack = loaded_config.find_stack('us-east-1', 'myapp-vpc')
|
20
36
|
expect(stack).to eq(myapp_vpc_definition)
|
data/stack_master.gemspec
CHANGED
@@ -28,7 +28,7 @@ Gem::Specification.new do |spec|
|
|
28
28
|
spec.add_dependency "ruby-progressbar"
|
29
29
|
spec.add_dependency "commander"
|
30
30
|
spec.add_dependency "virtus"
|
31
|
-
spec.add_dependency "aws-sdk"
|
31
|
+
spec.add_dependency "aws-sdk", "~> 2.1"
|
32
32
|
spec.add_dependency "diffy"
|
33
33
|
spec.add_dependency "colorize"
|
34
34
|
spec.add_dependency "activesupport"
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: stack_master
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.3
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Steve Hodgkiss
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2015-
|
12
|
+
date: 2015-12-09 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: bundler
|
@@ -155,16 +155,16 @@ dependencies:
|
|
155
155
|
name: aws-sdk
|
156
156
|
requirement: !ruby/object:Gem::Requirement
|
157
157
|
requirements:
|
158
|
-
- - "
|
158
|
+
- - "~>"
|
159
159
|
- !ruby/object:Gem::Version
|
160
|
-
version: '
|
160
|
+
version: '2.1'
|
161
161
|
type: :runtime
|
162
162
|
prerelease: false
|
163
163
|
version_requirements: !ruby/object:Gem::Requirement
|
164
164
|
requirements:
|
165
|
-
- - "
|
165
|
+
- - "~>"
|
166
166
|
- !ruby/object:Gem::Version
|
167
|
-
version: '
|
167
|
+
version: '2.1'
|
168
168
|
- !ruby/object:Gem::Dependency
|
169
169
|
name: diffy
|
170
170
|
requirement: !ruby/object:Gem::Requirement
|