test-kitchen 1.7.0 → 1.7.1.dev
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/.cane +8 -8
- data/.gitattributes +3 -0
- data/.github/ISSUE_TEMPLATE.md +55 -55
- data/.gitignore +28 -28
- data/.kitchen.ci.yml +23 -23
- data/.kitchen.proxy.yml +27 -27
- data/.rubocop.yml +3 -3
- data/.travis.yml +70 -70
- data/.yardopts +3 -3
- data/Berksfile +3 -3
- data/CHANGELOG.md +1090 -1083
- data/CONTRIBUTING.md +14 -14
- data/Gemfile +19 -19
- data/Gemfile.proxy_tests +4 -4
- data/Guardfile +42 -42
- data/LICENSE +15 -15
- data/MAINTAINERS.md +23 -23
- data/README.md +135 -135
- data/Rakefile +61 -61
- data/appveyor.yml +44 -44
- data/features/kitchen_action_commands.feature +164 -164
- data/features/kitchen_command.feature +16 -16
- data/features/kitchen_console_command.feature +34 -34
- data/features/kitchen_defaults.feature +38 -38
- data/features/kitchen_diagnose_command.feature +96 -96
- data/features/kitchen_driver_create_command.feature +64 -64
- data/features/kitchen_driver_discover_command.feature +25 -25
- data/features/kitchen_help_command.feature +16 -16
- data/features/kitchen_init_command.feature +274 -274
- data/features/kitchen_list_command.feature +104 -104
- data/features/kitchen_login_command.feature +62 -62
- data/features/kitchen_sink_command.feature +30 -30
- data/features/kitchen_test_command.feature +88 -88
- data/features/step_definitions/gem_steps.rb +36 -36
- data/features/step_definitions/git_steps.rb +5 -5
- data/features/step_definitions/output_steps.rb +5 -5
- data/features/support/env.rb +75 -75
- data/lib/kitchen.rb +150 -150
- data/lib/kitchen/base64_stream.rb +55 -55
- data/lib/kitchen/cli.rb +419 -419
- data/lib/kitchen/collection.rb +55 -55
- data/lib/kitchen/color.rb +65 -65
- data/lib/kitchen/command.rb +185 -185
- data/lib/kitchen/command/action.rb +45 -45
- data/lib/kitchen/command/console.rb +58 -58
- data/lib/kitchen/command/diagnose.rb +92 -92
- data/lib/kitchen/command/driver_discover.rb +105 -105
- data/lib/kitchen/command/exec.rb +41 -41
- data/lib/kitchen/command/list.rb +119 -119
- data/lib/kitchen/command/login.rb +43 -43
- data/lib/kitchen/command/sink.rb +54 -54
- data/lib/kitchen/command/test.rb +51 -51
- data/lib/kitchen/config.rb +322 -322
- data/lib/kitchen/configurable.rb +529 -529
- data/lib/kitchen/data_munger.rb +959 -959
- data/lib/kitchen/diagnostic.rb +141 -141
- data/lib/kitchen/driver.rb +56 -56
- data/lib/kitchen/driver/base.rb +134 -134
- data/lib/kitchen/driver/dummy.rb +108 -108
- data/lib/kitchen/driver/proxy.rb +72 -72
- data/lib/kitchen/driver/ssh_base.rb +357 -357
- data/lib/kitchen/errors.rb +229 -229
- data/lib/kitchen/generator/driver_create.rb +177 -177
- data/lib/kitchen/generator/init.rb +296 -296
- data/lib/kitchen/instance.rb +662 -662
- data/lib/kitchen/lazy_hash.rb +142 -142
- data/lib/kitchen/loader/yaml.rb +349 -349
- data/lib/kitchen/logger.rb +423 -423
- data/lib/kitchen/logging.rb +56 -56
- data/lib/kitchen/login_command.rb +52 -52
- data/lib/kitchen/metadata_chopper.rb +52 -52
- data/lib/kitchen/platform.rb +67 -67
- data/lib/kitchen/provisioner.rb +54 -54
- data/lib/kitchen/provisioner/base.rb +236 -236
- data/lib/kitchen/provisioner/chef/berkshelf.rb +114 -114
- data/lib/kitchen/provisioner/chef/common_sandbox.rb +322 -322
- data/lib/kitchen/provisioner/chef/librarian.rb +112 -112
- data/lib/kitchen/provisioner/chef_apply.rb +124 -124
- data/lib/kitchen/provisioner/chef_base.rb +341 -341
- data/lib/kitchen/provisioner/chef_solo.rb +88 -88
- data/lib/kitchen/provisioner/chef_zero.rb +245 -245
- data/lib/kitchen/provisioner/dummy.rb +79 -79
- data/lib/kitchen/provisioner/shell.rb +138 -138
- data/lib/kitchen/rake_tasks.rb +63 -63
- data/lib/kitchen/shell_out.rb +93 -93
- data/lib/kitchen/ssh.rb +276 -276
- data/lib/kitchen/state_file.rb +120 -120
- data/lib/kitchen/suite.rb +51 -51
- data/lib/kitchen/thor_tasks.rb +66 -66
- data/lib/kitchen/transport.rb +54 -54
- data/lib/kitchen/transport/base.rb +176 -176
- data/lib/kitchen/transport/dummy.rb +79 -79
- data/lib/kitchen/transport/ssh.rb +364 -364
- data/lib/kitchen/transport/winrm.rb +486 -486
- data/lib/kitchen/util.rb +147 -147
- data/lib/kitchen/verifier.rb +55 -55
- data/lib/kitchen/verifier/base.rb +235 -235
- data/lib/kitchen/verifier/busser.rb +277 -277
- data/lib/kitchen/verifier/dummy.rb +79 -79
- data/lib/kitchen/verifier/shell.rb +101 -101
- data/lib/kitchen/version.rb +21 -21
- data/lib/vendor/hash_recursive_merge.rb +82 -82
- data/spec/kitchen/base64_stream_spec.rb +77 -77
- data/spec/kitchen/cli_spec.rb +56 -56
- data/spec/kitchen/collection_spec.rb +80 -80
- data/spec/kitchen/color_spec.rb +54 -54
- data/spec/kitchen/config_spec.rb +408 -408
- data/spec/kitchen/configurable_spec.rb +1095 -1095
- data/spec/kitchen/data_munger_spec.rb +2694 -2694
- data/spec/kitchen/diagnostic_spec.rb +129 -129
- data/spec/kitchen/driver/base_spec.rb +121 -121
- data/spec/kitchen/driver/dummy_spec.rb +199 -199
- data/spec/kitchen/driver/proxy_spec.rb +138 -138
- data/spec/kitchen/driver/ssh_base_spec.rb +1115 -1115
- data/spec/kitchen/driver_spec.rb +112 -112
- data/spec/kitchen/errors_spec.rb +309 -309
- data/spec/kitchen/instance_spec.rb +1419 -1419
- data/spec/kitchen/lazy_hash_spec.rb +117 -117
- data/spec/kitchen/loader/yaml_spec.rb +774 -774
- data/spec/kitchen/logger_spec.rb +429 -429
- data/spec/kitchen/logging_spec.rb +59 -59
- data/spec/kitchen/login_command_spec.rb +68 -68
- data/spec/kitchen/metadata_chopper_spec.rb +82 -82
- data/spec/kitchen/platform_spec.rb +89 -89
- data/spec/kitchen/provisioner/base_spec.rb +386 -386
- data/spec/kitchen/provisioner/chef_apply_spec.rb +136 -136
- data/spec/kitchen/provisioner/chef_base_spec.rb +1161 -1161
- data/spec/kitchen/provisioner/chef_solo_spec.rb +557 -557
- data/spec/kitchen/provisioner/chef_zero_spec.rb +1001 -1001
- data/spec/kitchen/provisioner/dummy_spec.rb +99 -99
- data/spec/kitchen/provisioner/shell_spec.rb +566 -566
- data/spec/kitchen/provisioner_spec.rb +107 -107
- data/spec/kitchen/shell_out_spec.rb +150 -150
- data/spec/kitchen/ssh_spec.rb +693 -693
- data/spec/kitchen/state_file_spec.rb +129 -129
- data/spec/kitchen/suite_spec.rb +62 -62
- data/spec/kitchen/transport/base_spec.rb +89 -89
- data/spec/kitchen/transport/ssh_spec.rb +1255 -1255
- data/spec/kitchen/transport/winrm_spec.rb +1143 -1143
- data/spec/kitchen/transport_spec.rb +112 -112
- data/spec/kitchen/util_spec.rb +165 -165
- data/spec/kitchen/verifier/base_spec.rb +362 -362
- data/spec/kitchen/verifier/busser_spec.rb +610 -610
- data/spec/kitchen/verifier/dummy_spec.rb +99 -99
- data/spec/kitchen/verifier/shell_spec.rb +160 -160
- data/spec/kitchen/verifier_spec.rb +120 -120
- data/spec/kitchen_spec.rb +114 -114
- data/spec/spec_helper.rb +85 -85
- data/spec/support/powershell_max_size_spec.rb +40 -40
- data/support/busser_install_command.ps1 +14 -14
- data/support/busser_install_command.sh +14 -14
- data/support/chef-client-zero.rb +77 -77
- data/support/chef_base_init_command.ps1 +18 -18
- data/support/chef_base_init_command.sh +2 -2
- data/support/chef_base_install_command.ps1 +85 -85
- data/support/chef_base_install_command.sh +229 -229
- data/support/chef_zero_prepare_command_legacy.ps1 +9 -9
- data/support/chef_zero_prepare_command_legacy.sh +10 -10
- data/support/download_helpers.sh +109 -109
- data/support/dummy-validation.pem +27 -27
- data/templates/driver/CHANGELOG.md.erb +3 -3
- data/templates/driver/Gemfile.erb +3 -3
- data/templates/driver/README.md.erb +64 -64
- data/templates/driver/Rakefile.erb +21 -21
- data/templates/driver/driver.rb.erb +23 -23
- data/templates/driver/gemspec.erb +29 -29
- data/templates/driver/gitignore.erb +17 -17
- data/templates/driver/license_apachev2.erb +15 -15
- data/templates/driver/license_lgplv3.erb +16 -16
- data/templates/driver/license_mit.erb +22 -22
- data/templates/driver/license_reserved.erb +5 -5
- data/templates/driver/tailor.erb +4 -4
- data/templates/driver/travis.yml.erb +11 -11
- data/templates/driver/version.rb.erb +12 -12
- data/templates/init/chefignore.erb +1 -1
- data/templates/init/kitchen.yml.erb +18 -18
- data/test-kitchen.gemspec +62 -62
- data/test/integration/default/default_spec.rb +3 -3
- data/testing_windows.md +37 -37
- metadata +5 -4
|
@@ -1,79 +1,79 @@
|
|
|
1
|
-
# -*- encoding: utf-8 -*-
|
|
2
|
-
#
|
|
3
|
-
# Author:: Fletcher Nichol (<fnichol@nichol.ca>)
|
|
4
|
-
#
|
|
5
|
-
# Copyright (C) 2015, Fletcher Nichol
|
|
6
|
-
#
|
|
7
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
8
|
-
# you may not use this file except in compliance with the License.
|
|
9
|
-
# You may obtain a copy of the License at
|
|
10
|
-
#
|
|
11
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
#
|
|
13
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
# See the License for the specific language governing permissions and
|
|
17
|
-
# limitations under the License.
|
|
18
|
-
|
|
19
|
-
require "kitchen/verifier/base"
|
|
20
|
-
|
|
21
|
-
module Kitchen
|
|
22
|
-
|
|
23
|
-
module Verifier
|
|
24
|
-
|
|
25
|
-
# Dummy verifier for Kitchen. This verifier does nothing but report what
|
|
26
|
-
# would happen if this verifier did anything of consequence. As a result
|
|
27
|
-
# it may be a useful verifier to use when debugging or developing new
|
|
28
|
-
# features or plugins.
|
|
29
|
-
#
|
|
30
|
-
# @author Fletcher Nichol <fnichol@nichol.ca>
|
|
31
|
-
class Dummy < Kitchen::Verifier::Base
|
|
32
|
-
|
|
33
|
-
kitchen_verifier_api_version 1
|
|
34
|
-
|
|
35
|
-
plugin_version Kitchen::VERSION
|
|
36
|
-
|
|
37
|
-
default_config :sleep, 0
|
|
38
|
-
default_config :random_failure, false
|
|
39
|
-
|
|
40
|
-
# (see Base#call)
|
|
41
|
-
def call(state)
|
|
42
|
-
info("[#{name}] Verify on instance=#{instance} with state=#{state}")
|
|
43
|
-
sleep_if_set
|
|
44
|
-
failure_if_set
|
|
45
|
-
debug("[#{name}] Verify completed (#{config[:sleep]}s).")
|
|
46
|
-
end
|
|
47
|
-
|
|
48
|
-
private
|
|
49
|
-
|
|
50
|
-
# Sleep for a period of time, if a value is set in the config.
|
|
51
|
-
#
|
|
52
|
-
# @api private
|
|
53
|
-
def sleep_if_set
|
|
54
|
-
sleep(config[:sleep].to_f) if config[:sleep].to_f > 0.0
|
|
55
|
-
end
|
|
56
|
-
|
|
57
|
-
# Simulate a failure in an action, if set in the config.
|
|
58
|
-
#
|
|
59
|
-
# @api private
|
|
60
|
-
def failure_if_set
|
|
61
|
-
if config[:fail]
|
|
62
|
-
debug("Failure for Verifier #{name}.")
|
|
63
|
-
raise ActionFailed, "Action #verify failed for #{instance.to_str}."
|
|
64
|
-
elsif config[:random_failure] && randomly_fail?
|
|
65
|
-
debug("Random failure for Verifier #{name}.")
|
|
66
|
-
raise ActionFailed, "Action #verify failed for #{instance.to_str}."
|
|
67
|
-
end
|
|
68
|
-
end
|
|
69
|
-
|
|
70
|
-
# Determine whether or not to randomly fail.
|
|
71
|
-
#
|
|
72
|
-
# @return [true, false]
|
|
73
|
-
# @api private
|
|
74
|
-
def randomly_fail?
|
|
75
|
-
[true, false].sample
|
|
76
|
-
end
|
|
77
|
-
end
|
|
78
|
-
end
|
|
79
|
-
end
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
|
2
|
+
#
|
|
3
|
+
# Author:: Fletcher Nichol (<fnichol@nichol.ca>)
|
|
4
|
+
#
|
|
5
|
+
# Copyright (C) 2015, Fletcher Nichol
|
|
6
|
+
#
|
|
7
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
8
|
+
# you may not use this file except in compliance with the License.
|
|
9
|
+
# You may obtain a copy of the License at
|
|
10
|
+
#
|
|
11
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
+
#
|
|
13
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
14
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
+
# See the License for the specific language governing permissions and
|
|
17
|
+
# limitations under the License.
|
|
18
|
+
|
|
19
|
+
require "kitchen/verifier/base"
|
|
20
|
+
|
|
21
|
+
module Kitchen
|
|
22
|
+
|
|
23
|
+
module Verifier
|
|
24
|
+
|
|
25
|
+
# Dummy verifier for Kitchen. This verifier does nothing but report what
|
|
26
|
+
# would happen if this verifier did anything of consequence. As a result
|
|
27
|
+
# it may be a useful verifier to use when debugging or developing new
|
|
28
|
+
# features or plugins.
|
|
29
|
+
#
|
|
30
|
+
# @author Fletcher Nichol <fnichol@nichol.ca>
|
|
31
|
+
class Dummy < Kitchen::Verifier::Base
|
|
32
|
+
|
|
33
|
+
kitchen_verifier_api_version 1
|
|
34
|
+
|
|
35
|
+
plugin_version Kitchen::VERSION
|
|
36
|
+
|
|
37
|
+
default_config :sleep, 0
|
|
38
|
+
default_config :random_failure, false
|
|
39
|
+
|
|
40
|
+
# (see Base#call)
|
|
41
|
+
def call(state)
|
|
42
|
+
info("[#{name}] Verify on instance=#{instance} with state=#{state}")
|
|
43
|
+
sleep_if_set
|
|
44
|
+
failure_if_set
|
|
45
|
+
debug("[#{name}] Verify completed (#{config[:sleep]}s).")
|
|
46
|
+
end
|
|
47
|
+
|
|
48
|
+
private
|
|
49
|
+
|
|
50
|
+
# Sleep for a period of time, if a value is set in the config.
|
|
51
|
+
#
|
|
52
|
+
# @api private
|
|
53
|
+
def sleep_if_set
|
|
54
|
+
sleep(config[:sleep].to_f) if config[:sleep].to_f > 0.0
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
# Simulate a failure in an action, if set in the config.
|
|
58
|
+
#
|
|
59
|
+
# @api private
|
|
60
|
+
def failure_if_set
|
|
61
|
+
if config[:fail]
|
|
62
|
+
debug("Failure for Verifier #{name}.")
|
|
63
|
+
raise ActionFailed, "Action #verify failed for #{instance.to_str}."
|
|
64
|
+
elsif config[:random_failure] && randomly_fail?
|
|
65
|
+
debug("Random failure for Verifier #{name}.")
|
|
66
|
+
raise ActionFailed, "Action #verify failed for #{instance.to_str}."
|
|
67
|
+
end
|
|
68
|
+
end
|
|
69
|
+
|
|
70
|
+
# Determine whether or not to randomly fail.
|
|
71
|
+
#
|
|
72
|
+
# @return [true, false]
|
|
73
|
+
# @api private
|
|
74
|
+
def randomly_fail?
|
|
75
|
+
[true, false].sample
|
|
76
|
+
end
|
|
77
|
+
end
|
|
78
|
+
end
|
|
79
|
+
end
|
|
@@ -1,101 +1,101 @@
|
|
|
1
|
-
# -*- encoding: utf-8 -*-
|
|
2
|
-
#
|
|
3
|
-
# Author:: SAWANOBORI Yukihiko (<sawanoboriyu@higanworks.com>)
|
|
4
|
-
#
|
|
5
|
-
# Copyright (C) 2015, HiganWorks LLC
|
|
6
|
-
#
|
|
7
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
8
|
-
# you may not use this file except in compliance with the License.
|
|
9
|
-
# You may obtain a copy of the License at
|
|
10
|
-
#
|
|
11
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
#
|
|
13
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
# See the License for the specific language governing permissions and
|
|
17
|
-
# limitations under the License.
|
|
18
|
-
|
|
19
|
-
require "kitchen/verifier/base"
|
|
20
|
-
|
|
21
|
-
module Kitchen
|
|
22
|
-
|
|
23
|
-
module Verifier
|
|
24
|
-
|
|
25
|
-
# Shell verifier for Kitchen. This verifier just execute shell command from local.
|
|
26
|
-
#
|
|
27
|
-
# @author SAWANOBORI Yukihiko (<sawanoboriyu@higanworks.com>)
|
|
28
|
-
class Shell < Kitchen::Verifier::Base
|
|
29
|
-
require "mixlib/shellout"
|
|
30
|
-
|
|
31
|
-
kitchen_verifier_api_version 1
|
|
32
|
-
|
|
33
|
-
plugin_version Kitchen::VERSION
|
|
34
|
-
|
|
35
|
-
default_config :sleep, 0
|
|
36
|
-
default_config :command, "true"
|
|
37
|
-
default_config :shellout_opts, {}
|
|
38
|
-
default_config :live_stream, $stdout
|
|
39
|
-
default_config :remote_exec, false
|
|
40
|
-
|
|
41
|
-
# (see Base#call)
|
|
42
|
-
def call(state)
|
|
43
|
-
info("[#{name}] Verify on instance=#{instance} with state=#{state}")
|
|
44
|
-
sleep_if_set
|
|
45
|
-
merge_state_to_env(state)
|
|
46
|
-
if config[:remote_exec]
|
|
47
|
-
instance.transport.connection(state) do |conn|
|
|
48
|
-
conn.execute(config[:command])
|
|
49
|
-
end
|
|
50
|
-
else
|
|
51
|
-
shellout
|
|
52
|
-
end
|
|
53
|
-
debug("[#{name}] Verify completed.")
|
|
54
|
-
end
|
|
55
|
-
|
|
56
|
-
# for legacy drivers.
|
|
57
|
-
def run_command
|
|
58
|
-
if config[:remote_exec]
|
|
59
|
-
config[:command]
|
|
60
|
-
else
|
|
61
|
-
shellout
|
|
62
|
-
nil
|
|
63
|
-
end
|
|
64
|
-
end
|
|
65
|
-
|
|
66
|
-
private
|
|
67
|
-
|
|
68
|
-
# Sleep for a period of time, if a value is set in the config.
|
|
69
|
-
#
|
|
70
|
-
# @api private
|
|
71
|
-
def sleep_if_set
|
|
72
|
-
config[:sleep].to_i.times do
|
|
73
|
-
info(".")
|
|
74
|
-
sleep 1
|
|
75
|
-
end
|
|
76
|
-
end
|
|
77
|
-
|
|
78
|
-
def shellout
|
|
79
|
-
cmd = Mixlib::ShellOut.new(config[:command], config[:shellout_opts])
|
|
80
|
-
cmd.live_stream = config[:live_stream]
|
|
81
|
-
cmd.run_command
|
|
82
|
-
begin
|
|
83
|
-
cmd.error!
|
|
84
|
-
rescue Mixlib::ShellOut::ShellCommandFailed
|
|
85
|
-
raise ActionFailed, "Action #verify failed for #{instance.to_str}."
|
|
86
|
-
end
|
|
87
|
-
end
|
|
88
|
-
|
|
89
|
-
def merge_state_to_env(state)
|
|
90
|
-
env_state = { :environment => {} }
|
|
91
|
-
env_state[:environment]["KITCHEN_INSTANCE"] = instance.name
|
|
92
|
-
env_state[:environment]["KITCHEN_PLATFORM"] = instance.platform.name
|
|
93
|
-
env_state[:environment]["KITCHEN_SUITE"] = instance.suite.name
|
|
94
|
-
state.each_pair do |key, value|
|
|
95
|
-
env_state[:environment]["KITCHEN_" + key.to_s.upcase] = value.to_s
|
|
96
|
-
end
|
|
97
|
-
config[:shellout_opts].merge!(env_state)
|
|
98
|
-
end
|
|
99
|
-
end
|
|
100
|
-
end
|
|
101
|
-
end
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
|
2
|
+
#
|
|
3
|
+
# Author:: SAWANOBORI Yukihiko (<sawanoboriyu@higanworks.com>)
|
|
4
|
+
#
|
|
5
|
+
# Copyright (C) 2015, HiganWorks LLC
|
|
6
|
+
#
|
|
7
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
8
|
+
# you may not use this file except in compliance with the License.
|
|
9
|
+
# You may obtain a copy of the License at
|
|
10
|
+
#
|
|
11
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
+
#
|
|
13
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
14
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
+
# See the License for the specific language governing permissions and
|
|
17
|
+
# limitations under the License.
|
|
18
|
+
|
|
19
|
+
require "kitchen/verifier/base"
|
|
20
|
+
|
|
21
|
+
module Kitchen
|
|
22
|
+
|
|
23
|
+
module Verifier
|
|
24
|
+
|
|
25
|
+
# Shell verifier for Kitchen. This verifier just execute shell command from local.
|
|
26
|
+
#
|
|
27
|
+
# @author SAWANOBORI Yukihiko (<sawanoboriyu@higanworks.com>)
|
|
28
|
+
class Shell < Kitchen::Verifier::Base
|
|
29
|
+
require "mixlib/shellout"
|
|
30
|
+
|
|
31
|
+
kitchen_verifier_api_version 1
|
|
32
|
+
|
|
33
|
+
plugin_version Kitchen::VERSION
|
|
34
|
+
|
|
35
|
+
default_config :sleep, 0
|
|
36
|
+
default_config :command, "true"
|
|
37
|
+
default_config :shellout_opts, {}
|
|
38
|
+
default_config :live_stream, $stdout
|
|
39
|
+
default_config :remote_exec, false
|
|
40
|
+
|
|
41
|
+
# (see Base#call)
|
|
42
|
+
def call(state)
|
|
43
|
+
info("[#{name}] Verify on instance=#{instance} with state=#{state}")
|
|
44
|
+
sleep_if_set
|
|
45
|
+
merge_state_to_env(state)
|
|
46
|
+
if config[:remote_exec]
|
|
47
|
+
instance.transport.connection(state) do |conn|
|
|
48
|
+
conn.execute(config[:command])
|
|
49
|
+
end
|
|
50
|
+
else
|
|
51
|
+
shellout
|
|
52
|
+
end
|
|
53
|
+
debug("[#{name}] Verify completed.")
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
# for legacy drivers.
|
|
57
|
+
def run_command
|
|
58
|
+
if config[:remote_exec]
|
|
59
|
+
config[:command]
|
|
60
|
+
else
|
|
61
|
+
shellout
|
|
62
|
+
nil
|
|
63
|
+
end
|
|
64
|
+
end
|
|
65
|
+
|
|
66
|
+
private
|
|
67
|
+
|
|
68
|
+
# Sleep for a period of time, if a value is set in the config.
|
|
69
|
+
#
|
|
70
|
+
# @api private
|
|
71
|
+
def sleep_if_set
|
|
72
|
+
config[:sleep].to_i.times do
|
|
73
|
+
info(".")
|
|
74
|
+
sleep 1
|
|
75
|
+
end
|
|
76
|
+
end
|
|
77
|
+
|
|
78
|
+
def shellout
|
|
79
|
+
cmd = Mixlib::ShellOut.new(config[:command], config[:shellout_opts])
|
|
80
|
+
cmd.live_stream = config[:live_stream]
|
|
81
|
+
cmd.run_command
|
|
82
|
+
begin
|
|
83
|
+
cmd.error!
|
|
84
|
+
rescue Mixlib::ShellOut::ShellCommandFailed
|
|
85
|
+
raise ActionFailed, "Action #verify failed for #{instance.to_str}."
|
|
86
|
+
end
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
def merge_state_to_env(state)
|
|
90
|
+
env_state = { :environment => {} }
|
|
91
|
+
env_state[:environment]["KITCHEN_INSTANCE"] = instance.name
|
|
92
|
+
env_state[:environment]["KITCHEN_PLATFORM"] = instance.platform.name
|
|
93
|
+
env_state[:environment]["KITCHEN_SUITE"] = instance.suite.name
|
|
94
|
+
state.each_pair do |key, value|
|
|
95
|
+
env_state[:environment]["KITCHEN_" + key.to_s.upcase] = value.to_s
|
|
96
|
+
end
|
|
97
|
+
config[:shellout_opts].merge!(env_state)
|
|
98
|
+
end
|
|
99
|
+
end
|
|
100
|
+
end
|
|
101
|
+
end
|
data/lib/kitchen/version.rb
CHANGED
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
# -*- encoding: utf-8 -*-
|
|
2
|
-
#
|
|
3
|
-
# Author:: Fletcher Nichol (<fnichol@nichol.ca>)
|
|
4
|
-
#
|
|
5
|
-
# Copyright (C) 2012, 2013, Fletcher Nichol
|
|
6
|
-
#
|
|
7
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
8
|
-
# you may not use this file except in compliance with the License.
|
|
9
|
-
# You may obtain a copy of the License at
|
|
10
|
-
#
|
|
11
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
#
|
|
13
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
# See the License for the specific language governing permissions and
|
|
17
|
-
# limitations under the License.
|
|
18
|
-
|
|
19
|
-
module Kitchen
|
|
20
|
-
VERSION = "1.7.
|
|
21
|
-
end
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
|
2
|
+
#
|
|
3
|
+
# Author:: Fletcher Nichol (<fnichol@nichol.ca>)
|
|
4
|
+
#
|
|
5
|
+
# Copyright (C) 2012, 2013, Fletcher Nichol
|
|
6
|
+
#
|
|
7
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
8
|
+
# you may not use this file except in compliance with the License.
|
|
9
|
+
# You may obtain a copy of the License at
|
|
10
|
+
#
|
|
11
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
+
#
|
|
13
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
14
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
+
# See the License for the specific language governing permissions and
|
|
17
|
+
# limitations under the License.
|
|
18
|
+
|
|
19
|
+
module Kitchen
|
|
20
|
+
VERSION = "1.7.1.dev"
|
|
21
|
+
end
|
|
@@ -1,82 +1,82 @@
|
|
|
1
|
-
# -*- encoding: utf-8 -*-
|
|
2
|
-
#
|
|
3
|
-
# = Hash Recursive Merge
|
|
4
|
-
#
|
|
5
|
-
# Merges a Ruby Hash recursively, Also known as deep merge.
|
|
6
|
-
# Recursive version of Hash#merge and Hash#merge!.
|
|
7
|
-
#
|
|
8
|
-
# Category:: Ruby
|
|
9
|
-
# Package:: Hash
|
|
10
|
-
# Author:: Simone Carletti <weppos@weppos.net>
|
|
11
|
-
# Copyright:: 2007-2008 The Authors
|
|
12
|
-
# License:: MIT License
|
|
13
|
-
# Link:: http://www.simonecarletti.com/
|
|
14
|
-
# Source:: http://gist.github.com/gists/6391/
|
|
15
|
-
#
|
|
16
|
-
module HashRecursiveMerge
|
|
17
|
-
|
|
18
|
-
#
|
|
19
|
-
# Recursive version of Hash#merge!
|
|
20
|
-
#
|
|
21
|
-
# Adds the contents of +other_hash+ to +hsh+,
|
|
22
|
-
# merging entries in +hsh+ with duplicate keys with those from +other_hash+.
|
|
23
|
-
#
|
|
24
|
-
# Compared with Hash#merge!, this method supports nested hashes.
|
|
25
|
-
# When both +hsh+ and +other_hash+ contains an entry with the same key,
|
|
26
|
-
# it merges and returns the values from both arrays.
|
|
27
|
-
#
|
|
28
|
-
# @example
|
|
29
|
-
#
|
|
30
|
-
# h1 = {"a" => 100, "b" => 200, "c" => {"c1" => 12, "c2" => 14}}
|
|
31
|
-
# h2 = {"b" => 254, "c" => {"c1" => 16, "c3" => 94}}
|
|
32
|
-
# h1.rmerge!(h2) #=> {"a" => 100, "b" => 254, "c" => {"c1" => 16, "c2" => 14, "c3" => 94}}
|
|
33
|
-
#
|
|
34
|
-
# Simply using Hash#merge! would return
|
|
35
|
-
#
|
|
36
|
-
# @example
|
|
37
|
-
#
|
|
38
|
-
# h1.merge!(h2) #=> {"a" => 100, "b" = >254, "c" => {"c1" => 16, "c3" => 94}}
|
|
39
|
-
#
|
|
40
|
-
def rmerge!(other_hash)
|
|
41
|
-
merge!(other_hash) do |_key, oldval, newval|
|
|
42
|
-
oldval.class == self.class ? oldval.rmerge!(newval) : newval
|
|
43
|
-
end
|
|
44
|
-
end
|
|
45
|
-
|
|
46
|
-
#
|
|
47
|
-
# Recursive version of Hash#merge
|
|
48
|
-
#
|
|
49
|
-
# Compared with Hash#merge!, this method supports nested hashes.
|
|
50
|
-
# When both +hsh+ and +other_hash+ contains an entry with the same key,
|
|
51
|
-
# it merges and returns the values from both arrays.
|
|
52
|
-
#
|
|
53
|
-
# Compared with Hash#merge, this method provides a different approch
|
|
54
|
-
# for merging nasted hashes.
|
|
55
|
-
# If the value of a given key is an Hash and both +other_hash+ abd +hsh
|
|
56
|
-
# includes the same key, the value is merged instead replaced with
|
|
57
|
-
# +other_hash+ value.
|
|
58
|
-
#
|
|
59
|
-
# @example
|
|
60
|
-
#
|
|
61
|
-
# h1 = {"a" => 100, "b" => 200, "c" => {"c1" => 12, "c2" => 14}}
|
|
62
|
-
# h2 = {"b" => 254, "c" => {"c1" => 16, "c3" => 94}}
|
|
63
|
-
# h1.rmerge(h2) #=> {"a" => 100, "b" => 254, "c" => {"c1" => 16, "c2" => 14, "c3" => 94}}
|
|
64
|
-
#
|
|
65
|
-
# Simply using Hash#merge would return
|
|
66
|
-
#
|
|
67
|
-
# @example
|
|
68
|
-
#
|
|
69
|
-
# h1.merge(h2) #=> {"a" => 100, "b" = >254, "c" => {"c1" => 16, "c3" => 94}}
|
|
70
|
-
#
|
|
71
|
-
def rmerge(other_hash)
|
|
72
|
-
r = {}
|
|
73
|
-
merge(other_hash) do |key, oldval, newval|
|
|
74
|
-
r[key] = oldval.class == self.class ? oldval.rmerge(newval) : newval
|
|
75
|
-
end
|
|
76
|
-
end
|
|
77
|
-
|
|
78
|
-
end
|
|
79
|
-
|
|
80
|
-
class Hash
|
|
81
|
-
include HashRecursiveMerge
|
|
82
|
-
end
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
|
2
|
+
#
|
|
3
|
+
# = Hash Recursive Merge
|
|
4
|
+
#
|
|
5
|
+
# Merges a Ruby Hash recursively, Also known as deep merge.
|
|
6
|
+
# Recursive version of Hash#merge and Hash#merge!.
|
|
7
|
+
#
|
|
8
|
+
# Category:: Ruby
|
|
9
|
+
# Package:: Hash
|
|
10
|
+
# Author:: Simone Carletti <weppos@weppos.net>
|
|
11
|
+
# Copyright:: 2007-2008 The Authors
|
|
12
|
+
# License:: MIT License
|
|
13
|
+
# Link:: http://www.simonecarletti.com/
|
|
14
|
+
# Source:: http://gist.github.com/gists/6391/
|
|
15
|
+
#
|
|
16
|
+
module HashRecursiveMerge
|
|
17
|
+
|
|
18
|
+
#
|
|
19
|
+
# Recursive version of Hash#merge!
|
|
20
|
+
#
|
|
21
|
+
# Adds the contents of +other_hash+ to +hsh+,
|
|
22
|
+
# merging entries in +hsh+ with duplicate keys with those from +other_hash+.
|
|
23
|
+
#
|
|
24
|
+
# Compared with Hash#merge!, this method supports nested hashes.
|
|
25
|
+
# When both +hsh+ and +other_hash+ contains an entry with the same key,
|
|
26
|
+
# it merges and returns the values from both arrays.
|
|
27
|
+
#
|
|
28
|
+
# @example
|
|
29
|
+
#
|
|
30
|
+
# h1 = {"a" => 100, "b" => 200, "c" => {"c1" => 12, "c2" => 14}}
|
|
31
|
+
# h2 = {"b" => 254, "c" => {"c1" => 16, "c3" => 94}}
|
|
32
|
+
# h1.rmerge!(h2) #=> {"a" => 100, "b" => 254, "c" => {"c1" => 16, "c2" => 14, "c3" => 94}}
|
|
33
|
+
#
|
|
34
|
+
# Simply using Hash#merge! would return
|
|
35
|
+
#
|
|
36
|
+
# @example
|
|
37
|
+
#
|
|
38
|
+
# h1.merge!(h2) #=> {"a" => 100, "b" = >254, "c" => {"c1" => 16, "c3" => 94}}
|
|
39
|
+
#
|
|
40
|
+
def rmerge!(other_hash)
|
|
41
|
+
merge!(other_hash) do |_key, oldval, newval|
|
|
42
|
+
oldval.class == self.class ? oldval.rmerge!(newval) : newval
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
|
|
46
|
+
#
|
|
47
|
+
# Recursive version of Hash#merge
|
|
48
|
+
#
|
|
49
|
+
# Compared with Hash#merge!, this method supports nested hashes.
|
|
50
|
+
# When both +hsh+ and +other_hash+ contains an entry with the same key,
|
|
51
|
+
# it merges and returns the values from both arrays.
|
|
52
|
+
#
|
|
53
|
+
# Compared with Hash#merge, this method provides a different approch
|
|
54
|
+
# for merging nasted hashes.
|
|
55
|
+
# If the value of a given key is an Hash and both +other_hash+ abd +hsh
|
|
56
|
+
# includes the same key, the value is merged instead replaced with
|
|
57
|
+
# +other_hash+ value.
|
|
58
|
+
#
|
|
59
|
+
# @example
|
|
60
|
+
#
|
|
61
|
+
# h1 = {"a" => 100, "b" => 200, "c" => {"c1" => 12, "c2" => 14}}
|
|
62
|
+
# h2 = {"b" => 254, "c" => {"c1" => 16, "c3" => 94}}
|
|
63
|
+
# h1.rmerge(h2) #=> {"a" => 100, "b" => 254, "c" => {"c1" => 16, "c2" => 14, "c3" => 94}}
|
|
64
|
+
#
|
|
65
|
+
# Simply using Hash#merge would return
|
|
66
|
+
#
|
|
67
|
+
# @example
|
|
68
|
+
#
|
|
69
|
+
# h1.merge(h2) #=> {"a" => 100, "b" = >254, "c" => {"c1" => 16, "c3" => 94}}
|
|
70
|
+
#
|
|
71
|
+
def rmerge(other_hash)
|
|
72
|
+
r = {}
|
|
73
|
+
merge(other_hash) do |key, oldval, newval|
|
|
74
|
+
r[key] = oldval.class == self.class ? oldval.rmerge(newval) : newval
|
|
75
|
+
end
|
|
76
|
+
end
|
|
77
|
+
|
|
78
|
+
end
|
|
79
|
+
|
|
80
|
+
class Hash
|
|
81
|
+
include HashRecursiveMerge
|
|
82
|
+
end
|