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,386 +1,386 @@
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_relative "../../spec_helper"
20
- require "logger"
21
- require "stringio"
22
-
23
- require "kitchen"
24
-
25
- module Kitchen
26
-
27
- module Provisioner
28
-
29
- class TestingDummy < Kitchen::Provisioner::Base
30
-
31
- attr_reader :called_create_sandbox, :called_cleanup_sandbox
32
-
33
- def install_command
34
- "install"
35
- end
36
-
37
- def init_command
38
- "init"
39
- end
40
-
41
- def prepare_command
42
- "prepare"
43
- end
44
-
45
- def run_command
46
- "run"
47
- end
48
-
49
- def create_sandbox
50
- @called_create_sandbox = true
51
- end
52
-
53
- def cleanup_sandbox
54
- @called_cleanup_sandbox = true
55
- end
56
-
57
- def sandbox_path
58
- "/tmp/sandbox"
59
- end
60
- end
61
- end
62
- end
63
-
64
- describe Kitchen::Provisioner::Base do
65
-
66
- let(:logged_output) { StringIO.new }
67
- let(:logger) { Logger.new(logged_output) }
68
- let(:platform) { stub(:os_type => nil, :shell_type => nil) }
69
- let(:config) { Hash.new }
70
-
71
- let(:transport) do
72
- t = mock("transport")
73
- t.responds_like_instance_of(Kitchen::Transport::Base)
74
- t
75
- end
76
-
77
- let(:instance) do
78
- stub(
79
- :name => "coolbeans",
80
- :to_str => "instance",
81
- :logger => logger,
82
- :platform => platform,
83
- :transport => transport
84
- )
85
- end
86
-
87
- let(:provisioner) do
88
- Kitchen::Provisioner::Base.new(config).finalize_config!(instance)
89
- end
90
-
91
- describe "configuration" do
92
-
93
- describe "for unix operating systems" do
94
-
95
- before { platform.stubs(:os_type).returns("unix") }
96
-
97
- it ":root_path defaults to /tmp/kitchen" do
98
- provisioner[:root_path].must_equal "/tmp/kitchen"
99
- end
100
-
101
- it ":sudo defaults to true" do
102
- provisioner[:sudo].must_equal true
103
- end
104
-
105
- it ":sudo_command defaults to sudo -E" do
106
- provisioner[:sudo_command].must_equal "sudo -E"
107
- end
108
- end
109
-
110
- describe "for windows operating systems" do
111
-
112
- before { platform.stubs(:os_type).returns("windows") }
113
-
114
- it ":root_path defaults to $env:TEMP\\kitchen" do
115
- provisioner[:root_path].must_equal "$env:TEMP\\kitchen"
116
- end
117
-
118
- it ":sudo defaults to nil" do
119
- provisioner[:sudo].must_equal nil
120
- end
121
-
122
- it ":sudo_command defaults to nil" do
123
- provisioner[:sudo_command].must_equal nil
124
- end
125
- end
126
-
127
- it ":http_proxy defaults to nil" do
128
- provisioner[:http_proxy].must_equal nil
129
- end
130
-
131
- it ":http_proxys defaults to nil" do
132
- provisioner[:https_proxy].must_equal nil
133
- end
134
-
135
- it ":ftp_proxy defaults to nil" do
136
- provisioner[:ftp_proxy].must_equal nil
137
- end
138
- end
139
-
140
- describe "#call" do
141
-
142
- let(:state) { Hash.new }
143
- let(:cmd) { provisioner.call(state) }
144
-
145
- let(:connection) do
146
- c = mock("transport_connection")
147
- c.responds_like_instance_of(Kitchen::Transport::Base::Connection)
148
- c
149
- end
150
-
151
- let(:provisioner) do
152
- Kitchen::Provisioner::TestingDummy.new(config).finalize_config!(instance)
153
- end
154
-
155
- before do
156
- FakeFS.activate!
157
- FileUtils.mkdir_p(File.join(provisioner.sandbox_path, "stuff"))
158
- transport.stubs(:connection).yields(connection)
159
- connection.stubs(:execute)
160
- connection.stubs(:upload)
161
- end
162
-
163
- after do
164
- FakeFS.deactivate!
165
- FakeFS::FileSystem.clear
166
- end
167
-
168
- it "creates the sandbox" do
169
- provisioner.expects(:create_sandbox)
170
-
171
- cmd
172
- end
173
-
174
- it "ensures that the sandbox is cleanup up" do
175
- transport.stubs(:connection).raises
176
- provisioner.expects(:cleanup_sandbox)
177
-
178
- begin
179
- cmd
180
- rescue # rubocop:disable Lint/HandleExceptions
181
- end
182
- end
183
-
184
- it "yields a connection given the state" do
185
- state[:a] = "b"
186
- transport.expects(:connection).with(state).yields(connection)
187
-
188
- cmd
189
- end
190
-
191
- it "invokes the provisioner commands over the transport" do
192
- order = sequence("order")
193
- connection.expects(:execute).with("install").in_sequence(order)
194
- connection.expects(:execute).with("init").in_sequence(order)
195
- connection.expects(:execute).with("prepare").in_sequence(order)
196
- connection.expects(:execute).with("run").in_sequence(order)
197
-
198
- cmd
199
- end
200
-
201
- it "logs to info" do
202
- cmd
203
-
204
- logged_output.string.
205
- must_match(/INFO -- : Transferring files to instance$/)
206
- end
207
-
208
- it "uploads sandbox files" do
209
- connection.expects(:upload).with(["/tmp/sandbox/stuff"], "/tmp/kitchen")
210
-
211
- cmd
212
- end
213
-
214
- it "logs to debug" do
215
- cmd
216
-
217
- logged_output.string.must_match(/DEBUG -- : Transfer complete$/)
218
- end
219
-
220
- it "raises an ActionFailed on transfer when TransportFailed is raised" do
221
- connection.stubs(:upload).
222
- raises(Kitchen::Transport::TransportFailed.new("dang"))
223
-
224
- proc { cmd }.must_raise Kitchen::ActionFailed
225
- end
226
-
227
- it "raises an ActionFailed on execute when TransportFailed is raised" do
228
- connection.stubs(:execute).
229
- raises(Kitchen::Transport::TransportFailed.new("dang"))
230
-
231
- proc { cmd }.must_raise Kitchen::ActionFailed
232
- end
233
- end
234
-
235
- [:init_command, :install_command, :prepare_command, :run_command].each do |cmd|
236
-
237
- it "has a #{cmd} method" do
238
- provisioner.public_send(cmd).must_be_nil
239
- end
240
- end
241
-
242
- describe "sandbox" do
243
-
244
- after do
245
- begin
246
- provisioner.cleanup_sandbox
247
- rescue # rubocop:disable Lint/HandleExceptions
248
- end
249
- end
250
-
251
- it "raises ClientError if #sandbox_path is called before #create_sandbox" do
252
- proc { provisioner.sandbox_path }.must_raise Kitchen::ClientError
253
- end
254
-
255
- it "#create_sandbox creates a temporary directory" do
256
- provisioner.create_sandbox
257
-
258
- File.directory?(provisioner.sandbox_path).must_equal true
259
- format("%o", File.stat(provisioner.sandbox_path).mode)[1, 4].
260
- must_equal "0755"
261
- end
262
-
263
- it "#create_sandbox logs an info message" do
264
- provisioner.create_sandbox
265
-
266
- logged_output.string.must_match info_line("Preparing files for transfer")
267
- end
268
-
269
- it "#create_sandbox logs a debug message" do
270
- provisioner.create_sandbox
271
-
272
- logged_output.string.
273
- must_match debug_line_starting_with("Creating local sandbox in ")
274
- end
275
-
276
- it "#cleanup_sandbox deletes the sandbox directory" do
277
- provisioner.create_sandbox
278
- provisioner.cleanup_sandbox
279
-
280
- File.directory?(provisioner.sandbox_path).must_equal false
281
- end
282
-
283
- it "#cleanup_sandbox logs a debug message" do
284
- provisioner.create_sandbox
285
- provisioner.cleanup_sandbox
286
-
287
- logged_output.string.
288
- must_match debug_line_starting_with("Cleaning up local sandbox in ")
289
- end
290
-
291
- def info_line(msg)
292
- %r{^I, .* : #{Regexp.escape(msg)}$}
293
- end
294
-
295
- def debug_line_starting_with(msg)
296
- %r{^D, .* : #{Regexp.escape(msg)}}
297
- end
298
- end
299
-
300
- describe "#sudo" do
301
-
302
- describe "with :sudo set" do
303
-
304
- before { config[:sudo] = true }
305
-
306
- it "prepends sudo command" do
307
- provisioner.send(:sudo, "wakka").must_equal("sudo -E wakka")
308
- end
309
-
310
- it "customizes sudo when :sudo_command is set" do
311
- config[:sudo_command] = "blueto -Ohai"
312
-
313
- provisioner.send(:sudo, "wakka").must_equal("blueto -Ohai wakka")
314
- end
315
- end
316
-
317
- describe "with :sudo falsey" do
318
-
319
- before { config[:sudo] = false }
320
-
321
- it "does not include sudo command" do
322
- provisioner.send(:sudo, "wakka").must_equal("wakka")
323
- end
324
-
325
- it "does not include sudo command, even when :sudo_command is set" do
326
- config[:sudo_command] = "blueto -Ohai"
327
-
328
- provisioner.send(:sudo, "wakka").must_equal("wakka")
329
- end
330
- end
331
- end
332
-
333
- describe "#sudo_command" do
334
-
335
- describe "with :sudo set" do
336
-
337
- before { config[:sudo] = true }
338
-
339
- it "returns the default sudo_command" do
340
- provisioner.send(:sudo_command).must_equal("sudo -E")
341
- end
342
-
343
- it "returns the custom sudo_command" do
344
- config[:sudo_command] = "mysudo"
345
-
346
- provisioner.send(:sudo_command).must_equal("mysudo")
347
- end
348
- end
349
-
350
- describe "with :sudo falsey" do
351
-
352
- before { config[:sudo] = false }
353
-
354
- it "returns empty string for default sudo_command" do
355
- provisioner.send(:sudo_command).must_equal("")
356
- end
357
-
358
- it "returns empty string for custom sudo_command" do
359
- config[:sudo_command] = "mysudo"
360
-
361
- provisioner.send(:sudo_command).must_equal("")
362
- end
363
- end
364
- end
365
-
366
- describe "#prefix_command" do
367
-
368
- describe "with :command_prefix set" do
369
-
370
- before { config[:command_prefix] = "my_prefix" }
371
-
372
- it "prepends the command with the prefix" do
373
- provisioner.send(:prefix_command, "my_command").must_equal("my_prefix my_command")
374
- end
375
- end
376
-
377
- describe "with :command_prefix unset" do
378
-
379
- before { config[:command_prefix] = nil }
380
-
381
- it "returns an unaltered command" do
382
- provisioner.send(:prefix_command, "my_command").must_equal("my_command")
383
- end
384
- end
385
- end
386
- 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_relative "../../spec_helper"
20
+ require "logger"
21
+ require "stringio"
22
+
23
+ require "kitchen"
24
+
25
+ module Kitchen
26
+
27
+ module Provisioner
28
+
29
+ class TestingDummy < Kitchen::Provisioner::Base
30
+
31
+ attr_reader :called_create_sandbox, :called_cleanup_sandbox
32
+
33
+ def install_command
34
+ "install"
35
+ end
36
+
37
+ def init_command
38
+ "init"
39
+ end
40
+
41
+ def prepare_command
42
+ "prepare"
43
+ end
44
+
45
+ def run_command
46
+ "run"
47
+ end
48
+
49
+ def create_sandbox
50
+ @called_create_sandbox = true
51
+ end
52
+
53
+ def cleanup_sandbox
54
+ @called_cleanup_sandbox = true
55
+ end
56
+
57
+ def sandbox_path
58
+ "/tmp/sandbox"
59
+ end
60
+ end
61
+ end
62
+ end
63
+
64
+ describe Kitchen::Provisioner::Base do
65
+
66
+ let(:logged_output) { StringIO.new }
67
+ let(:logger) { Logger.new(logged_output) }
68
+ let(:platform) { stub(:os_type => nil, :shell_type => nil) }
69
+ let(:config) { Hash.new }
70
+
71
+ let(:transport) do
72
+ t = mock("transport")
73
+ t.responds_like_instance_of(Kitchen::Transport::Base)
74
+ t
75
+ end
76
+
77
+ let(:instance) do
78
+ stub(
79
+ :name => "coolbeans",
80
+ :to_str => "instance",
81
+ :logger => logger,
82
+ :platform => platform,
83
+ :transport => transport
84
+ )
85
+ end
86
+
87
+ let(:provisioner) do
88
+ Kitchen::Provisioner::Base.new(config).finalize_config!(instance)
89
+ end
90
+
91
+ describe "configuration" do
92
+
93
+ describe "for unix operating systems" do
94
+
95
+ before { platform.stubs(:os_type).returns("unix") }
96
+
97
+ it ":root_path defaults to /tmp/kitchen" do
98
+ provisioner[:root_path].must_equal "/tmp/kitchen"
99
+ end
100
+
101
+ it ":sudo defaults to true" do
102
+ provisioner[:sudo].must_equal true
103
+ end
104
+
105
+ it ":sudo_command defaults to sudo -E" do
106
+ provisioner[:sudo_command].must_equal "sudo -E"
107
+ end
108
+ end
109
+
110
+ describe "for windows operating systems" do
111
+
112
+ before { platform.stubs(:os_type).returns("windows") }
113
+
114
+ it ":root_path defaults to $env:TEMP\\kitchen" do
115
+ provisioner[:root_path].must_equal "$env:TEMP\\kitchen"
116
+ end
117
+
118
+ it ":sudo defaults to nil" do
119
+ provisioner[:sudo].must_equal nil
120
+ end
121
+
122
+ it ":sudo_command defaults to nil" do
123
+ provisioner[:sudo_command].must_equal nil
124
+ end
125
+ end
126
+
127
+ it ":http_proxy defaults to nil" do
128
+ provisioner[:http_proxy].must_equal nil
129
+ end
130
+
131
+ it ":http_proxys defaults to nil" do
132
+ provisioner[:https_proxy].must_equal nil
133
+ end
134
+
135
+ it ":ftp_proxy defaults to nil" do
136
+ provisioner[:ftp_proxy].must_equal nil
137
+ end
138
+ end
139
+
140
+ describe "#call" do
141
+
142
+ let(:state) { Hash.new }
143
+ let(:cmd) { provisioner.call(state) }
144
+
145
+ let(:connection) do
146
+ c = mock("transport_connection")
147
+ c.responds_like_instance_of(Kitchen::Transport::Base::Connection)
148
+ c
149
+ end
150
+
151
+ let(:provisioner) do
152
+ Kitchen::Provisioner::TestingDummy.new(config).finalize_config!(instance)
153
+ end
154
+
155
+ before do
156
+ FakeFS.activate!
157
+ FileUtils.mkdir_p(File.join(provisioner.sandbox_path, "stuff"))
158
+ transport.stubs(:connection).yields(connection)
159
+ connection.stubs(:execute)
160
+ connection.stubs(:upload)
161
+ end
162
+
163
+ after do
164
+ FakeFS.deactivate!
165
+ FakeFS::FileSystem.clear
166
+ end
167
+
168
+ it "creates the sandbox" do
169
+ provisioner.expects(:create_sandbox)
170
+
171
+ cmd
172
+ end
173
+
174
+ it "ensures that the sandbox is cleanup up" do
175
+ transport.stubs(:connection).raises
176
+ provisioner.expects(:cleanup_sandbox)
177
+
178
+ begin
179
+ cmd
180
+ rescue # rubocop:disable Lint/HandleExceptions
181
+ end
182
+ end
183
+
184
+ it "yields a connection given the state" do
185
+ state[:a] = "b"
186
+ transport.expects(:connection).with(state).yields(connection)
187
+
188
+ cmd
189
+ end
190
+
191
+ it "invokes the provisioner commands over the transport" do
192
+ order = sequence("order")
193
+ connection.expects(:execute).with("install").in_sequence(order)
194
+ connection.expects(:execute).with("init").in_sequence(order)
195
+ connection.expects(:execute).with("prepare").in_sequence(order)
196
+ connection.expects(:execute).with("run").in_sequence(order)
197
+
198
+ cmd
199
+ end
200
+
201
+ it "logs to info" do
202
+ cmd
203
+
204
+ logged_output.string.
205
+ must_match(/INFO -- : Transferring files to instance$/)
206
+ end
207
+
208
+ it "uploads sandbox files" do
209
+ connection.expects(:upload).with(["/tmp/sandbox/stuff"], "/tmp/kitchen")
210
+
211
+ cmd
212
+ end
213
+
214
+ it "logs to debug" do
215
+ cmd
216
+
217
+ logged_output.string.must_match(/DEBUG -- : Transfer complete$/)
218
+ end
219
+
220
+ it "raises an ActionFailed on transfer when TransportFailed is raised" do
221
+ connection.stubs(:upload).
222
+ raises(Kitchen::Transport::TransportFailed.new("dang"))
223
+
224
+ proc { cmd }.must_raise Kitchen::ActionFailed
225
+ end
226
+
227
+ it "raises an ActionFailed on execute when TransportFailed is raised" do
228
+ connection.stubs(:execute).
229
+ raises(Kitchen::Transport::TransportFailed.new("dang"))
230
+
231
+ proc { cmd }.must_raise Kitchen::ActionFailed
232
+ end
233
+ end
234
+
235
+ [:init_command, :install_command, :prepare_command, :run_command].each do |cmd|
236
+
237
+ it "has a #{cmd} method" do
238
+ provisioner.public_send(cmd).must_be_nil
239
+ end
240
+ end
241
+
242
+ describe "sandbox" do
243
+
244
+ after do
245
+ begin
246
+ provisioner.cleanup_sandbox
247
+ rescue # rubocop:disable Lint/HandleExceptions
248
+ end
249
+ end
250
+
251
+ it "raises ClientError if #sandbox_path is called before #create_sandbox" do
252
+ proc { provisioner.sandbox_path }.must_raise Kitchen::ClientError
253
+ end
254
+
255
+ it "#create_sandbox creates a temporary directory" do
256
+ provisioner.create_sandbox
257
+
258
+ File.directory?(provisioner.sandbox_path).must_equal true
259
+ format("%o", File.stat(provisioner.sandbox_path).mode)[1, 4].
260
+ must_equal "0755"
261
+ end
262
+
263
+ it "#create_sandbox logs an info message" do
264
+ provisioner.create_sandbox
265
+
266
+ logged_output.string.must_match info_line("Preparing files for transfer")
267
+ end
268
+
269
+ it "#create_sandbox logs a debug message" do
270
+ provisioner.create_sandbox
271
+
272
+ logged_output.string.
273
+ must_match debug_line_starting_with("Creating local sandbox in ")
274
+ end
275
+
276
+ it "#cleanup_sandbox deletes the sandbox directory" do
277
+ provisioner.create_sandbox
278
+ provisioner.cleanup_sandbox
279
+
280
+ File.directory?(provisioner.sandbox_path).must_equal false
281
+ end
282
+
283
+ it "#cleanup_sandbox logs a debug message" do
284
+ provisioner.create_sandbox
285
+ provisioner.cleanup_sandbox
286
+
287
+ logged_output.string.
288
+ must_match debug_line_starting_with("Cleaning up local sandbox in ")
289
+ end
290
+
291
+ def info_line(msg)
292
+ %r{^I, .* : #{Regexp.escape(msg)}$}
293
+ end
294
+
295
+ def debug_line_starting_with(msg)
296
+ %r{^D, .* : #{Regexp.escape(msg)}}
297
+ end
298
+ end
299
+
300
+ describe "#sudo" do
301
+
302
+ describe "with :sudo set" do
303
+
304
+ before { config[:sudo] = true }
305
+
306
+ it "prepends sudo command" do
307
+ provisioner.send(:sudo, "wakka").must_equal("sudo -E wakka")
308
+ end
309
+
310
+ it "customizes sudo when :sudo_command is set" do
311
+ config[:sudo_command] = "blueto -Ohai"
312
+
313
+ provisioner.send(:sudo, "wakka").must_equal("blueto -Ohai wakka")
314
+ end
315
+ end
316
+
317
+ describe "with :sudo falsey" do
318
+
319
+ before { config[:sudo] = false }
320
+
321
+ it "does not include sudo command" do
322
+ provisioner.send(:sudo, "wakka").must_equal("wakka")
323
+ end
324
+
325
+ it "does not include sudo command, even when :sudo_command is set" do
326
+ config[:sudo_command] = "blueto -Ohai"
327
+
328
+ provisioner.send(:sudo, "wakka").must_equal("wakka")
329
+ end
330
+ end
331
+ end
332
+
333
+ describe "#sudo_command" do
334
+
335
+ describe "with :sudo set" do
336
+
337
+ before { config[:sudo] = true }
338
+
339
+ it "returns the default sudo_command" do
340
+ provisioner.send(:sudo_command).must_equal("sudo -E")
341
+ end
342
+
343
+ it "returns the custom sudo_command" do
344
+ config[:sudo_command] = "mysudo"
345
+
346
+ provisioner.send(:sudo_command).must_equal("mysudo")
347
+ end
348
+ end
349
+
350
+ describe "with :sudo falsey" do
351
+
352
+ before { config[:sudo] = false }
353
+
354
+ it "returns empty string for default sudo_command" do
355
+ provisioner.send(:sudo_command).must_equal("")
356
+ end
357
+
358
+ it "returns empty string for custom sudo_command" do
359
+ config[:sudo_command] = "mysudo"
360
+
361
+ provisioner.send(:sudo_command).must_equal("")
362
+ end
363
+ end
364
+ end
365
+
366
+ describe "#prefix_command" do
367
+
368
+ describe "with :command_prefix set" do
369
+
370
+ before { config[:command_prefix] = "my_prefix" }
371
+
372
+ it "prepends the command with the prefix" do
373
+ provisioner.send(:prefix_command, "my_command").must_equal("my_prefix my_command")
374
+ end
375
+ end
376
+
377
+ describe "with :command_prefix unset" do
378
+
379
+ before { config[:command_prefix] = nil }
380
+
381
+ it "returns an unaltered command" do
382
+ provisioner.send(:prefix_command, "my_command").must_equal("my_command")
383
+ end
384
+ end
385
+ end
386
+ end