test-kitchen 1.6.0 → 1.7.0

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 (180) hide show
  1. checksums.yaml +4 -4
  2. data/.cane +8 -7
  3. data/.github/ISSUE_TEMPLATE.md +56 -0
  4. data/.gitignore +28 -27
  5. data/.kitchen.ci.yml +23 -0
  6. data/.kitchen.proxy.yml +27 -0
  7. data/.rubocop.yml +3 -3
  8. data/.travis.yml +70 -53
  9. data/.yardopts +3 -3
  10. data/Berksfile +3 -0
  11. data/CHANGELOG.md +1083 -1051
  12. data/CONTRIBUTING.md +14 -14
  13. data/Gemfile +19 -14
  14. data/Gemfile.proxy_tests +4 -5
  15. data/Guardfile +42 -42
  16. data/LICENSE +15 -15
  17. data/MAINTAINERS.md +23 -24
  18. data/README.md +135 -135
  19. data/Rakefile +61 -76
  20. data/appveyor.yml +44 -34
  21. data/features/kitchen_action_commands.feature +164 -164
  22. data/features/kitchen_command.feature +16 -16
  23. data/features/kitchen_console_command.feature +34 -34
  24. data/features/kitchen_defaults.feature +38 -38
  25. data/features/kitchen_diagnose_command.feature +96 -96
  26. data/features/kitchen_driver_create_command.feature +64 -64
  27. data/features/kitchen_driver_discover_command.feature +25 -25
  28. data/features/kitchen_help_command.feature +16 -16
  29. data/features/kitchen_init_command.feature +274 -274
  30. data/features/kitchen_list_command.feature +104 -104
  31. data/features/kitchen_login_command.feature +62 -62
  32. data/features/kitchen_sink_command.feature +30 -30
  33. data/features/kitchen_test_command.feature +88 -88
  34. data/features/step_definitions/gem_steps.rb +36 -36
  35. data/features/step_definitions/git_steps.rb +5 -5
  36. data/features/step_definitions/output_steps.rb +5 -5
  37. data/features/support/env.rb +75 -75
  38. data/lib/kitchen.rb +150 -150
  39. data/lib/kitchen/base64_stream.rb +55 -55
  40. data/lib/kitchen/cli.rb +419 -419
  41. data/lib/kitchen/collection.rb +55 -55
  42. data/lib/kitchen/color.rb +65 -65
  43. data/lib/kitchen/command.rb +185 -185
  44. data/lib/kitchen/command/action.rb +45 -45
  45. data/lib/kitchen/command/console.rb +58 -58
  46. data/lib/kitchen/command/diagnose.rb +92 -92
  47. data/lib/kitchen/command/driver_discover.rb +105 -105
  48. data/lib/kitchen/command/exec.rb +41 -41
  49. data/lib/kitchen/command/list.rb +119 -119
  50. data/lib/kitchen/command/login.rb +43 -43
  51. data/lib/kitchen/command/sink.rb +54 -54
  52. data/lib/kitchen/command/test.rb +51 -51
  53. data/lib/kitchen/config.rb +322 -322
  54. data/lib/kitchen/configurable.rb +529 -529
  55. data/lib/kitchen/data_munger.rb +959 -960
  56. data/lib/kitchen/diagnostic.rb +141 -141
  57. data/lib/kitchen/driver.rb +56 -56
  58. data/lib/kitchen/driver/base.rb +134 -134
  59. data/lib/kitchen/driver/dummy.rb +108 -108
  60. data/lib/kitchen/driver/proxy.rb +72 -72
  61. data/lib/kitchen/driver/ssh_base.rb +357 -357
  62. data/lib/kitchen/errors.rb +229 -229
  63. data/lib/kitchen/generator/driver_create.rb +177 -177
  64. data/lib/kitchen/generator/init.rb +296 -296
  65. data/lib/kitchen/instance.rb +662 -662
  66. data/lib/kitchen/lazy_hash.rb +142 -142
  67. data/lib/kitchen/loader/yaml.rb +349 -349
  68. data/lib/kitchen/logger.rb +423 -423
  69. data/lib/kitchen/logging.rb +56 -56
  70. data/lib/kitchen/login_command.rb +52 -52
  71. data/lib/kitchen/metadata_chopper.rb +52 -52
  72. data/lib/kitchen/platform.rb +67 -67
  73. data/lib/kitchen/provisioner.rb +54 -54
  74. data/lib/kitchen/provisioner/base.rb +236 -236
  75. data/lib/kitchen/provisioner/chef/berkshelf.rb +114 -114
  76. data/lib/kitchen/provisioner/chef/common_sandbox.rb +322 -322
  77. data/lib/kitchen/provisioner/chef/librarian.rb +112 -112
  78. data/lib/kitchen/provisioner/chef_apply.rb +124 -125
  79. data/lib/kitchen/provisioner/chef_base.rb +341 -294
  80. data/lib/kitchen/provisioner/chef_solo.rb +88 -89
  81. data/lib/kitchen/provisioner/chef_zero.rb +245 -245
  82. data/lib/kitchen/provisioner/dummy.rb +79 -79
  83. data/lib/kitchen/provisioner/shell.rb +138 -138
  84. data/lib/kitchen/rake_tasks.rb +63 -63
  85. data/lib/kitchen/shell_out.rb +93 -93
  86. data/lib/kitchen/ssh.rb +276 -276
  87. data/lib/kitchen/state_file.rb +120 -120
  88. data/lib/kitchen/suite.rb +51 -51
  89. data/lib/kitchen/thor_tasks.rb +66 -66
  90. data/lib/kitchen/transport.rb +54 -54
  91. data/lib/kitchen/transport/base.rb +176 -176
  92. data/lib/kitchen/transport/dummy.rb +79 -79
  93. data/lib/kitchen/transport/ssh.rb +364 -364
  94. data/lib/kitchen/transport/winrm.rb +486 -486
  95. data/lib/kitchen/util.rb +147 -147
  96. data/lib/kitchen/verifier.rb +55 -55
  97. data/lib/kitchen/verifier/base.rb +235 -235
  98. data/lib/kitchen/verifier/busser.rb +277 -277
  99. data/lib/kitchen/verifier/dummy.rb +79 -79
  100. data/lib/kitchen/verifier/shell.rb +101 -101
  101. data/lib/kitchen/version.rb +21 -21
  102. data/lib/vendor/hash_recursive_merge.rb +82 -82
  103. data/spec/kitchen/base64_stream_spec.rb +77 -77
  104. data/spec/kitchen/cli_spec.rb +56 -56
  105. data/spec/kitchen/collection_spec.rb +80 -80
  106. data/spec/kitchen/color_spec.rb +54 -54
  107. data/spec/kitchen/config_spec.rb +408 -408
  108. data/spec/kitchen/configurable_spec.rb +1095 -1062
  109. data/spec/kitchen/data_munger_spec.rb +2694 -2383
  110. data/spec/kitchen/diagnostic_spec.rb +129 -129
  111. data/spec/kitchen/driver/base_spec.rb +121 -121
  112. data/spec/kitchen/driver/dummy_spec.rb +199 -199
  113. data/spec/kitchen/driver/proxy_spec.rb +138 -138
  114. data/spec/kitchen/driver/ssh_base_spec.rb +1115 -1115
  115. data/spec/kitchen/driver_spec.rb +112 -112
  116. data/spec/kitchen/errors_spec.rb +309 -309
  117. data/spec/kitchen/instance_spec.rb +1419 -1419
  118. data/spec/kitchen/lazy_hash_spec.rb +117 -117
  119. data/spec/kitchen/loader/yaml_spec.rb +774 -774
  120. data/spec/kitchen/logger_spec.rb +429 -429
  121. data/spec/kitchen/logging_spec.rb +59 -59
  122. data/spec/kitchen/login_command_spec.rb +68 -68
  123. data/spec/kitchen/metadata_chopper_spec.rb +82 -82
  124. data/spec/kitchen/platform_spec.rb +89 -89
  125. data/spec/kitchen/provisioner/base_spec.rb +386 -386
  126. data/spec/kitchen/provisioner/chef_apply_spec.rb +136 -136
  127. data/spec/kitchen/provisioner/chef_base_spec.rb +1161 -1067
  128. data/spec/kitchen/provisioner/chef_solo_spec.rb +557 -557
  129. data/spec/kitchen/provisioner/chef_zero_spec.rb +1001 -1001
  130. data/spec/kitchen/provisioner/dummy_spec.rb +99 -99
  131. data/spec/kitchen/provisioner/shell_spec.rb +566 -566
  132. data/spec/kitchen/provisioner_spec.rb +107 -107
  133. data/spec/kitchen/shell_out_spec.rb +150 -150
  134. data/spec/kitchen/ssh_spec.rb +693 -693
  135. data/spec/kitchen/state_file_spec.rb +129 -129
  136. data/spec/kitchen/suite_spec.rb +62 -62
  137. data/spec/kitchen/transport/base_spec.rb +89 -89
  138. data/spec/kitchen/transport/ssh_spec.rb +1255 -1255
  139. data/spec/kitchen/transport/winrm_spec.rb +1143 -1143
  140. data/spec/kitchen/transport_spec.rb +112 -112
  141. data/spec/kitchen/util_spec.rb +165 -165
  142. data/spec/kitchen/verifier/base_spec.rb +362 -362
  143. data/spec/kitchen/verifier/busser_spec.rb +610 -610
  144. data/spec/kitchen/verifier/dummy_spec.rb +99 -99
  145. data/spec/kitchen/verifier/shell_spec.rb +160 -158
  146. data/spec/kitchen/verifier_spec.rb +120 -120
  147. data/spec/kitchen_spec.rb +114 -114
  148. data/spec/spec_helper.rb +85 -85
  149. data/spec/support/powershell_max_size_spec.rb +40 -40
  150. data/support/busser_install_command.ps1 +14 -14
  151. data/support/busser_install_command.sh +14 -14
  152. data/support/chef-client-zero.rb +77 -77
  153. data/support/chef_base_init_command.ps1 +18 -18
  154. data/support/chef_base_init_command.sh +2 -2
  155. data/support/chef_base_install_command.ps1 +85 -85
  156. data/support/chef_base_install_command.sh +229 -229
  157. data/support/chef_zero_prepare_command_legacy.ps1 +9 -9
  158. data/support/chef_zero_prepare_command_legacy.sh +10 -10
  159. data/support/download_helpers.sh +109 -109
  160. data/support/dummy-validation.pem +27 -27
  161. data/templates/driver/CHANGELOG.md.erb +3 -3
  162. data/templates/driver/Gemfile.erb +3 -3
  163. data/templates/driver/README.md.erb +64 -64
  164. data/templates/driver/Rakefile.erb +21 -21
  165. data/templates/driver/driver.rb.erb +23 -23
  166. data/templates/driver/gemspec.erb +29 -29
  167. data/templates/driver/gitignore.erb +17 -17
  168. data/templates/driver/license_apachev2.erb +15 -15
  169. data/templates/driver/license_lgplv3.erb +16 -16
  170. data/templates/driver/license_mit.erb +22 -22
  171. data/templates/driver/license_reserved.erb +5 -5
  172. data/templates/driver/tailor.erb +4 -4
  173. data/templates/driver/travis.yml.erb +11 -11
  174. data/templates/driver/version.rb.erb +12 -12
  175. data/templates/init/chefignore.erb +1 -1
  176. data/templates/init/kitchen.yml.erb +18 -18
  177. data/test-kitchen.gemspec +62 -62
  178. data/test/integration/default/default_spec.rb +3 -0
  179. data/testing_windows.md +37 -37
  180. metadata +23 -11
@@ -1,112 +1,112 @@
1
- # -*- encoding: utf-8 -*-
2
- #
3
- # Author:: Fletcher Nichol (<fnichol@nichol.ca>)
4
- #
5
- # Copyright (C) 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
- require "kitchen/errors"
20
- require "kitchen/logging"
21
-
22
- module Kitchen
23
-
24
- module Provisioner
25
-
26
- module Chef
27
-
28
- # Chef cookbook resolver that uses Librarian-Chef and a Cheffile to
29
- # calculate dependencies.
30
- #
31
- # @author Fletcher Nichol <fnichol@nichol.ca>
32
- class Librarian
33
-
34
- include Logging
35
-
36
- # Creates a new cookbook resolver.
37
- #
38
- # @param cheffile [String] path to a Cheffile
39
- # @param path [String] path in which to vendor the resulting
40
- # cookbooks
41
- # @param logger [Kitchen::Logger] a logger to use for output, defaults
42
- # to `Kitchen.logger`
43
- def initialize(cheffile, path, logger = Kitchen.logger)
44
- @cheffile = cheffile
45
- @path = path
46
- @logger = logger
47
- end
48
-
49
- # Loads the library code required to use the resolver.
50
- #
51
- # @param logger [Kitchen::Logger] a logger to use for output, defaults
52
- # to `Kitchen.logger`
53
- def self.load!(logger = Kitchen.logger)
54
- load_librarian!(logger)
55
- end
56
-
57
- # Performs the cookbook resolution and vendors the resulting cookbooks
58
- # in the desired path.
59
- def resolve
60
- version = ::Librarian::Chef::VERSION
61
- info("Resolving cookbook dependencies with Librarian-Chef #{version}...")
62
- debug("Using Cheffile from #{cheffile}")
63
-
64
- env = ::Librarian::Chef::Environment.new(
65
- :project_path => File.dirname(cheffile))
66
- env.config_db.local["path"] = path
67
- ::Librarian::Action::Resolve.new(env).run
68
- ::Librarian::Action::Install.new(env).run
69
- end
70
-
71
- private
72
-
73
- # @return [String] path to a Cheffile
74
- # @api private
75
- attr_reader :cheffile
76
-
77
- # @return [String] path in which to vendor the resulting cookbooks
78
- # @api private
79
- attr_reader :path
80
-
81
- # @return [Kitchen::Logger] a logger to use for output
82
- # @api private
83
- attr_reader :logger
84
-
85
- # Load the Librarian-specific libary code.
86
- #
87
- # @param logger [Kitchen::Logger] the logger to use
88
- # @raise [UserError] if the library couldn't be loaded
89
- # @api private
90
- def self.load_librarian!(logger)
91
- first_load = require "librarian/chef/environment"
92
- require "librarian/action/resolve"
93
- require "librarian/action/install"
94
-
95
- version = ::Librarian::Chef::VERSION
96
- if first_load
97
- logger.debug("Librarian-Chef #{version} library loaded")
98
- else
99
- logger.debug("Librarian-Chef #{version} previously loaded")
100
- end
101
- rescue LoadError => e
102
- logger.fatal("The `librarian-chef' gem is missing and must be installed" \
103
- " or cannot be properly activated. Run" \
104
- " `gem install librarian-chef` or add the following to your" \
105
- " Gemfile if you are using Bundler: `gem 'librarian-chef'`.")
106
- raise UserError,
107
- "Could not load or activate Librarian-Chef (#{e.message})"
108
- end
109
- end
110
- end
111
- end
112
- end
1
+ # -*- encoding: utf-8 -*-
2
+ #
3
+ # Author:: Fletcher Nichol (<fnichol@nichol.ca>)
4
+ #
5
+ # Copyright (C) 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
+ require "kitchen/errors"
20
+ require "kitchen/logging"
21
+
22
+ module Kitchen
23
+
24
+ module Provisioner
25
+
26
+ module Chef
27
+
28
+ # Chef cookbook resolver that uses Librarian-Chef and a Cheffile to
29
+ # calculate dependencies.
30
+ #
31
+ # @author Fletcher Nichol <fnichol@nichol.ca>
32
+ class Librarian
33
+
34
+ include Logging
35
+
36
+ # Creates a new cookbook resolver.
37
+ #
38
+ # @param cheffile [String] path to a Cheffile
39
+ # @param path [String] path in which to vendor the resulting
40
+ # cookbooks
41
+ # @param logger [Kitchen::Logger] a logger to use for output, defaults
42
+ # to `Kitchen.logger`
43
+ def initialize(cheffile, path, logger = Kitchen.logger)
44
+ @cheffile = cheffile
45
+ @path = path
46
+ @logger = logger
47
+ end
48
+
49
+ # Loads the library code required to use the resolver.
50
+ #
51
+ # @param logger [Kitchen::Logger] a logger to use for output, defaults
52
+ # to `Kitchen.logger`
53
+ def self.load!(logger = Kitchen.logger)
54
+ load_librarian!(logger)
55
+ end
56
+
57
+ # Performs the cookbook resolution and vendors the resulting cookbooks
58
+ # in the desired path.
59
+ def resolve
60
+ version = ::Librarian::Chef::VERSION
61
+ info("Resolving cookbook dependencies with Librarian-Chef #{version}...")
62
+ debug("Using Cheffile from #{cheffile}")
63
+
64
+ env = ::Librarian::Chef::Environment.new(
65
+ :project_path => File.dirname(cheffile))
66
+ env.config_db.local["path"] = path
67
+ ::Librarian::Action::Resolve.new(env).run
68
+ ::Librarian::Action::Install.new(env).run
69
+ end
70
+
71
+ private
72
+
73
+ # @return [String] path to a Cheffile
74
+ # @api private
75
+ attr_reader :cheffile
76
+
77
+ # @return [String] path in which to vendor the resulting cookbooks
78
+ # @api private
79
+ attr_reader :path
80
+
81
+ # @return [Kitchen::Logger] a logger to use for output
82
+ # @api private
83
+ attr_reader :logger
84
+
85
+ # Load the Librarian-specific libary code.
86
+ #
87
+ # @param logger [Kitchen::Logger] the logger to use
88
+ # @raise [UserError] if the library couldn't be loaded
89
+ # @api private
90
+ def self.load_librarian!(logger)
91
+ first_load = require "librarian/chef/environment"
92
+ require "librarian/action/resolve"
93
+ require "librarian/action/install"
94
+
95
+ version = ::Librarian::Chef::VERSION
96
+ if first_load
97
+ logger.debug("Librarian-Chef #{version} library loaded")
98
+ else
99
+ logger.debug("Librarian-Chef #{version} previously loaded")
100
+ end
101
+ rescue LoadError => e
102
+ logger.fatal("The `librarian-chef' gem is missing and must be installed" \
103
+ " or cannot be properly activated. Run" \
104
+ " `gem install librarian-chef` or add the following to your" \
105
+ " Gemfile if you are using Bundler: `gem 'librarian-chef'`.")
106
+ raise UserError,
107
+ "Could not load or activate Librarian-Chef (#{e.message})"
108
+ end
109
+ end
110
+ end
111
+ end
112
+ end
@@ -1,125 +1,124 @@
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
- # Usage:
20
- #
21
- # puts your recipes to` apply/` directory.
22
- #
23
- # An example of .kitchen.yml.
24
- #
25
- # ---
26
- # driver:
27
- # name: vagrant
28
- #
29
- # provisioner:
30
- # name: chef_apply
31
- #
32
- # platforms:
33
- # - name: ubuntu-12.04
34
- # - name: centos-6.4
35
- #
36
- # suites:
37
- # - name: default
38
- # run_list:
39
- # - recipe1
40
- # - recipe2
41
- #
42
- #
43
- # The chef-apply runs twice below.
44
- #
45
- # chef-apply apply/recipe1.rb
46
- # chef-apply apply/recipe2.rb
47
-
48
- require "kitchen/provisioner/chef_base"
49
-
50
- module Kitchen
51
-
52
- module Provisioner
53
-
54
- # Chef Apply provisioner.
55
- #
56
- # @author SAWANOBORI Yukihiko <sawanoboriyu@higanworks.com>)
57
- class ChefApply < ChefBase
58
-
59
- kitchen_provisioner_api_version 2
60
-
61
- plugin_version Kitchen::VERSION
62
-
63
- default_config :chef_apply_path do |provisioner|
64
- provisioner.
65
- remote_path_join(%W[#{provisioner[:chef_omnibus_root]} bin chef-apply]).
66
- tap { |path| path.concat(".bat") if provisioner.windows_os? }
67
- end
68
-
69
- default_config :apply_path do |provisioner|
70
- provisioner.calculate_path("apply")
71
- end
72
- expand_path_for :apply_path
73
-
74
- # (see ChefBase#create_sandbox)
75
- def create_sandbox
76
- @sandbox_path = Dir.mktmpdir("#{instance.name}-sandbox-")
77
- File.chmod(0755, sandbox_path)
78
- info("Preparing files for transfer")
79
- debug("Creating local sandbox in #{sandbox_path}")
80
-
81
- prepare_json
82
- prepare(:apply)
83
- end
84
-
85
- # (see ChefBase#init_command)
86
- def init_command
87
- dirs = %w[
88
- apply
89
- ].sort.map { |dir| remote_path_join(config[:root_path], dir) }
90
-
91
- vars = if powershell_shell?
92
- init_command_vars_for_powershell(dirs)
93
- else
94
- init_command_vars_for_bourne(dirs)
95
- end
96
-
97
- prefix_command(shell_code_from_file(vars, "chef_base_init_command"))
98
- end
99
-
100
- # (see ChefSolo#run_command)
101
- def run_command
102
- level = config[:log_level] == :info ? :auto : config[:log_level]
103
-
104
- lines = []
105
- config[:run_list].map do |recipe|
106
- cmd = sudo(config[:chef_apply_path]).dup.
107
- tap { |str| str.insert(0, "& ") if powershell_shell? }
108
- args = [
109
- "apply/#{recipe}.rb",
110
- "--log_level #{level}",
111
- "--no-color"
112
- ]
113
- args << "--logfile #{config[:log_file]}" if config[:log_file]
114
-
115
- lines << wrap_shell_code(
116
- [cmd, *args].join(" ").
117
- tap { |str| str.insert(0, reload_ps1_path) if windows_os? }
118
- )
119
- end
120
-
121
- prefix_command(lines.join("\n"))
122
- end
123
- end
124
- end
125
- 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
+ # Usage:
20
+ #
21
+ # puts your recipes to` apply/` directory.
22
+ #
23
+ # An example of .kitchen.yml.
24
+ #
25
+ # ---
26
+ # driver:
27
+ # name: vagrant
28
+ #
29
+ # provisioner:
30
+ # name: chef_apply
31
+ #
32
+ # platforms:
33
+ # - name: ubuntu-12.04
34
+ # - name: centos-6.4
35
+ #
36
+ # suites:
37
+ # - name: default
38
+ # run_list:
39
+ # - recipe1
40
+ # - recipe2
41
+ #
42
+ #
43
+ # The chef-apply runs twice below.
44
+ #
45
+ # chef-apply apply/recipe1.rb
46
+ # chef-apply apply/recipe2.rb
47
+
48
+ require "kitchen/provisioner/chef_base"
49
+
50
+ module Kitchen
51
+
52
+ module Provisioner
53
+
54
+ # Chef Apply provisioner.
55
+ #
56
+ # @author SAWANOBORI Yukihiko <sawanoboriyu@higanworks.com>)
57
+ class ChefApply < ChefBase
58
+
59
+ kitchen_provisioner_api_version 2
60
+
61
+ plugin_version Kitchen::VERSION
62
+
63
+ default_config :chef_apply_path do |provisioner|
64
+ provisioner.
65
+ remote_path_join(%W[#{provisioner[:chef_omnibus_root]} bin chef-apply]).
66
+ tap { |path| path.concat(".bat") if provisioner.windows_os? }
67
+ end
68
+
69
+ default_config :apply_path do |provisioner|
70
+ provisioner.calculate_path("apply")
71
+ end
72
+ expand_path_for :apply_path
73
+
74
+ # (see ChefBase#create_sandbox)
75
+ def create_sandbox
76
+ @sandbox_path = Dir.mktmpdir("#{instance.name}-sandbox-")
77
+ File.chmod(0755, sandbox_path)
78
+ info("Preparing files for transfer")
79
+ debug("Creating local sandbox in #{sandbox_path}")
80
+
81
+ prepare_json
82
+ prepare(:apply)
83
+ end
84
+
85
+ # (see ChefBase#init_command)
86
+ def init_command
87
+ dirs = %w[
88
+ apply
89
+ ].sort.map { |dir| remote_path_join(config[:root_path], dir) }
90
+
91
+ vars = if powershell_shell?
92
+ init_command_vars_for_powershell(dirs)
93
+ else
94
+ init_command_vars_for_bourne(dirs)
95
+ end
96
+
97
+ prefix_command(shell_code_from_file(vars, "chef_base_init_command"))
98
+ end
99
+
100
+ # (see ChefSolo#run_command)
101
+ def run_command
102
+ level = config[:log_level]
103
+ lines = []
104
+ config[:run_list].map do |recipe|
105
+ cmd = sudo(config[:chef_apply_path]).dup.
106
+ tap { |str| str.insert(0, "& ") if powershell_shell? }
107
+ args = [
108
+ "apply/#{recipe}.rb",
109
+ "--log_level #{level}",
110
+ "--no-color"
111
+ ]
112
+ args << "--logfile #{config[:log_file]}" if config[:log_file]
113
+
114
+ lines << wrap_shell_code(
115
+ [cmd, *args].join(" ").
116
+ tap { |str| str.insert(0, reload_ps1_path) if windows_os? }
117
+ )
118
+ end
119
+
120
+ prefix_command(lines.join("\n"))
121
+ end
122
+ end
123
+ end
124
+ end