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,99 +1,99 @@
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_relative "../../spec_helper"
20
-
21
- require "logger"
22
- require "stringio"
23
-
24
- require "kitchen/verifier/dummy"
25
-
26
- describe Kitchen::Verifier::Dummy do
27
-
28
- let(:logged_output) { StringIO.new }
29
- let(:logger) { Logger.new(logged_output) }
30
- let(:platform) { stub(:os_type => nil, :shell_type => nil) }
31
- let(:suite) { stub(:name => "fries") }
32
- let(:state) { Hash.new }
33
-
34
- let(:config) do
35
- { :test_base_path => "/basist", :kitchen_root => "/rooty" }
36
- end
37
-
38
- let(:instance) do
39
- stub(
40
- :name => "coolbeans",
41
- :to_str => "instance",
42
- :logger => logger,
43
- :suite => suite,
44
- :platform => platform
45
- )
46
- end
47
-
48
- let(:verifier) do
49
- Kitchen::Verifier::Dummy.new(config).finalize_config!(instance)
50
- end
51
-
52
- it "verifier api_version is 1" do
53
- verifier.diagnose_plugin[:api_version].must_equal 1
54
- end
55
-
56
- it "plugin_version is set to Kitchen::VERSION" do
57
- verifier.diagnose_plugin[:version].must_equal Kitchen::VERSION
58
- end
59
-
60
- describe "configuration" do
61
-
62
- it "sets :sleep to 0 by default" do
63
- verifier[:sleep].must_equal 0
64
- end
65
-
66
- it "sets :random_failure to false by default" do
67
- verifier[:random_failure].must_equal false
68
- end
69
- end
70
-
71
- describe "#call" do
72
-
73
- it "calls sleep if :sleep value is greater than 0" do
74
- config[:sleep] = 12.5
75
- verifier.expects(:sleep).with(12.5).returns(true)
76
-
77
- verifier.call(state)
78
- end
79
-
80
- it "raises ActionFailed if :fail is set" do
81
- config[:fail] = true
82
-
83
- proc { verifier.call(state) }.must_raise Kitchen::ActionFailed
84
- end
85
-
86
- it "randomly raises ActionFailed if :random_failure is set" do
87
- config[:random_failure] = true
88
- verifier.stubs(:randomly_fail?).returns(true)
89
-
90
- proc { verifier.call(state) }.must_raise Kitchen::ActionFailed
91
- end
92
-
93
- it "logs a converge event to INFO" do
94
- verifier.call(state)
95
-
96
- logged_output.string.must_match(/^.+ INFO .+ \[Dummy\] Verify on .+$/)
97
- end
98
- end
99
- 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_relative "../../spec_helper"
20
+
21
+ require "logger"
22
+ require "stringio"
23
+
24
+ require "kitchen/verifier/dummy"
25
+
26
+ describe Kitchen::Verifier::Dummy do
27
+
28
+ let(:logged_output) { StringIO.new }
29
+ let(:logger) { Logger.new(logged_output) }
30
+ let(:platform) { stub(:os_type => nil, :shell_type => nil) }
31
+ let(:suite) { stub(:name => "fries") }
32
+ let(:state) { Hash.new }
33
+
34
+ let(:config) do
35
+ { :test_base_path => "/basist", :kitchen_root => "/rooty" }
36
+ end
37
+
38
+ let(:instance) do
39
+ stub(
40
+ :name => "coolbeans",
41
+ :to_str => "instance",
42
+ :logger => logger,
43
+ :suite => suite,
44
+ :platform => platform
45
+ )
46
+ end
47
+
48
+ let(:verifier) do
49
+ Kitchen::Verifier::Dummy.new(config).finalize_config!(instance)
50
+ end
51
+
52
+ it "verifier api_version is 1" do
53
+ verifier.diagnose_plugin[:api_version].must_equal 1
54
+ end
55
+
56
+ it "plugin_version is set to Kitchen::VERSION" do
57
+ verifier.diagnose_plugin[:version].must_equal Kitchen::VERSION
58
+ end
59
+
60
+ describe "configuration" do
61
+
62
+ it "sets :sleep to 0 by default" do
63
+ verifier[:sleep].must_equal 0
64
+ end
65
+
66
+ it "sets :random_failure to false by default" do
67
+ verifier[:random_failure].must_equal false
68
+ end
69
+ end
70
+
71
+ describe "#call" do
72
+
73
+ it "calls sleep if :sleep value is greater than 0" do
74
+ config[:sleep] = 12.5
75
+ verifier.expects(:sleep).with(12.5).returns(true)
76
+
77
+ verifier.call(state)
78
+ end
79
+
80
+ it "raises ActionFailed if :fail is set" do
81
+ config[:fail] = true
82
+
83
+ proc { verifier.call(state) }.must_raise Kitchen::ActionFailed
84
+ end
85
+
86
+ it "randomly raises ActionFailed if :random_failure is set" do
87
+ config[:random_failure] = true
88
+ verifier.stubs(:randomly_fail?).returns(true)
89
+
90
+ proc { verifier.call(state) }.must_raise Kitchen::ActionFailed
91
+ end
92
+
93
+ it "logs a converge event to INFO" do
94
+ verifier.call(state)
95
+
96
+ logged_output.string.must_match(/^.+ INFO .+ \[Dummy\] Verify on .+$/)
97
+ end
98
+ end
99
+ end
@@ -1,158 +1,160 @@
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_relative "../../spec_helper"
20
-
21
- require "logger"
22
- require "stringio"
23
-
24
- require "kitchen/verifier/shell"
25
- require "kitchen/transport/ssh"
26
-
27
- describe Kitchen::Verifier::Shell do
28
-
29
- let(:logged_output) { StringIO.new }
30
- let(:logger) { Logger.new(logged_output) }
31
- let(:platform) { stub(:os_type => nil, :shell_type => nil, :name => "coolbeans") }
32
- let(:suite) { stub(:name => "fries") }
33
- let(:state) { Hash.new }
34
-
35
- let(:config) do
36
- { :test_base_path => "/basist", :kitchen_root => "/rooty" }
37
- end
38
-
39
- let(:instance) do
40
- stub(
41
- :name => [platform.name, suite.name].join("-"),
42
- :to_str => "instance",
43
- :logger => logger,
44
- :suite => suite,
45
- :platform => platform
46
- )
47
- end
48
-
49
- let(:verifier) do
50
- Kitchen::Verifier::Shell.new(config).finalize_config!(instance)
51
- end
52
-
53
- it "verifier api_version is 1" do
54
- verifier.diagnose_plugin[:api_version].must_equal 1
55
- end
56
-
57
- it "plugin_version is set to Kitchen::VERSION" do
58
- verifier.diagnose_plugin[:version].must_equal Kitchen::VERSION
59
- end
60
-
61
- describe "configuration" do
62
-
63
- it "sets :sleep to 0 by default" do
64
- verifier[:sleep].must_equal 0
65
- end
66
-
67
- it "sets :command to 'true' by default" do
68
- verifier[:command].must_equal "true"
69
- end
70
-
71
- it "sets :live_stream to stdout by default" do
72
- verifier[:live_stream].must_equal $stdout
73
- end
74
- end
75
-
76
- describe "#call" do
77
-
78
- describe "#shell_out" do
79
- it "calls sleep if :sleep value is greater than 0" do
80
- config[:sleep] = 3
81
- verifier.expects(:sleep).with(1).returns(true).at_least(3)
82
-
83
- verifier.call(state)
84
- end
85
-
86
- it "states are set to environment" do
87
- state[:hostname] = "testhost"
88
- state[:server_id] = "i-xxxxxx"
89
- verifier.call(state)
90
- config[:shellout_opts][:environment]["KITCHEN_HOSTNAME"].must_equal "testhost"
91
- config[:shellout_opts][:environment]["KITCHEN_SERVER_ID"].must_equal "i-xxxxxx"
92
- config[:shellout_opts][:environment]["KITCHEN_INSTANCE"].must_equal "coolbeans-fries"
93
- config[:shellout_opts][:environment]["KITCHEN_PLATFORM"].must_equal "coolbeans"
94
- config[:shellout_opts][:environment]["KITCHEN_SUITE"].must_equal "fries"
95
- end
96
-
97
- it "raises ActionFailed if set false to :command" do
98
- config[:command] = "false"
99
-
100
- proc { verifier.call(state) }.must_raise Kitchen::ActionFailed
101
- end
102
-
103
- it "logs a converge event to INFO" do
104
- verifier.call(state)
105
-
106
- logged_output.string.must_match(/^.+ INFO .+ \[Shell\] Verify on .+$/)
107
- end
108
- end
109
-
110
- describe "remote_exec" do
111
- let(:transport) do
112
- t = mock("transport")
113
- t.responds_like_instance_of(Kitchen::Transport::Ssh)
114
- t
115
- end
116
-
117
- let(:connection) do
118
- c = mock("transport_connection")
119
- c.responds_like_instance_of(Kitchen::Transport::Ssh::Connection)
120
- c
121
- end
122
-
123
- let(:instance) do
124
- stub(
125
- :name => "coolbeans",
126
- :to_str => "instance",
127
- :logger => logger,
128
- :platform => platform,
129
- :suite => suite,
130
- :transport => transport
131
- )
132
- end
133
-
134
- before do
135
- transport.stubs(:connection).yields(connection)
136
- connection.stubs(:execute)
137
- end
138
-
139
- it "execute command onto instance." do
140
- config[:remote_exec] = true
141
-
142
- transport.expects(:connection).with(state).yields(connection)
143
- verifier.call(state)
144
- end
145
- end
146
- end
147
-
148
- describe "#run_command" do
149
- it "execute localy and returns nil" do
150
- verifier.run_command
151
- end
152
-
153
- it "returns string when remote_exec" do
154
- config[:remote_exec] = true
155
- verifier.run_command.must_equal "true"
156
- end
157
- end
158
- 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_relative "../../spec_helper"
20
+
21
+ require "logger"
22
+ require "stringio"
23
+
24
+ require "kitchen/verifier/shell"
25
+ require "kitchen/transport/ssh"
26
+
27
+ describe Kitchen::Verifier::Shell do
28
+
29
+ let(:logged_output) { StringIO.new }
30
+ let(:logger) { Logger.new(logged_output) }
31
+ let(:platform) { stub(:os_type => nil, :shell_type => nil, :name => "coolbeans") }
32
+ let(:suite) { stub(:name => "fries") }
33
+ let(:state) { Hash.new }
34
+
35
+ let(:config) do
36
+ { :test_base_path => "/basist", :kitchen_root => "/rooty" }
37
+ end
38
+
39
+ let(:instance) do
40
+ stub(
41
+ :name => [platform.name, suite.name].join("-"),
42
+ :to_str => "instance",
43
+ :logger => logger,
44
+ :suite => suite,
45
+ :platform => platform
46
+ )
47
+ end
48
+
49
+ let(:verifier) do
50
+ Kitchen::Verifier::Shell.new(config).finalize_config!(instance)
51
+ end
52
+
53
+ it "verifier api_version is 1" do
54
+ verifier.diagnose_plugin[:api_version].must_equal 1
55
+ end
56
+
57
+ it "plugin_version is set to Kitchen::VERSION" do
58
+ verifier.diagnose_plugin[:version].must_equal Kitchen::VERSION
59
+ end
60
+
61
+ describe "configuration" do
62
+
63
+ it "sets :sleep to 0 by default" do
64
+ verifier[:sleep].must_equal 0
65
+ end
66
+
67
+ it "sets :command to 'true' by default" do
68
+ verifier[:command].must_equal "true"
69
+ end
70
+
71
+ it "sets :live_stream to stdout by default" do
72
+ verifier[:live_stream].must_equal $stdout
73
+ end
74
+ end
75
+
76
+ describe "#call" do
77
+
78
+ describe "#shell_out" do
79
+ it "calls sleep if :sleep value is greater than 0" do
80
+ config[:sleep] = 3
81
+ verifier.expects(:sleep).with(1).returns(true).at_least(3)
82
+
83
+ verifier.call(state)
84
+ end
85
+
86
+ it "states are set to environment" do
87
+ state[:hostname] = "testhost"
88
+ state[:server_id] = "i-xxxxxx"
89
+ state[:port] = 22
90
+ verifier.call(state)
91
+ config[:shellout_opts][:environment]["KITCHEN_HOSTNAME"].must_equal "testhost"
92
+ config[:shellout_opts][:environment]["KITCHEN_SERVER_ID"].must_equal "i-xxxxxx"
93
+ config[:shellout_opts][:environment]["KITCHEN_PORT"].must_equal "22"
94
+ config[:shellout_opts][:environment]["KITCHEN_INSTANCE"].must_equal "coolbeans-fries"
95
+ config[:shellout_opts][:environment]["KITCHEN_PLATFORM"].must_equal "coolbeans"
96
+ config[:shellout_opts][:environment]["KITCHEN_SUITE"].must_equal "fries"
97
+ end
98
+
99
+ it "raises ActionFailed if set false to :command" do
100
+ config[:command] = "false"
101
+
102
+ proc { verifier.call(state) }.must_raise Kitchen::ActionFailed
103
+ end
104
+
105
+ it "logs a converge event to INFO" do
106
+ verifier.call(state)
107
+
108
+ logged_output.string.must_match(/^.+ INFO .+ \[Shell\] Verify on .+$/)
109
+ end
110
+ end
111
+
112
+ describe "remote_exec" do
113
+ let(:transport) do
114
+ t = mock("transport")
115
+ t.responds_like_instance_of(Kitchen::Transport::Ssh)
116
+ t
117
+ end
118
+
119
+ let(:connection) do
120
+ c = mock("transport_connection")
121
+ c.responds_like_instance_of(Kitchen::Transport::Ssh::Connection)
122
+ c
123
+ end
124
+
125
+ let(:instance) do
126
+ stub(
127
+ :name => "coolbeans",
128
+ :to_str => "instance",
129
+ :logger => logger,
130
+ :platform => platform,
131
+ :suite => suite,
132
+ :transport => transport
133
+ )
134
+ end
135
+
136
+ before do
137
+ transport.stubs(:connection).yields(connection)
138
+ connection.stubs(:execute)
139
+ end
140
+
141
+ it "execute command onto instance." do
142
+ config[:remote_exec] = true
143
+
144
+ transport.expects(:connection).with(state).yields(connection)
145
+ verifier.call(state)
146
+ end
147
+ end
148
+ end
149
+
150
+ describe "#run_command" do
151
+ it "execute localy and returns nil" do
152
+ verifier.run_command
153
+ end
154
+
155
+ it "returns string when remote_exec" do
156
+ config[:remote_exec] = true
157
+ verifier.run_command.must_equal "true"
158
+ end
159
+ end
160
+ end