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,120 +1,120 @@
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
- if RUBY_VERSION <= "1.9.3"
20
- # ensure that Psych and not Syck is used for Ruby 1.9.2
21
- require "yaml"
22
- YAML::ENGINE.yamler = "psych"
23
- end
24
- require "safe_yaml/load"
25
-
26
- module Kitchen
27
-
28
- # Exception class for any exceptions raised when reading and parsing a state
29
- # file from disk
30
- class StateFileLoadError < StandardError; end
31
-
32
- # State persistence manager for instances between actions and invocations.
33
- #
34
- # @author Fletcher Nichol <fnichol@nichol.ca>
35
- class StateFile
36
-
37
- # Constructs an new instance taking the kitchen root and instance name.
38
- #
39
- # @param kitchen_root [String] path to the Kitchen project's root directory
40
- # @param name [String] name of the instance representing this state
41
- def initialize(kitchen_root, name)
42
- @file_name = File.expand_path(
43
- File.join(kitchen_root, ".kitchen", "#{name}.yml")
44
- )
45
- end
46
-
47
- # Reads and loads an instance's state into a Hash data structure which is
48
- # returned.
49
- #
50
- # @return [Hash] a hash representation of an instance's state
51
- # @raise [StateFileLoadError] if there is a problem loading the state file
52
- # from disk and loading it into a Hash
53
- def read
54
- if File.exist?(file_name) && !File.zero?(file_name)
55
- Util.symbolized_hash(deserialize_string(read_file))
56
- else
57
- Hash.new
58
- end
59
- end
60
-
61
- # Serializes the state hash and writes a state file to disk.
62
- #
63
- # @param state [Hash] the current state of the instance
64
- def write(state)
65
- dir = File.dirname(file_name)
66
- serialized_string = serialize_hash(Util.stringified_hash(state))
67
-
68
- FileUtils.mkdir_p(dir) if !File.directory?(dir)
69
- File.open(file_name, "wb") { |f| f.write(serialized_string) }
70
- end
71
-
72
- # Destroys a state file on disk if it exists.
73
- def destroy
74
- FileUtils.rm_f(file_name) if File.exist?(file_name)
75
- end
76
-
77
- # Returns a Hash of configuration and other useful diagnostic information.
78
- #
79
- # @return [Hash] a diagnostic hash
80
- def diagnose
81
- raw = read
82
- result = Hash.new
83
- raw.keys.sort.each { |k| result[k] = raw[k] }
84
- result
85
- end
86
-
87
- private
88
-
89
- # @return [String] absolute path to the yaml state file on disk
90
- # @api private
91
- attr_reader :file_name
92
-
93
- # @return [String] a string representation of the yaml state file
94
- # @api private
95
- def read_file
96
- IO.read(file_name)
97
- end
98
-
99
- # Parses a YAML string and returns a Hash.
100
- #
101
- # @param string [String] a yaml document as a string
102
- # @return [Hash] a hash
103
- # @raise [StateFileLoadError] if the string document cannot be parsed
104
- # @api private
105
- def deserialize_string(string)
106
- SafeYAML.load(string)
107
- rescue SyntaxError, Psych::SyntaxError => ex
108
- raise StateFileLoadError, "Error parsing #{file_name} (#{ex.message})"
109
- end
110
-
111
- # Serializes a Hash into a YAML string.
112
- #
113
- # @param hash [Hash] a hash
114
- # @return [String] a yaml document as a string
115
- # @api private
116
- def serialize_hash(hash)
117
- ::YAML.dump(hash)
118
- end
119
- end
120
- 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
+ if RUBY_VERSION <= "1.9.3"
20
+ # ensure that Psych and not Syck is used for Ruby 1.9.2
21
+ require "yaml"
22
+ YAML::ENGINE.yamler = "psych"
23
+ end
24
+ require "safe_yaml/load"
25
+
26
+ module Kitchen
27
+
28
+ # Exception class for any exceptions raised when reading and parsing a state
29
+ # file from disk
30
+ class StateFileLoadError < StandardError; end
31
+
32
+ # State persistence manager for instances between actions and invocations.
33
+ #
34
+ # @author Fletcher Nichol <fnichol@nichol.ca>
35
+ class StateFile
36
+
37
+ # Constructs an new instance taking the kitchen root and instance name.
38
+ #
39
+ # @param kitchen_root [String] path to the Kitchen project's root directory
40
+ # @param name [String] name of the instance representing this state
41
+ def initialize(kitchen_root, name)
42
+ @file_name = File.expand_path(
43
+ File.join(kitchen_root, ".kitchen", "#{name}.yml")
44
+ )
45
+ end
46
+
47
+ # Reads and loads an instance's state into a Hash data structure which is
48
+ # returned.
49
+ #
50
+ # @return [Hash] a hash representation of an instance's state
51
+ # @raise [StateFileLoadError] if there is a problem loading the state file
52
+ # from disk and loading it into a Hash
53
+ def read
54
+ if File.exist?(file_name) && !File.zero?(file_name)
55
+ Util.symbolized_hash(deserialize_string(read_file))
56
+ else
57
+ Hash.new
58
+ end
59
+ end
60
+
61
+ # Serializes the state hash and writes a state file to disk.
62
+ #
63
+ # @param state [Hash] the current state of the instance
64
+ def write(state)
65
+ dir = File.dirname(file_name)
66
+ serialized_string = serialize_hash(Util.stringified_hash(state))
67
+
68
+ FileUtils.mkdir_p(dir) if !File.directory?(dir)
69
+ File.open(file_name, "wb") { |f| f.write(serialized_string) }
70
+ end
71
+
72
+ # Destroys a state file on disk if it exists.
73
+ def destroy
74
+ FileUtils.rm_f(file_name) if File.exist?(file_name)
75
+ end
76
+
77
+ # Returns a Hash of configuration and other useful diagnostic information.
78
+ #
79
+ # @return [Hash] a diagnostic hash
80
+ def diagnose
81
+ raw = read
82
+ result = Hash.new
83
+ raw.keys.sort.each { |k| result[k] = raw[k] }
84
+ result
85
+ end
86
+
87
+ private
88
+
89
+ # @return [String] absolute path to the yaml state file on disk
90
+ # @api private
91
+ attr_reader :file_name
92
+
93
+ # @return [String] a string representation of the yaml state file
94
+ # @api private
95
+ def read_file
96
+ IO.read(file_name)
97
+ end
98
+
99
+ # Parses a YAML string and returns a Hash.
100
+ #
101
+ # @param string [String] a yaml document as a string
102
+ # @return [Hash] a hash
103
+ # @raise [StateFileLoadError] if the string document cannot be parsed
104
+ # @api private
105
+ def deserialize_string(string)
106
+ SafeYAML.load(string)
107
+ rescue SyntaxError, Psych::SyntaxError => ex
108
+ raise StateFileLoadError, "Error parsing #{file_name} (#{ex.message})"
109
+ end
110
+
111
+ # Serializes a Hash into a YAML string.
112
+ #
113
+ # @param hash [Hash] a hash
114
+ # @return [String] a yaml document as a string
115
+ # @api private
116
+ def serialize_hash(hash)
117
+ ::YAML.dump(hash)
118
+ end
119
+ end
120
+ end
data/lib/kitchen/suite.rb CHANGED
@@ -1,51 +1,51 @@
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
- module Kitchen
20
-
21
- # A logical configuration representing a test case or fixture that will be
22
- # executed on a platform.
23
- #
24
- # @author Fletcher Nichol <fnichol@nichol.ca>
25
- class Suite
26
-
27
- # @return [String] logical name of this suite
28
- attr_reader :name
29
-
30
- # @return [Array] Array of names of excluded platforms
31
- attr_reader :excludes
32
-
33
- # @return [Array] Array of names of only included platforms
34
- attr_reader :includes
35
-
36
- # Constructs a new suite.
37
- #
38
- # @param [Hash] options configuration for a new suite
39
- # @option options [String] :name logical name of this suit (**Required**)
40
- # @option options [String] :excludes Array of names of excluded platforms
41
- # @option options [String] :includes Array of names of only included
42
- # platforms
43
- def initialize(options = {})
44
- @name = options.fetch(:name) do
45
- raise ClientError, "Suite#new requires option :name"
46
- end
47
- @excludes = options.fetch(:excludes, [])
48
- @includes = options.fetch(:includes, [])
49
- end
50
- end
51
- 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
+ module Kitchen
20
+
21
+ # A logical configuration representing a test case or fixture that will be
22
+ # executed on a platform.
23
+ #
24
+ # @author Fletcher Nichol <fnichol@nichol.ca>
25
+ class Suite
26
+
27
+ # @return [String] logical name of this suite
28
+ attr_reader :name
29
+
30
+ # @return [Array] Array of names of excluded platforms
31
+ attr_reader :excludes
32
+
33
+ # @return [Array] Array of names of only included platforms
34
+ attr_reader :includes
35
+
36
+ # Constructs a new suite.
37
+ #
38
+ # @param [Hash] options configuration for a new suite
39
+ # @option options [String] :name logical name of this suit (**Required**)
40
+ # @option options [String] :excludes Array of names of excluded platforms
41
+ # @option options [String] :includes Array of names of only included
42
+ # platforms
43
+ def initialize(options = {})
44
+ @name = options.fetch(:name) do
45
+ raise ClientError, "Suite#new requires option :name"
46
+ end
47
+ @excludes = options.fetch(:excludes, [])
48
+ @includes = options.fetch(:includes, [])
49
+ end
50
+ end
51
+ end
@@ -1,66 +1,66 @@
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 "thor"
20
-
21
- require "kitchen"
22
-
23
- module Kitchen
24
-
25
- # Kitchen Thor task generator.
26
- #
27
- # @author Fletcher Nichol <fnichol@nichol.ca>
28
- class ThorTasks < Thor
29
-
30
- namespace :kitchen
31
-
32
- # Creates Kitchen Thor tasks and allows the callee to configure it.
33
- #
34
- # @yield [self] gives itself to the block
35
- def initialize(*args)
36
- super
37
- @config = Kitchen::Config.new
38
- Kitchen.logger = Kitchen.default_file_logger(nil, false)
39
- yield self if block_given?
40
- define
41
- end
42
-
43
- private
44
-
45
- # @return [Config] a Kitchen::Config
46
- attr_reader :config
47
-
48
- # Generates a test Thor task for each instance and one to test all
49
- # instances in serial.
50
- #
51
- # @api private
52
- def define
53
- config.instances.each do |instance|
54
- self.class.desc instance.name, "Run #{instance.name} test instance"
55
- self.class.send(:define_method, instance.name.gsub(/-/, "_")) do
56
- instance.test(:always)
57
- end
58
- end
59
-
60
- self.class.desc "all", "Run all test instances"
61
- self.class.send(:define_method, :all) do
62
- config.instances.each { |i| invoke i.name.gsub(/-/, "_") }
63
- end
64
- end
65
- end
66
- 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 "thor"
20
+
21
+ require "kitchen"
22
+
23
+ module Kitchen
24
+
25
+ # Kitchen Thor task generator.
26
+ #
27
+ # @author Fletcher Nichol <fnichol@nichol.ca>
28
+ class ThorTasks < Thor
29
+
30
+ namespace :kitchen
31
+
32
+ # Creates Kitchen Thor tasks and allows the callee to configure it.
33
+ #
34
+ # @yield [self] gives itself to the block
35
+ def initialize(*args)
36
+ super
37
+ @config = Kitchen::Config.new
38
+ Kitchen.logger = Kitchen.default_file_logger(nil, false)
39
+ yield self if block_given?
40
+ define
41
+ end
42
+
43
+ private
44
+
45
+ # @return [Config] a Kitchen::Config
46
+ attr_reader :config
47
+
48
+ # Generates a test Thor task for each instance and one to test all
49
+ # instances in serial.
50
+ #
51
+ # @api private
52
+ def define
53
+ config.instances.each do |instance|
54
+ self.class.desc instance.name, "Run #{instance.name} test instance"
55
+ self.class.send(:define_method, instance.name.gsub(/-/, "_")) do
56
+ instance.test(:always)
57
+ end
58
+ end
59
+
60
+ self.class.desc "all", "Run all test instances"
61
+ self.class.send(:define_method, :all) do
62
+ config.instances.each { |i| invoke i.name.gsub(/-/, "_") }
63
+ end
64
+ end
65
+ end
66
+ end