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,199 +1,199 @@
1
- # -*- encoding: utf-8 -*-
2
- #
3
- # Author:: Fletcher Nichol (<fnichol@nichol.ca>)
4
- #
5
- # Copyright (C) 2012, 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/driver/dummy"
24
-
25
- describe Kitchen::Driver::Dummy do
26
-
27
- let(:logged_output) { StringIO.new }
28
- let(:logger) { Logger.new(logged_output) }
29
- let(:config) { Hash.new }
30
- let(:state) { Hash.new }
31
-
32
- let(:instance) do
33
- stub(:name => "coolbeans", :logger => logger, :to_str => "instance")
34
- end
35
-
36
- let(:driver) do
37
- Kitchen::Driver::Dummy.new(config).finalize_config!(instance)
38
- end
39
-
40
- it "driver api_version is 2" do
41
- driver.diagnose_plugin[:api_version].must_equal 2
42
- end
43
-
44
- it "plugin_version is set to Kitchen::VERSION" do
45
- driver.diagnose_plugin[:version].must_equal Kitchen::VERSION
46
- end
47
-
48
- describe "default_config" do
49
-
50
- it "sets :sleep to 0 by default" do
51
- driver[:sleep].must_equal 0
52
- end
53
-
54
- it "sets :random_failure to false by default" do
55
- driver[:random_failure].must_equal false
56
- end
57
- end
58
-
59
- describe "#create" do
60
-
61
- it "sets :my_id to a unique value as an example" do
62
- driver.create(state)
63
-
64
- state[:my_id].must_match(/^coolbeans-/)
65
- end
66
-
67
- it "calls sleep if :sleep value is greater than 0" do
68
- config[:sleep] = 12.5
69
- driver.expects(:sleep).with(12.5).returns(true)
70
-
71
- driver.create(state)
72
- end
73
-
74
- it "raises ActionFailed if :fail_create is set" do
75
- config[:fail_create] = true
76
-
77
- proc { driver.create(state) }.must_raise Kitchen::ActionFailed
78
- end
79
-
80
- it "randomly raises ActionFailed if :random_failure is set" do
81
- config[:random_failure] = true
82
- driver.stubs(:randomly_fail?).returns(true)
83
-
84
- proc { driver.create(state) }.must_raise Kitchen::ActionFailed
85
- end
86
-
87
- it "will only raise ActionFailed if :random_failure is set" do
88
- config[:random_failure] = true
89
-
90
- begin
91
- driver.create(state)
92
- rescue Kitchen::ActionFailed
93
- # If exception is anything other than Kitchen::ActionFailed, this spec
94
- # will fail
95
- true
96
- end
97
- end
98
-
99
- it "logs a create event to INFO" do
100
- driver.create(state)
101
-
102
- logged_output.string.must_match(/^.+ INFO .+ \[Dummy\] Create on .+$/)
103
- end
104
- end
105
-
106
- describe "#setup" do
107
-
108
- it "calls sleep if :sleep value is greater than 0" do
109
- config[:sleep] = 12.5
110
- driver.expects(:sleep).with(12.5).returns(true)
111
-
112
- driver.setup(state)
113
- end
114
-
115
- it "raises ActionFailed if :fail_setup is set" do
116
- config[:fail_setup] = true
117
-
118
- proc { driver.setup(state) }.must_raise Kitchen::ActionFailed
119
- end
120
-
121
- it "randomly raises ActionFailed if :random_failure is set" do
122
- config[:random_failure] = true
123
- driver.stubs(:randomly_fail?).returns(true)
124
-
125
- proc { driver.setup(state) }.must_raise Kitchen::ActionFailed
126
- end
127
-
128
- it "logs a setup event to INFO" do
129
- driver.setup(state)
130
-
131
- logged_output.string.must_match(/^.+ INFO .+ \[Dummy\] Setup on .+$/)
132
- end
133
- end
134
-
135
- describe "#verify" do
136
-
137
- it "calls sleep if :sleep value is greater than 0" do
138
- config[:sleep] = 12.5
139
- driver.expects(:sleep).with(12.5).returns(true)
140
-
141
- driver.verify(state)
142
- end
143
-
144
- it "raises ActionFailed if :fail_verify is set" do
145
- config[:fail_verify] = true
146
-
147
- proc { driver.verify(state) }.must_raise Kitchen::ActionFailed
148
- end
149
-
150
- it "randomly raises ActionFailed if :random_failure is set" do
151
- config[:random_failure] = true
152
- driver.stubs(:randomly_fail?).returns(true)
153
-
154
- proc { driver.verify(state) }.must_raise Kitchen::ActionFailed
155
- end
156
-
157
- it "logs a verify event to INFO" do
158
- driver.verify(state)
159
-
160
- logged_output.string.must_match(/^.+ INFO .+ \[Dummy\] Verify on .+$/)
161
- end
162
- end
163
-
164
- describe "#destroy" do
165
-
166
- it "removes :my_id from the state hash" do
167
- state[:my_id] = "90210"
168
- driver.destroy(state)
169
-
170
- state[:my_id].must_be_nil
171
- end
172
-
173
- it "calls sleep if :sleep value is greater than 0" do
174
- config[:sleep] = 12.5
175
- driver.expects(:sleep).with(12.5).returns(true)
176
-
177
- driver.verify(state)
178
- end
179
-
180
- it "raises ActionFailed if :fail_destroy is set" do
181
- config[:fail_destroy] = true
182
-
183
- proc { driver.destroy(state) }.must_raise Kitchen::ActionFailed
184
- end
185
-
186
- it "randomly raises ActionFailed if :random_failure is set" do
187
- config[:random_failure] = true
188
- driver.stubs(:randomly_fail?).returns(true)
189
-
190
- proc { driver.destroy(state) }.must_raise Kitchen::ActionFailed
191
- end
192
-
193
- it "logs a destroy event to INFO" do
194
- driver.destroy(state)
195
-
196
- logged_output.string.must_match(/^.+ INFO .+ \[Dummy\] Destroy on .+$/)
197
- end
198
- end
199
- end
1
+ # -*- encoding: utf-8 -*-
2
+ #
3
+ # Author:: Fletcher Nichol (<fnichol@nichol.ca>)
4
+ #
5
+ # Copyright (C) 2012, 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/driver/dummy"
24
+
25
+ describe Kitchen::Driver::Dummy do
26
+
27
+ let(:logged_output) { StringIO.new }
28
+ let(:logger) { Logger.new(logged_output) }
29
+ let(:config) { Hash.new }
30
+ let(:state) { Hash.new }
31
+
32
+ let(:instance) do
33
+ stub(:name => "coolbeans", :logger => logger, :to_str => "instance")
34
+ end
35
+
36
+ let(:driver) do
37
+ Kitchen::Driver::Dummy.new(config).finalize_config!(instance)
38
+ end
39
+
40
+ it "driver api_version is 2" do
41
+ driver.diagnose_plugin[:api_version].must_equal 2
42
+ end
43
+
44
+ it "plugin_version is set to Kitchen::VERSION" do
45
+ driver.diagnose_plugin[:version].must_equal Kitchen::VERSION
46
+ end
47
+
48
+ describe "default_config" do
49
+
50
+ it "sets :sleep to 0 by default" do
51
+ driver[:sleep].must_equal 0
52
+ end
53
+
54
+ it "sets :random_failure to false by default" do
55
+ driver[:random_failure].must_equal false
56
+ end
57
+ end
58
+
59
+ describe "#create" do
60
+
61
+ it "sets :my_id to a unique value as an example" do
62
+ driver.create(state)
63
+
64
+ state[:my_id].must_match(/^coolbeans-/)
65
+ end
66
+
67
+ it "calls sleep if :sleep value is greater than 0" do
68
+ config[:sleep] = 12.5
69
+ driver.expects(:sleep).with(12.5).returns(true)
70
+
71
+ driver.create(state)
72
+ end
73
+
74
+ it "raises ActionFailed if :fail_create is set" do
75
+ config[:fail_create] = true
76
+
77
+ proc { driver.create(state) }.must_raise Kitchen::ActionFailed
78
+ end
79
+
80
+ it "randomly raises ActionFailed if :random_failure is set" do
81
+ config[:random_failure] = true
82
+ driver.stubs(:randomly_fail?).returns(true)
83
+
84
+ proc { driver.create(state) }.must_raise Kitchen::ActionFailed
85
+ end
86
+
87
+ it "will only raise ActionFailed if :random_failure is set" do
88
+ config[:random_failure] = true
89
+
90
+ begin
91
+ driver.create(state)
92
+ rescue Kitchen::ActionFailed
93
+ # If exception is anything other than Kitchen::ActionFailed, this spec
94
+ # will fail
95
+ true
96
+ end
97
+ end
98
+
99
+ it "logs a create event to INFO" do
100
+ driver.create(state)
101
+
102
+ logged_output.string.must_match(/^.+ INFO .+ \[Dummy\] Create on .+$/)
103
+ end
104
+ end
105
+
106
+ describe "#setup" do
107
+
108
+ it "calls sleep if :sleep value is greater than 0" do
109
+ config[:sleep] = 12.5
110
+ driver.expects(:sleep).with(12.5).returns(true)
111
+
112
+ driver.setup(state)
113
+ end
114
+
115
+ it "raises ActionFailed if :fail_setup is set" do
116
+ config[:fail_setup] = true
117
+
118
+ proc { driver.setup(state) }.must_raise Kitchen::ActionFailed
119
+ end
120
+
121
+ it "randomly raises ActionFailed if :random_failure is set" do
122
+ config[:random_failure] = true
123
+ driver.stubs(:randomly_fail?).returns(true)
124
+
125
+ proc { driver.setup(state) }.must_raise Kitchen::ActionFailed
126
+ end
127
+
128
+ it "logs a setup event to INFO" do
129
+ driver.setup(state)
130
+
131
+ logged_output.string.must_match(/^.+ INFO .+ \[Dummy\] Setup on .+$/)
132
+ end
133
+ end
134
+
135
+ describe "#verify" do
136
+
137
+ it "calls sleep if :sleep value is greater than 0" do
138
+ config[:sleep] = 12.5
139
+ driver.expects(:sleep).with(12.5).returns(true)
140
+
141
+ driver.verify(state)
142
+ end
143
+
144
+ it "raises ActionFailed if :fail_verify is set" do
145
+ config[:fail_verify] = true
146
+
147
+ proc { driver.verify(state) }.must_raise Kitchen::ActionFailed
148
+ end
149
+
150
+ it "randomly raises ActionFailed if :random_failure is set" do
151
+ config[:random_failure] = true
152
+ driver.stubs(:randomly_fail?).returns(true)
153
+
154
+ proc { driver.verify(state) }.must_raise Kitchen::ActionFailed
155
+ end
156
+
157
+ it "logs a verify event to INFO" do
158
+ driver.verify(state)
159
+
160
+ logged_output.string.must_match(/^.+ INFO .+ \[Dummy\] Verify on .+$/)
161
+ end
162
+ end
163
+
164
+ describe "#destroy" do
165
+
166
+ it "removes :my_id from the state hash" do
167
+ state[:my_id] = "90210"
168
+ driver.destroy(state)
169
+
170
+ state[:my_id].must_be_nil
171
+ end
172
+
173
+ it "calls sleep if :sleep value is greater than 0" do
174
+ config[:sleep] = 12.5
175
+ driver.expects(:sleep).with(12.5).returns(true)
176
+
177
+ driver.verify(state)
178
+ end
179
+
180
+ it "raises ActionFailed if :fail_destroy is set" do
181
+ config[:fail_destroy] = true
182
+
183
+ proc { driver.destroy(state) }.must_raise Kitchen::ActionFailed
184
+ end
185
+
186
+ it "randomly raises ActionFailed if :random_failure is set" do
187
+ config[:random_failure] = true
188
+ driver.stubs(:randomly_fail?).returns(true)
189
+
190
+ proc { driver.destroy(state) }.must_raise Kitchen::ActionFailed
191
+ end
192
+
193
+ it "logs a destroy event to INFO" do
194
+ driver.destroy(state)
195
+
196
+ logged_output.string.must_match(/^.+ INFO .+ \[Dummy\] Destroy on .+$/)
197
+ end
198
+ end
199
+ end
@@ -1,138 +1,138 @@
1
- # -*- encoding: utf-8 -*-
2
- #
3
- # Author:: Fletcher Nichol (<fnichol@nichol.ca>)
4
- #
5
- # Copyright (C) 2014, 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
-
21
- require "kitchen/driver/proxy"
22
-
23
- describe Kitchen::Driver::Proxy do
24
-
25
- let(:logged_output) { StringIO.new }
26
- let(:logger) { Logger.new(logged_output) }
27
- let(:state) { Hash.new }
28
-
29
- let(:config) do
30
- { :host => "foobnoobs.com", :reset_command => "mulligan" }
31
- end
32
-
33
- let(:instance) do
34
- stub(:name => "coolbeans", :logger => logger, :to_str => "instance")
35
- end
36
-
37
- let(:driver) do
38
- Kitchen::Driver::Proxy.new(config).finalize_config!(instance)
39
- end
40
-
41
- it "plugin_version is set to Kitchen::VERSION" do
42
- driver.diagnose_plugin[:version].must_equal Kitchen::VERSION
43
- end
44
-
45
- describe "non-parallel action" do
46
-
47
- it "create must be serially executed" do
48
- Kitchen::Driver::Proxy.serial_actions.must_include :create
49
- end
50
-
51
- it "destroy must be serially executed" do
52
- Kitchen::Driver::Proxy.serial_actions.must_include :destroy
53
- end
54
- end
55
-
56
- describe "required_config" do
57
-
58
- [:host, :reset_command].each do |attr|
59
- it "requires :#{attr}" do
60
- config.delete(attr)
61
-
62
- begin
63
- driver
64
- flunk "UserError must be raised for missing :#{attr}"
65
- rescue Kitchen::UserError => e
66
- e.message.must_match regexify("config[:#{attr}] cannot be blank")
67
- end
68
- end
69
- end
70
-
71
- def regexify(str)
72
- Regexp.new(Regexp.escape(str))
73
- end
74
- end
75
-
76
- describe "#create" do
77
-
78
- it "sets :hostname in state config" do
79
- driver.stubs(:ssh)
80
- driver.create(state)
81
-
82
- state[:hostname].must_equal "foobnoobs.com"
83
- end
84
-
85
- it "calls the reset command over ssh" do
86
- driver.expects(:ssh).with do |ssh_args, cmd|
87
- ssh_args[0].must_equal "foobnoobs.com"
88
- cmd.must_equal "mulligan"
89
- end
90
-
91
- driver.create(state)
92
- end
93
-
94
- it "skips ssh call if :reset_command is falsey" do
95
- config[:reset_command] = false
96
- driver.expects(:ssh).never
97
-
98
- driver.create(state)
99
- end
100
- end
101
-
102
- describe "#destroy" do
103
-
104
- before do
105
- state[:hostname] = "beep"
106
- end
107
-
108
- it "deletes :hostname in state config" do
109
- driver.stubs(:ssh)
110
- driver.destroy(state)
111
-
112
- state[:hostname].must_equal nil
113
- end
114
-
115
- it "calls the reset command over ssh" do
116
- driver.expects(:ssh).with do |ssh_args, cmd|
117
- ssh_args[0].must_equal "beep"
118
- cmd.must_equal "mulligan"
119
- end
120
-
121
- driver.destroy(state)
122
- end
123
-
124
- it "skips ssh call if :hostname is not in state config" do
125
- state.delete(:hostname)
126
- driver.expects(:ssh).never
127
-
128
- driver.destroy(state)
129
- end
130
-
131
- it "skips ssh call if :reset_command is falsey" do
132
- config[:reset_command] = false
133
- driver.expects(:ssh).never
134
-
135
- driver.destroy(state)
136
- end
137
- end
138
- end
1
+ # -*- encoding: utf-8 -*-
2
+ #
3
+ # Author:: Fletcher Nichol (<fnichol@nichol.ca>)
4
+ #
5
+ # Copyright (C) 2014, 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
+
21
+ require "kitchen/driver/proxy"
22
+
23
+ describe Kitchen::Driver::Proxy do
24
+
25
+ let(:logged_output) { StringIO.new }
26
+ let(:logger) { Logger.new(logged_output) }
27
+ let(:state) { Hash.new }
28
+
29
+ let(:config) do
30
+ { :host => "foobnoobs.com", :reset_command => "mulligan" }
31
+ end
32
+
33
+ let(:instance) do
34
+ stub(:name => "coolbeans", :logger => logger, :to_str => "instance")
35
+ end
36
+
37
+ let(:driver) do
38
+ Kitchen::Driver::Proxy.new(config).finalize_config!(instance)
39
+ end
40
+
41
+ it "plugin_version is set to Kitchen::VERSION" do
42
+ driver.diagnose_plugin[:version].must_equal Kitchen::VERSION
43
+ end
44
+
45
+ describe "non-parallel action" do
46
+
47
+ it "create must be serially executed" do
48
+ Kitchen::Driver::Proxy.serial_actions.must_include :create
49
+ end
50
+
51
+ it "destroy must be serially executed" do
52
+ Kitchen::Driver::Proxy.serial_actions.must_include :destroy
53
+ end
54
+ end
55
+
56
+ describe "required_config" do
57
+
58
+ [:host, :reset_command].each do |attr|
59
+ it "requires :#{attr}" do
60
+ config.delete(attr)
61
+
62
+ begin
63
+ driver
64
+ flunk "UserError must be raised for missing :#{attr}"
65
+ rescue Kitchen::UserError => e
66
+ e.message.must_match regexify("config[:#{attr}] cannot be blank")
67
+ end
68
+ end
69
+ end
70
+
71
+ def regexify(str)
72
+ Regexp.new(Regexp.escape(str))
73
+ end
74
+ end
75
+
76
+ describe "#create" do
77
+
78
+ it "sets :hostname in state config" do
79
+ driver.stubs(:ssh)
80
+ driver.create(state)
81
+
82
+ state[:hostname].must_equal "foobnoobs.com"
83
+ end
84
+
85
+ it "calls the reset command over ssh" do
86
+ driver.expects(:ssh).with do |ssh_args, cmd|
87
+ ssh_args[0].must_equal "foobnoobs.com"
88
+ cmd.must_equal "mulligan"
89
+ end
90
+
91
+ driver.create(state)
92
+ end
93
+
94
+ it "skips ssh call if :reset_command is falsey" do
95
+ config[:reset_command] = false
96
+ driver.expects(:ssh).never
97
+
98
+ driver.create(state)
99
+ end
100
+ end
101
+
102
+ describe "#destroy" do
103
+
104
+ before do
105
+ state[:hostname] = "beep"
106
+ end
107
+
108
+ it "deletes :hostname in state config" do
109
+ driver.stubs(:ssh)
110
+ driver.destroy(state)
111
+
112
+ state[:hostname].must_equal nil
113
+ end
114
+
115
+ it "calls the reset command over ssh" do
116
+ driver.expects(:ssh).with do |ssh_args, cmd|
117
+ ssh_args[0].must_equal "beep"
118
+ cmd.must_equal "mulligan"
119
+ end
120
+
121
+ driver.destroy(state)
122
+ end
123
+
124
+ it "skips ssh call if :hostname is not in state config" do
125
+ state.delete(:hostname)
126
+ driver.expects(:ssh).never
127
+
128
+ driver.destroy(state)
129
+ end
130
+
131
+ it "skips ssh call if :reset_command is falsey" do
132
+ config[:reset_command] = false
133
+ driver.expects(:ssh).never
134
+
135
+ driver.destroy(state)
136
+ end
137
+ end
138
+ end