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.
Files changed (181) hide show
  1. checksums.yaml +4 -4
  2. data/.cane +8 -8
  3. data/.gitattributes +3 -0
  4. data/.github/ISSUE_TEMPLATE.md +55 -55
  5. data/.gitignore +28 -28
  6. data/.kitchen.ci.yml +23 -23
  7. data/.kitchen.proxy.yml +27 -27
  8. data/.rubocop.yml +3 -3
  9. data/.travis.yml +70 -70
  10. data/.yardopts +3 -3
  11. data/Berksfile +3 -3
  12. data/CHANGELOG.md +1090 -1083
  13. data/CONTRIBUTING.md +14 -14
  14. data/Gemfile +19 -19
  15. data/Gemfile.proxy_tests +4 -4
  16. data/Guardfile +42 -42
  17. data/LICENSE +15 -15
  18. data/MAINTAINERS.md +23 -23
  19. data/README.md +135 -135
  20. data/Rakefile +61 -61
  21. data/appveyor.yml +44 -44
  22. data/features/kitchen_action_commands.feature +164 -164
  23. data/features/kitchen_command.feature +16 -16
  24. data/features/kitchen_console_command.feature +34 -34
  25. data/features/kitchen_defaults.feature +38 -38
  26. data/features/kitchen_diagnose_command.feature +96 -96
  27. data/features/kitchen_driver_create_command.feature +64 -64
  28. data/features/kitchen_driver_discover_command.feature +25 -25
  29. data/features/kitchen_help_command.feature +16 -16
  30. data/features/kitchen_init_command.feature +274 -274
  31. data/features/kitchen_list_command.feature +104 -104
  32. data/features/kitchen_login_command.feature +62 -62
  33. data/features/kitchen_sink_command.feature +30 -30
  34. data/features/kitchen_test_command.feature +88 -88
  35. data/features/step_definitions/gem_steps.rb +36 -36
  36. data/features/step_definitions/git_steps.rb +5 -5
  37. data/features/step_definitions/output_steps.rb +5 -5
  38. data/features/support/env.rb +75 -75
  39. data/lib/kitchen.rb +150 -150
  40. data/lib/kitchen/base64_stream.rb +55 -55
  41. data/lib/kitchen/cli.rb +419 -419
  42. data/lib/kitchen/collection.rb +55 -55
  43. data/lib/kitchen/color.rb +65 -65
  44. data/lib/kitchen/command.rb +185 -185
  45. data/lib/kitchen/command/action.rb +45 -45
  46. data/lib/kitchen/command/console.rb +58 -58
  47. data/lib/kitchen/command/diagnose.rb +92 -92
  48. data/lib/kitchen/command/driver_discover.rb +105 -105
  49. data/lib/kitchen/command/exec.rb +41 -41
  50. data/lib/kitchen/command/list.rb +119 -119
  51. data/lib/kitchen/command/login.rb +43 -43
  52. data/lib/kitchen/command/sink.rb +54 -54
  53. data/lib/kitchen/command/test.rb +51 -51
  54. data/lib/kitchen/config.rb +322 -322
  55. data/lib/kitchen/configurable.rb +529 -529
  56. data/lib/kitchen/data_munger.rb +959 -959
  57. data/lib/kitchen/diagnostic.rb +141 -141
  58. data/lib/kitchen/driver.rb +56 -56
  59. data/lib/kitchen/driver/base.rb +134 -134
  60. data/lib/kitchen/driver/dummy.rb +108 -108
  61. data/lib/kitchen/driver/proxy.rb +72 -72
  62. data/lib/kitchen/driver/ssh_base.rb +357 -357
  63. data/lib/kitchen/errors.rb +229 -229
  64. data/lib/kitchen/generator/driver_create.rb +177 -177
  65. data/lib/kitchen/generator/init.rb +296 -296
  66. data/lib/kitchen/instance.rb +662 -662
  67. data/lib/kitchen/lazy_hash.rb +142 -142
  68. data/lib/kitchen/loader/yaml.rb +349 -349
  69. data/lib/kitchen/logger.rb +423 -423
  70. data/lib/kitchen/logging.rb +56 -56
  71. data/lib/kitchen/login_command.rb +52 -52
  72. data/lib/kitchen/metadata_chopper.rb +52 -52
  73. data/lib/kitchen/platform.rb +67 -67
  74. data/lib/kitchen/provisioner.rb +54 -54
  75. data/lib/kitchen/provisioner/base.rb +236 -236
  76. data/lib/kitchen/provisioner/chef/berkshelf.rb +114 -114
  77. data/lib/kitchen/provisioner/chef/common_sandbox.rb +322 -322
  78. data/lib/kitchen/provisioner/chef/librarian.rb +112 -112
  79. data/lib/kitchen/provisioner/chef_apply.rb +124 -124
  80. data/lib/kitchen/provisioner/chef_base.rb +341 -341
  81. data/lib/kitchen/provisioner/chef_solo.rb +88 -88
  82. data/lib/kitchen/provisioner/chef_zero.rb +245 -245
  83. data/lib/kitchen/provisioner/dummy.rb +79 -79
  84. data/lib/kitchen/provisioner/shell.rb +138 -138
  85. data/lib/kitchen/rake_tasks.rb +63 -63
  86. data/lib/kitchen/shell_out.rb +93 -93
  87. data/lib/kitchen/ssh.rb +276 -276
  88. data/lib/kitchen/state_file.rb +120 -120
  89. data/lib/kitchen/suite.rb +51 -51
  90. data/lib/kitchen/thor_tasks.rb +66 -66
  91. data/lib/kitchen/transport.rb +54 -54
  92. data/lib/kitchen/transport/base.rb +176 -176
  93. data/lib/kitchen/transport/dummy.rb +79 -79
  94. data/lib/kitchen/transport/ssh.rb +364 -364
  95. data/lib/kitchen/transport/winrm.rb +486 -486
  96. data/lib/kitchen/util.rb +147 -147
  97. data/lib/kitchen/verifier.rb +55 -55
  98. data/lib/kitchen/verifier/base.rb +235 -235
  99. data/lib/kitchen/verifier/busser.rb +277 -277
  100. data/lib/kitchen/verifier/dummy.rb +79 -79
  101. data/lib/kitchen/verifier/shell.rb +101 -101
  102. data/lib/kitchen/version.rb +21 -21
  103. data/lib/vendor/hash_recursive_merge.rb +82 -82
  104. data/spec/kitchen/base64_stream_spec.rb +77 -77
  105. data/spec/kitchen/cli_spec.rb +56 -56
  106. data/spec/kitchen/collection_spec.rb +80 -80
  107. data/spec/kitchen/color_spec.rb +54 -54
  108. data/spec/kitchen/config_spec.rb +408 -408
  109. data/spec/kitchen/configurable_spec.rb +1095 -1095
  110. data/spec/kitchen/data_munger_spec.rb +2694 -2694
  111. data/spec/kitchen/diagnostic_spec.rb +129 -129
  112. data/spec/kitchen/driver/base_spec.rb +121 -121
  113. data/spec/kitchen/driver/dummy_spec.rb +199 -199
  114. data/spec/kitchen/driver/proxy_spec.rb +138 -138
  115. data/spec/kitchen/driver/ssh_base_spec.rb +1115 -1115
  116. data/spec/kitchen/driver_spec.rb +112 -112
  117. data/spec/kitchen/errors_spec.rb +309 -309
  118. data/spec/kitchen/instance_spec.rb +1419 -1419
  119. data/spec/kitchen/lazy_hash_spec.rb +117 -117
  120. data/spec/kitchen/loader/yaml_spec.rb +774 -774
  121. data/spec/kitchen/logger_spec.rb +429 -429
  122. data/spec/kitchen/logging_spec.rb +59 -59
  123. data/spec/kitchen/login_command_spec.rb +68 -68
  124. data/spec/kitchen/metadata_chopper_spec.rb +82 -82
  125. data/spec/kitchen/platform_spec.rb +89 -89
  126. data/spec/kitchen/provisioner/base_spec.rb +386 -386
  127. data/spec/kitchen/provisioner/chef_apply_spec.rb +136 -136
  128. data/spec/kitchen/provisioner/chef_base_spec.rb +1161 -1161
  129. data/spec/kitchen/provisioner/chef_solo_spec.rb +557 -557
  130. data/spec/kitchen/provisioner/chef_zero_spec.rb +1001 -1001
  131. data/spec/kitchen/provisioner/dummy_spec.rb +99 -99
  132. data/spec/kitchen/provisioner/shell_spec.rb +566 -566
  133. data/spec/kitchen/provisioner_spec.rb +107 -107
  134. data/spec/kitchen/shell_out_spec.rb +150 -150
  135. data/spec/kitchen/ssh_spec.rb +693 -693
  136. data/spec/kitchen/state_file_spec.rb +129 -129
  137. data/spec/kitchen/suite_spec.rb +62 -62
  138. data/spec/kitchen/transport/base_spec.rb +89 -89
  139. data/spec/kitchen/transport/ssh_spec.rb +1255 -1255
  140. data/spec/kitchen/transport/winrm_spec.rb +1143 -1143
  141. data/spec/kitchen/transport_spec.rb +112 -112
  142. data/spec/kitchen/util_spec.rb +165 -165
  143. data/spec/kitchen/verifier/base_spec.rb +362 -362
  144. data/spec/kitchen/verifier/busser_spec.rb +610 -610
  145. data/spec/kitchen/verifier/dummy_spec.rb +99 -99
  146. data/spec/kitchen/verifier/shell_spec.rb +160 -160
  147. data/spec/kitchen/verifier_spec.rb +120 -120
  148. data/spec/kitchen_spec.rb +114 -114
  149. data/spec/spec_helper.rb +85 -85
  150. data/spec/support/powershell_max_size_spec.rb +40 -40
  151. data/support/busser_install_command.ps1 +14 -14
  152. data/support/busser_install_command.sh +14 -14
  153. data/support/chef-client-zero.rb +77 -77
  154. data/support/chef_base_init_command.ps1 +18 -18
  155. data/support/chef_base_init_command.sh +2 -2
  156. data/support/chef_base_install_command.ps1 +85 -85
  157. data/support/chef_base_install_command.sh +229 -229
  158. data/support/chef_zero_prepare_command_legacy.ps1 +9 -9
  159. data/support/chef_zero_prepare_command_legacy.sh +10 -10
  160. data/support/download_helpers.sh +109 -109
  161. data/support/dummy-validation.pem +27 -27
  162. data/templates/driver/CHANGELOG.md.erb +3 -3
  163. data/templates/driver/Gemfile.erb +3 -3
  164. data/templates/driver/README.md.erb +64 -64
  165. data/templates/driver/Rakefile.erb +21 -21
  166. data/templates/driver/driver.rb.erb +23 -23
  167. data/templates/driver/gemspec.erb +29 -29
  168. data/templates/driver/gitignore.erb +17 -17
  169. data/templates/driver/license_apachev2.erb +15 -15
  170. data/templates/driver/license_lgplv3.erb +16 -16
  171. data/templates/driver/license_mit.erb +22 -22
  172. data/templates/driver/license_reserved.erb +5 -5
  173. data/templates/driver/tailor.erb +4 -4
  174. data/templates/driver/travis.yml.erb +11 -11
  175. data/templates/driver/version.rb.erb +12 -12
  176. data/templates/init/chefignore.erb +1 -1
  177. data/templates/init/kitchen.yml.erb +18 -18
  178. data/test-kitchen.gemspec +62 -62
  179. data/test/integration/default/default_spec.rb +3 -3
  180. data/testing_windows.md +37 -37
  181. 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
@@ -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.0"
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