chef-dk 2.6.2 → 3.0.36

Sign up to get free protection for your applications and to get access to all the features.
Files changed (377) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +126 -121
  3. data/Gemfile.lock +812 -807
  4. data/LICENSE +201 -201
  5. data/README.md +333 -333
  6. data/Rakefile +74 -74
  7. data/acceptance/.shared/kitchen_acceptance/.kitchen.digitalocean.yml +27 -27
  8. data/acceptance/.shared/kitchen_acceptance/.kitchen.ec2.yml +287 -287
  9. data/acceptance/.shared/kitchen_acceptance/.kitchen.vagrant.yml +52 -52
  10. data/acceptance/.shared/kitchen_acceptance/libraries/kitchen.rb +51 -51
  11. data/acceptance/.shared/kitchen_acceptance/metadata.rb +1 -1
  12. data/acceptance/Gemfile +21 -21
  13. data/acceptance/Gemfile.lock +334 -334
  14. data/acceptance/README.md +132 -132
  15. data/acceptance/trivial/.acceptance/acceptance-cookbook/.gitignore +2 -2
  16. data/acceptance/trivial/.acceptance/acceptance-cookbook/metadata.rb +2 -2
  17. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  18. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  19. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  20. data/acceptance/trivial/.kitchen.yml +7 -7
  21. data/acceptance/trivial/test/integration/chefdk-current-install/inspec/chef_client_spec.rb +5 -5
  22. data/bin/chef +25 -25
  23. data/chef-dk.gemspec +60 -60
  24. data/lib/chef-dk.rb +19 -19
  25. data/lib/chef-dk/authenticated_http.rb +22 -22
  26. data/lib/chef-dk/builtin_commands.rb +59 -59
  27. data/lib/chef-dk/chef_runner.rb +114 -114
  28. data/lib/chef-dk/chef_server_api_multi.rb +73 -73
  29. data/lib/chef-dk/cli.rb +201 -201
  30. data/lib/chef-dk/command/base.rb +79 -79
  31. data/lib/chef-dk/command/clean_policy_cookbooks.rb +114 -114
  32. data/lib/chef-dk/command/clean_policy_revisions.rb +111 -111
  33. data/lib/chef-dk/command/delete_policy.rb +120 -120
  34. data/lib/chef-dk/command/delete_policy_group.rb +120 -120
  35. data/lib/chef-dk/command/diff.rb +315 -315
  36. data/lib/chef-dk/command/env.rb +89 -89
  37. data/lib/chef-dk/command/exec.rb +44 -44
  38. data/lib/chef-dk/command/export.rb +155 -155
  39. data/lib/chef-dk/command/gem.rb +47 -47
  40. data/lib/chef-dk/command/generate.rb +125 -125
  41. data/lib/chef-dk/command/generator_commands.rb +83 -83
  42. data/lib/chef-dk/command/generator_commands/app.rb +106 -106
  43. data/lib/chef-dk/command/generator_commands/attribute.rb +36 -36
  44. data/lib/chef-dk/command/generator_commands/base.rb +157 -157
  45. data/lib/chef-dk/command/generator_commands/build_cookbook.rb +125 -125
  46. data/lib/chef-dk/command/generator_commands/chef_exts/generator_desc_resource.rb +85 -85
  47. data/lib/chef-dk/command/generator_commands/chef_exts/quieter_doc_formatter.rb +38 -38
  48. data/lib/chef-dk/command/generator_commands/chef_exts/recipe_dsl_ext.rb +39 -39
  49. data/lib/chef-dk/command/generator_commands/cookbook.rb +241 -241
  50. data/lib/chef-dk/command/generator_commands/cookbook_code_file.rb +100 -100
  51. data/lib/chef-dk/command/generator_commands/cookbook_file.rb +45 -45
  52. data/lib/chef-dk/command/generator_commands/generator_generator.rb +174 -174
  53. data/lib/chef-dk/command/generator_commands/helpers.rb +36 -36
  54. data/lib/chef-dk/command/generator_commands/policyfile.rb +124 -126
  55. data/lib/chef-dk/command/generator_commands/recipe.rb +36 -36
  56. data/lib/chef-dk/command/generator_commands/repo.rb +123 -123
  57. data/lib/chef-dk/command/generator_commands/resource.rb +36 -36
  58. data/lib/chef-dk/command/generator_commands/template.rb +46 -46
  59. data/lib/chef-dk/command/install.rb +120 -120
  60. data/lib/chef-dk/command/provision.rb +436 -436
  61. data/lib/chef-dk/command/push.rb +117 -117
  62. data/lib/chef-dk/command/push_archive.rb +125 -125
  63. data/lib/chef-dk/command/shell_init.rb +179 -179
  64. data/lib/chef-dk/command/show_policy.rb +163 -163
  65. data/lib/chef-dk/command/undelete.rb +154 -154
  66. data/lib/chef-dk/command/update.rb +133 -133
  67. data/lib/chef-dk/command/verify.rb +629 -629
  68. data/lib/chef-dk/commands_map.rb +113 -113
  69. data/lib/chef-dk/completions/bash.sh.erb +5 -5
  70. data/lib/chef-dk/completions/chef.fish.erb +10 -10
  71. data/lib/chef-dk/completions/zsh.zsh.erb +21 -21
  72. data/lib/chef-dk/component_test.rb +227 -227
  73. data/lib/chef-dk/configurable.rb +88 -88
  74. data/lib/chef-dk/cookbook_metadata.rb +45 -45
  75. data/lib/chef-dk/cookbook_omnifetch.rb +32 -32
  76. data/lib/chef-dk/cookbook_profiler/git.rb +152 -151
  77. data/lib/chef-dk/cookbook_profiler/identifiers.rb +72 -72
  78. data/lib/chef-dk/cookbook_profiler/null_scm.rb +31 -31
  79. data/lib/chef-dk/exceptions.rb +151 -150
  80. data/lib/chef-dk/generator.rb +165 -165
  81. data/lib/chef-dk/helpers.rb +176 -176
  82. data/lib/chef-dk/pager.rb +104 -105
  83. data/lib/chef-dk/policyfile/artifactory_cookbook_source.rb +102 -102
  84. data/lib/chef-dk/policyfile/attribute_merge_checker.rb +110 -110
  85. data/lib/chef-dk/policyfile/chef_repo_cookbook_source.rb +138 -138
  86. data/lib/chef-dk/policyfile/chef_server_cookbook_source.rb +99 -99
  87. data/lib/chef-dk/policyfile/chef_server_lock_fetcher.rb +167 -164
  88. data/lib/chef-dk/policyfile/community_cookbook_source.rb +95 -95
  89. data/lib/chef-dk/policyfile/comparison_base.rb +123 -123
  90. data/lib/chef-dk/policyfile/cookbook_location_specification.rb +154 -154
  91. data/lib/chef-dk/policyfile/cookbook_locks.rb +466 -466
  92. data/lib/chef-dk/policyfile/cookbook_sources.rb +23 -23
  93. data/lib/chef-dk/policyfile/delivery_supermarket_source.rb +89 -89
  94. data/lib/chef-dk/policyfile/differ.rb +263 -263
  95. data/lib/chef-dk/policyfile/dsl.rb +288 -288
  96. data/lib/chef-dk/policyfile/git_lock_fetcher.rb +265 -0
  97. data/lib/chef-dk/policyfile/included_policies_cookbook_source.rb +156 -156
  98. data/lib/chef-dk/policyfile/lister.rb +229 -229
  99. data/lib/chef-dk/policyfile/local_lock_fetcher.rb +129 -123
  100. data/lib/chef-dk/policyfile/lock_applier.rb +80 -80
  101. data/lib/chef-dk/policyfile/null_cookbook_source.rb +49 -49
  102. data/lib/chef-dk/policyfile/policyfile_location_specification.rb +125 -122
  103. data/lib/chef-dk/policyfile/read_cookbook_for_compat_mode_upload.rb +124 -124
  104. data/lib/chef-dk/policyfile/reports/install.rb +69 -69
  105. data/lib/chef-dk/policyfile/reports/table_printer.rb +57 -57
  106. data/lib/chef-dk/policyfile/reports/upload.rb +70 -70
  107. data/lib/chef-dk/policyfile/solution_dependencies.rb +311 -312
  108. data/lib/chef-dk/policyfile/source_uri.rb +57 -57
  109. data/lib/chef-dk/policyfile/storage_config.rb +112 -102
  110. data/lib/chef-dk/policyfile/undo_record.rb +139 -139
  111. data/lib/chef-dk/policyfile/undo_stack.rb +128 -128
  112. data/lib/chef-dk/policyfile/uploader.rb +213 -213
  113. data/lib/chef-dk/policyfile_compiler.rb +528 -528
  114. data/lib/chef-dk/policyfile_lock.rb +581 -581
  115. data/lib/chef-dk/policyfile_services/clean_policies.rb +95 -95
  116. data/lib/chef-dk/policyfile_services/clean_policy_cookbooks.rb +123 -123
  117. data/lib/chef-dk/policyfile_services/export_repo.rb +419 -420
  118. data/lib/chef-dk/policyfile_services/install.rb +162 -162
  119. data/lib/chef-dk/policyfile_services/push.rb +112 -112
  120. data/lib/chef-dk/policyfile_services/push_archive.rb +164 -200
  121. data/lib/chef-dk/policyfile_services/rm_policy.rb +141 -141
  122. data/lib/chef-dk/policyfile_services/rm_policy_group.rb +85 -85
  123. data/lib/chef-dk/policyfile_services/show_policy.rb +234 -236
  124. data/lib/chef-dk/policyfile_services/undelete.rb +108 -108
  125. data/lib/chef-dk/policyfile_services/update_attributes.rb +110 -110
  126. data/lib/chef-dk/service_exception_inspectors.rb +24 -24
  127. data/lib/chef-dk/service_exception_inspectors/base.rb +39 -39
  128. data/lib/chef-dk/service_exception_inspectors/http.rb +119 -119
  129. data/lib/chef-dk/service_exceptions.rb +142 -142
  130. data/lib/chef-dk/shell_out.rb +36 -36
  131. data/lib/chef-dk/skeletons/code_generator/files/default/Berksfile +4 -4
  132. data/lib/chef-dk/skeletons/code_generator/files/default/build_cookbook/.kitchen.yml +21 -21
  133. data/lib/chef-dk/skeletons/code_generator/files/default/build_cookbook/README.md +146 -146
  134. data/lib/chef-dk/skeletons/code_generator/files/default/build_cookbook/test-fixture-recipe.rb +9 -9
  135. data/lib/chef-dk/skeletons/code_generator/files/default/chefignore +104 -107
  136. data/lib/chef-dk/skeletons/code_generator/files/default/cookbook_readmes/README-policy.md +9 -9
  137. data/lib/chef-dk/skeletons/code_generator/files/default/cookbook_readmes/README.md +66 -54
  138. data/lib/chef-dk/skeletons/code_generator/files/default/delivery-config.json +17 -17
  139. data/lib/chef-dk/skeletons/code_generator/files/default/delivery-project.toml +36 -36
  140. data/lib/chef-dk/skeletons/code_generator/files/default/gitignore +22 -22
  141. data/lib/chef-dk/skeletons/code_generator/files/default/repo/README.md +24 -24
  142. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/README.md +27 -27
  143. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/attributes/default.rb +8 -8
  144. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/metadata.rb +7 -7
  145. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/recipes/default.rb +9 -9
  146. data/lib/chef-dk/skeletons/code_generator/files/default/repo/data_bags/README.md +56 -56
  147. data/lib/chef-dk/skeletons/code_generator/files/default/repo/data_bags/example/example_item.json +3 -3
  148. data/lib/chef-dk/skeletons/code_generator/files/default/repo/dot-chef-repo.txt +6 -6
  149. data/lib/chef-dk/skeletons/code_generator/files/default/repo/environments/README.md +9 -9
  150. data/lib/chef-dk/skeletons/code_generator/files/default/repo/environments/example.json +12 -12
  151. data/lib/chef-dk/skeletons/code_generator/files/default/repo/policies/README.md +24 -24
  152. data/lib/chef-dk/skeletons/code_generator/files/default/repo/roles/README.md +9 -9
  153. data/lib/chef-dk/skeletons/code_generator/files/default/repo/roles/example.json +12 -12
  154. data/lib/chef-dk/skeletons/code_generator/files/default/spec_helper.rb +3 -3
  155. data/lib/chef-dk/skeletons/code_generator/files/default/spec_helper_policyfile.rb +3 -3
  156. data/lib/chef-dk/skeletons/code_generator/metadata.rb +8 -8
  157. data/lib/chef-dk/skeletons/code_generator/recipes/app.rb +89 -89
  158. data/lib/chef-dk/skeletons/code_generator/recipes/attribute.rb +13 -13
  159. data/lib/chef-dk/skeletons/code_generator/recipes/build_cookbook.rb +177 -177
  160. data/lib/chef-dk/skeletons/code_generator/recipes/cookbook.rb +158 -152
  161. data/lib/chef-dk/skeletons/code_generator/recipes/cookbook_file.rb +25 -25
  162. data/lib/chef-dk/skeletons/code_generator/recipes/helpers.rb +21 -21
  163. data/lib/chef-dk/skeletons/code_generator/recipes/policyfile.rb +9 -9
  164. data/lib/chef-dk/skeletons/code_generator/recipes/recipe.rb +52 -52
  165. data/lib/chef-dk/skeletons/code_generator/recipes/repo.rb +68 -68
  166. data/lib/chef-dk/skeletons/code_generator/recipes/resource.rb +13 -13
  167. data/lib/chef-dk/skeletons/code_generator/recipes/template.rb +32 -32
  168. data/lib/chef-dk/skeletons/code_generator/templates/default/CHANGELOG.md.erb +11 -0
  169. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.all_rights.erb +3 -3
  170. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.apachev2.erb +201 -201
  171. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.gplv2.erb +339 -339
  172. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.gplv3.erb +674 -674
  173. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.mit.erb +21 -21
  174. data/lib/chef-dk/skeletons/code_generator/templates/default/Policyfile.rb.erb +25 -25
  175. data/lib/chef-dk/skeletons/code_generator/templates/default/README.md.erb +4 -4
  176. data/lib/chef-dk/skeletons/code_generator/templates/default/build_cookbook/Berksfile.erb +7 -7
  177. data/lib/chef-dk/skeletons/code_generator/templates/default/build_cookbook/metadata.rb.erb +10 -10
  178. data/lib/chef-dk/skeletons/code_generator/templates/default/build_cookbook/recipe.rb.erb +8 -8
  179. data/lib/chef-dk/skeletons/code_generator/templates/default/helpers.rb.erb +39 -39
  180. data/lib/chef-dk/skeletons/code_generator/templates/default/inspec_default_test.rb.erb +18 -18
  181. data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen.yml.erb +26 -26
  182. data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen_policyfile.yml.erb +33 -33
  183. data/lib/chef-dk/skeletons/code_generator/templates/default/metadata.rb.erb +20 -20
  184. data/lib/chef-dk/skeletons/code_generator/templates/default/recipe.rb.erb +5 -5
  185. data/lib/chef-dk/skeletons/code_generator/templates/default/recipe_spec.rb.erb +35 -35
  186. data/lib/chef-dk/skeletons/code_generator/templates/default/repo/gitignore.erb +128 -128
  187. data/lib/chef-dk/skeletons/code_generator/templates/default/resource.rb.erb +1 -1
  188. data/lib/chef-dk/ui.rb +57 -57
  189. data/lib/chef-dk/version.rb +20 -20
  190. data/lib/kitchen/provisioner/policyfile_zero.rb +195 -195
  191. data/omnibus_overrides.rb +25 -25
  192. data/spec/shared/a_file_generator.rb +125 -125
  193. data/spec/shared/a_generated_file.rb +12 -12
  194. data/spec/shared/command_with_ui_object.rb +11 -11
  195. data/spec/shared/custom_generator_cookbook.rb +136 -136
  196. data/spec/shared/fixture_cookbook_checksums.rb +46 -46
  197. data/spec/shared/setup_git_committer_config.rb +54 -54
  198. data/spec/shared/setup_git_cookbooks.rb +53 -53
  199. data/spec/spec_helper.rb +51 -51
  200. data/spec/test_helpers.rb +84 -84
  201. data/spec/unit/chef_runner_spec.rb +139 -139
  202. data/spec/unit/chef_server_api_multi_spec.rb +120 -120
  203. data/spec/unit/cli_spec.rb +377 -377
  204. data/spec/unit/command/base_spec.rb +172 -172
  205. data/spec/unit/command/clean_policy_cookbooks_spec.rb +180 -180
  206. data/spec/unit/command/clean_policy_revisions_spec.rb +180 -180
  207. data/spec/unit/command/delete_policy_group_spec.rb +206 -206
  208. data/spec/unit/command/delete_policy_spec.rb +206 -206
  209. data/spec/unit/command/diff_spec.rb +311 -311
  210. data/spec/unit/command/env_spec.rb +52 -52
  211. data/spec/unit/command/exec_spec.rb +178 -178
  212. data/spec/unit/command/export_spec.rb +199 -199
  213. data/spec/unit/command/generate_spec.rb +142 -142
  214. data/spec/unit/command/generator_commands/app_spec.rb +166 -166
  215. data/spec/unit/command/generator_commands/attribute_spec.rb +31 -31
  216. data/spec/unit/command/generator_commands/base_spec.rb +181 -181
  217. data/spec/unit/command/generator_commands/build_cookbook_spec.rb +377 -377
  218. data/spec/unit/command/generator_commands/chef_exts/generator_desc_resource_spec.rb +97 -97
  219. data/spec/unit/command/generator_commands/chef_exts/recipe_dsl_ext_spec.rb +111 -111
  220. data/spec/unit/command/generator_commands/cookbook_file_spec.rb +31 -31
  221. data/spec/unit/command/generator_commands/cookbook_spec.rb +765 -756
  222. data/spec/unit/command/generator_commands/generator_generator_spec.rb +227 -227
  223. data/spec/unit/command/generator_commands/helpers_spec.rb +31 -31
  224. data/spec/unit/command/generator_commands/policyfile_spec.rb +223 -223
  225. data/spec/unit/command/generator_commands/recipe_spec.rb +37 -37
  226. data/spec/unit/command/generator_commands/repo_spec.rb +374 -374
  227. data/spec/unit/command/generator_commands/resource_spec.rb +31 -31
  228. data/spec/unit/command/generator_commands/template_spec.rb +31 -31
  229. data/spec/unit/command/install_spec.rb +179 -179
  230. data/spec/unit/command/provision_spec.rb +589 -589
  231. data/spec/unit/command/push_archive_spec.rb +153 -153
  232. data/spec/unit/command/push_spec.rb +198 -198
  233. data/spec/unit/command/shell_init_spec.rb +339 -339
  234. data/spec/unit/command/show_policy_spec.rb +234 -234
  235. data/spec/unit/command/undelete_spec.rb +244 -244
  236. data/spec/unit/command/update_spec.rb +283 -283
  237. data/spec/unit/command/verify_spec.rb +341 -341
  238. data/spec/unit/commands_map_spec.rb +57 -57
  239. data/spec/unit/component_test_spec.rb +128 -128
  240. data/spec/unit/configurable_spec.rb +68 -68
  241. data/spec/unit/cookbook_metadata_spec.rb +96 -96
  242. data/spec/unit/cookbook_profiler/git_spec.rb +176 -176
  243. data/spec/unit/cookbook_profiler/identifiers_spec.rb +81 -81
  244. data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_one.rb +9 -9
  245. data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_two.rb +9 -9
  246. data/spec/unit/fixtures/command/cli_test_command.rb +26 -26
  247. data/spec/unit/fixtures/command/explicit_path_example.rb +7 -7
  248. data/spec/unit/fixtures/configurable/test_config_loader.rb +5 -5
  249. data/spec/unit/fixtures/configurable/test_configurable.rb +10 -10
  250. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -16
  251. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/Berksfile +3 -3
  252. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -4
  253. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/chefignore +96 -96
  254. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -8
  255. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -8
  256. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/.kitchen.yml +16 -16
  257. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/Berksfile +3 -3
  258. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/README.md +4 -4
  259. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/chefignore +96 -96
  260. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/metadata.rb +8 -8
  261. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/recipes/default.rb +8 -8
  262. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/.kitchen.yml +16 -16
  263. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/Berksfile +3 -3
  264. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/README.md +4 -4
  265. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/chefignore +96 -96
  266. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/metadata.rb +8 -8
  267. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/recipes/default.rb +8 -8
  268. data/spec/unit/fixtures/cookbooks_api/chef_server_universe.json +56 -56
  269. data/spec/unit/fixtures/cookbooks_api/pruned_chef_server_universe.json +30 -30
  270. data/spec/unit/fixtures/cookbooks_api/pruned_small_universe.json +1321 -1321
  271. data/spec/unit/fixtures/cookbooks_api/small_universe.json +2987 -2987
  272. data/spec/unit/fixtures/cookbooks_api/universe.json +1 -1
  273. data/spec/unit/fixtures/cookbooks_api/update_fixtures.rb +33 -33
  274. data/spec/unit/fixtures/dev_cookbooks/README.md +16 -16
  275. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/integration_test +2 -2
  276. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/verify_me +5 -5
  277. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/chef/verify_me +3 -3
  278. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/test-kitchen/verify_me +2 -2
  279. data/spec/unit/fixtures/example_cookbook/.gitignore +17 -17
  280. data/spec/unit/fixtures/example_cookbook/.kitchen.yml +16 -16
  281. data/spec/unit/fixtures/example_cookbook/Berksfile +3 -3
  282. data/spec/unit/fixtures/example_cookbook/README.md +4 -4
  283. data/spec/unit/fixtures/example_cookbook/chefignore +96 -96
  284. data/spec/unit/fixtures/example_cookbook/metadata.rb +8 -8
  285. data/spec/unit/fixtures/example_cookbook/recipes/default.rb +8 -8
  286. data/spec/unit/fixtures/example_cookbook_metadata_json_only/.gitignore +17 -17
  287. data/spec/unit/fixtures/example_cookbook_metadata_json_only/.kitchen.yml +16 -16
  288. data/spec/unit/fixtures/example_cookbook_metadata_json_only/Berksfile +3 -3
  289. data/spec/unit/fixtures/example_cookbook_metadata_json_only/README.md +4 -4
  290. data/spec/unit/fixtures/example_cookbook_metadata_json_only/chefignore +96 -96
  291. data/spec/unit/fixtures/example_cookbook_metadata_json_only/metadata.json +5 -5
  292. data/spec/unit/fixtures/example_cookbook_metadata_json_only/recipes/default.rb +8 -8
  293. data/spec/unit/fixtures/example_cookbook_no_metadata/.gitignore +17 -17
  294. data/spec/unit/fixtures/example_cookbook_no_metadata/.kitchen.yml +16 -16
  295. data/spec/unit/fixtures/example_cookbook_no_metadata/Berksfile +3 -3
  296. data/spec/unit/fixtures/example_cookbook_no_metadata/README.md +4 -4
  297. data/spec/unit/fixtures/example_cookbook_no_metadata/chefignore +96 -96
  298. data/spec/unit/fixtures/example_cookbook_no_metadata/recipes/default.rb +8 -8
  299. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/README.md +4 -4
  300. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/chefignore +96 -96
  301. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/metadata.rb +8 -8
  302. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/recipes/default.rb +8 -8
  303. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/Berksfile +3 -3
  304. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/README.md +4 -4
  305. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/chefignore +96 -96
  306. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/metadata.rb +9 -9
  307. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/recipes/default.rb +8 -8
  308. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/.kitchen.yml +16 -16
  309. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/Berksfile +3 -3
  310. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/README.md +4 -4
  311. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/chefignore +96 -96
  312. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/metadata.rb +8 -8
  313. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/recipes/default.rb +8 -8
  314. data/spec/unit/fixtures/local_path_cookbooks/metadata-missing/README.md +2 -2
  315. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -16
  316. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -4
  317. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -8
  318. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -8
  319. data/spec/unit/generator_spec.rb +119 -119
  320. data/spec/unit/pager_spec.rb +117 -117
  321. data/spec/unit/policyfile/artifactory_cookbook_source_spec.rb +59 -59
  322. data/spec/unit/policyfile/attribute_merge_checker_spec.rb +80 -80
  323. data/spec/unit/policyfile/chef_repo_cookbook_source_spec.rb +93 -93
  324. data/spec/unit/policyfile/chef_server_cookbook_source_spec.rb +55 -55
  325. data/spec/unit/policyfile/chef_server_lock_fetcher_spec.rb +161 -161
  326. data/spec/unit/policyfile/community_cookbook_source_spec.rb +83 -83
  327. data/spec/unit/policyfile/comparison_base_spec.rb +340 -340
  328. data/spec/unit/policyfile/cookbook_location_specification_spec.rb +347 -347
  329. data/spec/unit/policyfile/cookbook_locks_spec.rb +527 -527
  330. data/spec/unit/policyfile/delivery_supermarket_source_spec.rb +129 -129
  331. data/spec/unit/policyfile/differ_spec.rb +686 -686
  332. data/spec/unit/policyfile/git_lock_fetcher_spec.rb +155 -0
  333. data/spec/unit/policyfile/included_policies_cookbook_source_spec.rb +242 -242
  334. data/spec/unit/policyfile/lister_spec.rb +268 -268
  335. data/spec/unit/policyfile/local_lock_fetcher_spec.rb +173 -173
  336. data/spec/unit/policyfile/lock_applier_spec.rb +100 -100
  337. data/spec/unit/policyfile/null_cookbook_source_spec.rb +34 -34
  338. data/spec/unit/policyfile/read_cookbook_for_compat_mode_upload_spec.rb +92 -92
  339. data/spec/unit/policyfile/reports/install_spec.rb +114 -114
  340. data/spec/unit/policyfile/reports/upload_spec.rb +94 -94
  341. data/spec/unit/policyfile/solution_dependencies_spec.rb +170 -170
  342. data/spec/unit/policyfile/source_uri_spec.rb +36 -36
  343. data/spec/unit/policyfile/storage_config_spec.rb +180 -180
  344. data/spec/unit/policyfile/undo_record_spec.rb +258 -258
  345. data/spec/unit/policyfile/undo_stack_spec.rb +265 -265
  346. data/spec/unit/policyfile/uploader_spec.rb +409 -409
  347. data/spec/unit/policyfile_demands_spec.rb +1197 -1197
  348. data/spec/unit/policyfile_evaluation_spec.rb +628 -638
  349. data/spec/unit/policyfile_includes_dsl_spec.rb +159 -159
  350. data/spec/unit/policyfile_includes_spec.rb +720 -720
  351. data/spec/unit/policyfile_install_with_includes_spec.rb +232 -232
  352. data/spec/unit/policyfile_lock_build_spec.rb +1065 -1065
  353. data/spec/unit/policyfile_lock_install_spec.rb +137 -137
  354. data/spec/unit/policyfile_lock_serialization_spec.rb +424 -424
  355. data/spec/unit/policyfile_lock_validation_spec.rb +608 -608
  356. data/spec/unit/policyfile_services/clean_policies_spec.rb +236 -236
  357. data/spec/unit/policyfile_services/clean_policy_cookbooks_spec.rb +272 -272
  358. data/spec/unit/policyfile_services/export_repo_spec.rb +473 -478
  359. data/spec/unit/policyfile_services/install_spec.rb +209 -209
  360. data/spec/unit/policyfile_services/push_archive_spec.rb +359 -374
  361. data/spec/unit/policyfile_services/push_spec.rb +249 -249
  362. data/spec/unit/policyfile_services/rm_policy_group_spec.rb +237 -237
  363. data/spec/unit/policyfile_services/rm_policy_spec.rb +263 -263
  364. data/spec/unit/policyfile_services/show_policy_spec.rb +887 -887
  365. data/spec/unit/policyfile_services/undelete_spec.rb +302 -302
  366. data/spec/unit/policyfile_services/update_attributes_spec.rb +229 -229
  367. data/spec/unit/policyfile_services/update_spec.rb +140 -140
  368. data/spec/unit/service_exception_inspectors/base_spec.rb +41 -41
  369. data/spec/unit/service_exception_inspectors/http_spec.rb +138 -138
  370. data/spec/unit/shell_out_spec.rb +34 -34
  371. data/tasks/announce.rb +57 -57
  372. data/tasks/bin/bundle-platform.bat +2 -2
  373. data/tasks/dependencies.rb +89 -89
  374. data/tasks/templates/prerelease.md.erb +35 -35
  375. data/tasks/templates/release.md.erb +34 -34
  376. data/warning.txt +9 -9
  377. metadata +9 -5
@@ -1,629 +1,629 @@
1
- #
2
- # Copyright:: Copyright (c) 2014 Chef Software Inc.
3
- # License:: Apache License, Version 2.0
4
- #
5
- # Licensed under the Apache License, Version 2.0 (the "License");
6
- # you may not use this file except in compliance with the License.
7
- # You may obtain a copy of the License at
8
- #
9
- # http://www.apache.org/licenses/LICENSE-2.0
10
- #
11
- # Unless required by applicable law or agreed to in writing, software
12
- # distributed under the License is distributed on an "AS IS" BASIS,
13
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
- # See the License for the specific language governing permissions and
15
- # limitations under the License.
16
- #
17
-
18
- require "chef-dk/command/base"
19
- require "chef-dk/exceptions"
20
- require "chef-dk/component_test"
21
-
22
- module ChefDK
23
- module Command
24
- class Verify < ChefDK::Command::Base
25
-
26
- include ChefDK::Helpers
27
-
28
- banner "Usage: chef verify [component, ...] [options]"
29
-
30
- option :omnibus_dir,
31
- :long => "--omnibus-dir OMNIBUS_DIR",
32
- :description => "Alternate path to omnibus install (used for testing)"
33
-
34
- option :unit,
35
- :long => "--unit",
36
- :description => "Run bundled app unit tests (only smoke tests run by default)"
37
-
38
- option :integration,
39
- :long => "--integration",
40
- :description => "Run integration tests. Possibly dangerous, for development systems only"
41
-
42
- option :verbose,
43
- :long => "--verbose",
44
- :description => "Display all test output, not just failing tests"
45
-
46
- class << self
47
- def add_component(name, _delete_me = nil)
48
- component = ComponentTest.new(name)
49
- yield component if block_given? #delete this conditional
50
- component_map[name] = component
51
- end
52
-
53
- def component(name)
54
- component_map[name]
55
- end
56
-
57
- def components
58
- component_map.values
59
- end
60
-
61
- def component_map
62
- @component_map ||= {}
63
- end
64
- end
65
-
66
- def components
67
- self.class.components
68
- end
69
-
70
- bundle_install_mutex = Mutex.new
71
-
72
- #
73
- # Components included in Chef Development kit:
74
- # :base_dir => Relative path of the component w.r.t. omnibus_apps_dir
75
- # :gem_base_dir => Takes a gem name instead and uses first gem found
76
- # :test_cmd => Test command to be launched for the component
77
- #
78
- add_component "berkshelf" do |c|
79
- c.gem_base_dir = "berkshelf"
80
- # For berks the real command to run is "#{embedded_bin("bundle")} exec thor spec:ci"
81
- # We can't run it right now since graphviz specs are included in the
82
- # test suite by default. We will be able to switch to that command when/if
83
- # Graphviz is added to omnibus.
84
- c.unit_test do
85
- bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
86
- sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} --color --format progress spec/unit --tag ~graphviz")
87
- end
88
- c.integration_test do
89
- bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
90
- sh("#{embedded_bin("bundle")} exec #{embedded_bin("cucumber")} --color --format progress --tags ~@no_run --tags ~@spawn --tags ~@graphviz --strict")
91
- end
92
-
93
- c.smoke_test do
94
- tmpdir do |cwd|
95
- FileUtils.touch(File.join(cwd, "Berksfile"))
96
- sh("#{bin("berks")} install", cwd: cwd)
97
- end
98
- end
99
- end
100
-
101
- add_component "test-kitchen" do |c|
102
- c.gem_base_dir = "test-kitchen"
103
- c.unit_test do
104
- bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
105
- sh("#{embedded_bin("bundle")} exec rake unit")
106
- end
107
- c.integration_test do
108
- bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
109
- sh("#{embedded_bin("bundle")} exec rake features")
110
- end
111
-
112
- # NOTE: By default, kitchen tries to be helpful and install a driver
113
- # gem for you. This causes a race condition when running the tests
114
- # concurrently, because rubygems breaks when there are partially
115
- # installed gems in the gem repository. Instructing kitchen to create a
116
- # gemfile instead avoids the gem installation.
117
- c.smoke_test { run_in_tmpdir("kitchen init --create-gemfile") }
118
- end
119
-
120
- add_component "tk-policyfile-provisioner" do |c|
121
-
122
- c.gem_base_dir = "chef-dk"
123
-
124
- c.smoke_test do
125
- tmpdir do |cwd|
126
- File.open(File.join(cwd, ".kitchen.yml"), "w+") do |f|
127
- f.print(<<-KITCHEN_YML)
128
- ---
129
- driver:
130
- name: dummy
131
- network:
132
- - ["forwarded_port", {guest: 80, host: 8080}]
133
-
134
- provisioner:
135
- name: policyfile_zero
136
- require_chef_omnibus: 12.3.0
137
-
138
- platforms:
139
- - name: ubuntu-14.04
140
-
141
- suites:
142
- - name: default
143
- run_list:
144
- - recipe[aar::default]
145
- attributes:
146
-
147
- KITCHEN_YML
148
- end
149
-
150
- sh("kitchen list", cwd: cwd)
151
-
152
- end
153
- end
154
-
155
- end
156
-
157
- add_component "chef-client" do |c|
158
- c.gem_base_dir = "chef"
159
- c.unit_test do
160
- bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
161
- sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} -fp -t '~volatile_from_verify' spec/unit")
162
- end
163
- c.integration_test do
164
- bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
165
- sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} -fp spec/integration spec/functional")
166
- end
167
-
168
- c.smoke_test do
169
- tmpdir do |cwd|
170
- FileUtils.touch(File.join(cwd, "apply.rb"))
171
- sh("#{bin("chef-apply")} apply.rb", cwd: cwd)
172
- end
173
- end
174
- end
175
-
176
- add_component "chef-dk" do |c|
177
- c.gem_base_dir = "chef-dk"
178
- c.unit_test do
179
- bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
180
- sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")}")
181
- end
182
- c.smoke_test do
183
- run_in_tmpdir("#{bin("chef")} generate cookbook example")
184
- end
185
- end
186
-
187
- # entirely possible this needs to be driven by a utility method in chef-provisioning.
188
- add_component "chef-provisioning" do |c|
189
- c.gem_base_dir = "chef-dk"
190
-
191
- c.smoke_test do
192
- # ------------
193
- # we want to avoid hard-coding driver names, but calling Gem::Specification produces a warning;
194
- # changing $VERBOSE seems to be the best way to silence it.
195
- verbose = $VERBOSE
196
- $VERBOSE = nil
197
-
198
- # construct a hash of { driver_name => [version1, version2, ...]}
199
- driver_versions = {}
200
- Gem::Specification.all.map { |gs| [gs.name, gs.version] }.
201
- select { |n| n[0] =~ /^chef-provisioning-/ }.
202
- each { |gem, version| (driver_versions[gem] ||= []) << version }
203
-
204
- drivers = Gem::Specification.all.map { |gs| gs.name }.
205
- select { |n| n =~ /^chef-provisioning-/ }.
206
- uniq
207
-
208
- versions = Gem::Specification.find_all_by_name("chef-provisioning").map { |s| s.version }
209
- $VERBOSE = verbose
210
- # ------------
211
- failures = []
212
-
213
- # ------------
214
- # fail the verify if we have more than one version of chef-provisioning or any of its drivers.
215
- def format_gem_failure(name, versions)
216
- <<-EOS
217
- #{name} has multiple versions installed:
218
- #{versions.sort.map { |gv| " #{gv}" }.join("\n")}
219
- EOS
220
- end
221
-
222
- failures << format_gem_failure("chef-provisioning", versions) if versions.size > 1
223
-
224
- driver_versions.keys.sort.each do |driver_name|
225
- v = driver_versions[driver_name]
226
- failures << format_gem_failure(driver_name, v) if v.size > 1
227
- end
228
-
229
- if failures.size > 0
230
- failures << <<-EOS
231
-
232
- Some applications may need or prefer different versions of the chef-provisioning gem or its drivers, so
233
- this multiple-version check can fail if a user has installed new versions of those libraries.
234
- EOS
235
- end
236
-
237
- # ------------
238
- # load the core gem and all of the drivers (ignoring versions).
239
- require "chef/provisioning"
240
- drivers.map { |d| "#{d.tr('-', '/')}_driver" }.each do |driver_gem|
241
- begin
242
- begin
243
- require driver_gem
244
- rescue LoadError
245
- # anomalously, chef-provisioning-fog does not have a fog_driver.rb. (9/2015)
246
- require "#{driver_gem}/driver.rb"
247
- end
248
- rescue LoadError => ex
249
- puts ex
250
- end
251
- end
252
-
253
- # ------------
254
- # look for version dependency conflicts.
255
- tmpdir do |cwd|
256
- versions.each do |provisioning_version|
257
- gemfile = "chef-provisioning-#{provisioning_version}-chefdk-test.gemfile"
258
-
259
- # write out the gemfile for this chef-provisioning version, and see if Bundler can make it go.
260
- with_file(File.join(cwd, gemfile)) do |f|
261
- f.puts %Q{gem "chef-provisioning", "= #{provisioning_version}"}
262
- drivers.each { |d| f.puts %Q{gem "#{d}"} }
263
- end
264
-
265
- result = bundle_install_mutex.synchronize do
266
- sh("#{embedded_bin("bundle")} install --local --quiet", cwd: cwd, env: { "BUNDLE_GEMFILE" => gemfile })
267
- end
268
-
269
- if result.exitstatus != 0
270
- failures << result.stdout
271
- end
272
- end # end provisioning versions.
273
-
274
- failures.each { |fail| puts fail }
275
-
276
- # dubious on Windows.
277
- # this is weird, but we seem to require a Mixlib::ShellOut as the return value. suggestions
278
- # welcome.
279
- sh(failures.size > 0 ? "false" : "true")
280
- end
281
- end
282
- end
283
-
284
- add_component "chefspec" do |c|
285
- c.gem_base_dir = "chefspec"
286
- c.unit_test do
287
- bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
288
- sh("#{embedded_bin("bundle")} exec #{embedded_bin("rake")} unit")
289
- end
290
- c.smoke_test do
291
- tmpdir do |cwd|
292
- FileUtils.mkdir(File.join(cwd, "spec"))
293
- with_file(File.join(cwd, "spec", "spec_helper.rb")) do |f|
294
- f.write <<-EOF
295
- require 'chefspec'
296
- require 'chefspec/berkshelf'
297
- require 'chefspec/cacher'
298
-
299
- RSpec.configure do |config|
300
- config.expect_with(:rspec) { |c| c.syntax = :expect }
301
- end
302
- EOF
303
- end
304
- FileUtils.touch(File.join(cwd, "Berksfile"))
305
- with_file(File.join(cwd, "spec", "foo_spec.rb")) do |f|
306
- f.write <<-EOF
307
- require 'spec_helper'
308
- EOF
309
- end
310
- sh(embedded_bin("rspec"), cwd: cwd)
311
- end
312
- end
313
- end
314
-
315
- add_component "generated-cookbooks-pass-chefspec" do |c|
316
-
317
- c.gem_base_dir = "chef-dk"
318
- c.smoke_test do
319
- tmpdir do |cwd|
320
- sh("#{bin("chef")} generate cookbook example", cwd: cwd)
321
- cb_cwd = File.join(cwd, "example")
322
- sh(embedded_bin("rspec"), cwd: cb_cwd)
323
- end
324
- end
325
- end
326
-
327
- add_component "fauxhai" do |c|
328
- c.gem_base_dir = "fauxhai"
329
- c.smoke_test { sh("#{embedded_bin("gem")} list fauxhai") }
330
- end
331
-
332
- add_component "knife-spork" do |c|
333
- c.gem_base_dir = "knife-spork"
334
- c.smoke_test { sh("#{bin("knife")} spork info") }
335
- end
336
-
337
- add_component "kitchen-vagrant" do |c|
338
- c.gem_base_dir = "kitchen-vagrant"
339
- # The build is not passing in travis, so no tests
340
- c.smoke_test { sh("#{embedded_bin("gem")} list kitchen-vagrant") }
341
- end
342
-
343
- add_component "package installation" do |c|
344
-
345
- c.gem_base_dir = "chef-dk"
346
-
347
- c.smoke_test do
348
-
349
- if File.directory?(usr_bin_prefix)
350
- sh!("#{usr_bin_path("berks")} -v")
351
- sh!("#{usr_bin_path("chef")} -v")
352
- sh!("#{usr_bin_path("chef-client")} -v")
353
- sh!("#{usr_bin_path("chef-solo")} -v")
354
- sh!("#{usr_bin_path("delivery")} -V") unless Chef::Platform.windows?
355
-
356
- # In `knife`, `knife -v` follows a different code path that skips
357
- # command/plugin loading; `knife -h` loads commands and plugins, but
358
- # it exits with code 1, which is the same as a load error. Running
359
- # `knife exec` forces command loading to happen and this command
360
- # exits 0, which runs most of the code.
361
- #
362
- # See also: https://github.com/chef/chef-dk/issues/227
363
- sh!("#{usr_bin_path("knife")} exec -E true")
364
-
365
- tmpdir do |dir|
366
- # Kitchen tries to create a .kitchen dir even when just running
367
- # `kitchen -v`:
368
- sh!("#{usr_bin_path("kitchen")} -v", cwd: dir)
369
- end
370
-
371
- sh!("#{usr_bin_path("ohai")} -v")
372
- sh!("#{usr_bin_path("foodcritic")} -V")
373
- sh!("#{usr_bin_path("inspec")} version")
374
- end
375
-
376
- # Test blocks are expected to return a Mixlib::ShellOut compatible
377
- # object:
378
- ComponentTest::NullTestResult.new
379
- end
380
- end
381
-
382
- add_component "openssl" do |c|
383
- # https://github.com/chef/chef-dk/issues/420
384
- c.gem_base_dir = "chef"
385
-
386
- test = <<-EOF.gsub(/^\s+/, "")
387
- require "net/http"
388
-
389
- uris = %w{https://www.google.com https://chef.io/ https://ec2.amazonaws.com}
390
- uris.each do |uri|
391
- uri = URI(uri)
392
- puts "Fetching \#{uri} for SSL check"
393
- Net::HTTP.get uri
394
- end
395
- EOF
396
-
397
- c.unit_test do
398
- tmpdir do |cwd|
399
- with_file(File.join(cwd, "openssl.rb")) do |f|
400
- f.write test
401
- end
402
- sh!("#{Gem.ruby} openssl.rb", cwd: cwd)
403
- end
404
- end
405
- end
406
-
407
- add_component "inspec" do |c|
408
- c.gem_base_dir = "inspec"
409
-
410
- # Commenting out the unit and integration tests for now until we figure
411
- # out the bundler error
412
- #c.unit_test { sh("#{embedded_bin("bundle")} exec rake test:isolated") }
413
- # This runs Test Kitchen (using kitchen-inspec) with some inspec tests
414
- #c.integration_test { sh("#{embedded_bin("bundle")} exec rake test:vm") }
415
-
416
- # It would be nice to use a chef generator to create these specs, but
417
- # we dont have that yet. So we do it manually.
418
- c.smoke_test do
419
- tmpdir do |cwd|
420
- File.open(File.join(cwd, "some_spec.rb"), "w+") do |f|
421
- f.print <<-INSPEC_TEST
422
- rule '01' do
423
- impact 0.7
424
- title 'Some Test'
425
- desc 'Make sure inspec is installed and loading correct'
426
- describe 1 do
427
- it { should eq(1) }
428
- end
429
- end
430
- INSPEC_TEST
431
- end
432
- # TODO when we appbundle inspec, no longer `chef exec`
433
- sh("#{bin("chef")} exec #{embedded_bin("inspec")} exec .", cwd: cwd)
434
- end
435
- end
436
- end
437
-
438
- add_component "delivery-cli" do |c|
439
- # We'll want to come back and revisit getting unit tests added -
440
- # currently running the tests depends on cargo , which is not included
441
- # in our package.
442
- c.base_dir = "bin"
443
- c.smoke_test do
444
- tmpdir do |cwd|
445
- sh!("delivery setup --user=shipit --server=delivery.shipit.io --ent=chef --org=squirrels", cwd: cwd)
446
- end
447
- end
448
- end
449
-
450
- if Chef::Platform.windows?
451
- add_component "git" do |c|
452
- c.base_dir = "embedded/bin"
453
- c.smoke_test do
454
- tmpdir do |cwd|
455
- sh!("#{embedded_bin("git")} config -l")
456
- sh!("#{embedded_bin("git")} clone https://github.com/chef/chef-provisioning", cwd: cwd)
457
- end
458
- end
459
- end
460
- else
461
- add_component "git" do |c|
462
- c.base_dir = "gitbin"
463
- c.smoke_test do
464
- tmpdir do |cwd|
465
- sh!("#{File.join(omnibus_root, "gitbin", "git")} config -l")
466
- sh!("#{File.join(omnibus_root, "gitbin", "git")} clone https://github.com/chef/chef-provisioning", cwd: cwd)
467
-
468
- # If /usr/bin/git is a symlink, fail the test.
469
- # Note that this test cannot go last because it does not return a
470
- # Mixlib::Shellout object in the windows case, which will break the tests.
471
- failure_str = "#{nix_platform_native_bin_dir}/git contains a symlink which might mean we accidentally overwrote system git via chefdk."
472
- result = sh("readlink #{nix_platform_native_bin_dir}/git")
473
- # if a symlink was found, test to see if it is in a chefdk install
474
- if result.status.exitstatus == 0
475
- raise failure_str if result.stdout =~ /chefdk/
476
- end
477
-
478
- # <chef_dk>/bin/ should not contain a git binary.
479
- failure_str = "`<chef_dk>/bin/git --help` should fail as git should be installed in gitbin"
480
- fail_if_exit_zero("#{bin("git")} --help", failure_str)
481
- end
482
- end
483
- end
484
- end
485
-
486
- add_component "opscode-pushy-client" do |c|
487
- c.gem_base_dir = "opscode-pushy-client"
488
- # TODO the unit tests are currently failing in master
489
- # c.unit_test do
490
- # bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
491
- # sh("#{embedded_bin("bundle")} exec rake spec")
492
- # end
493
-
494
- c.smoke_test do
495
- tmpdir do |cwd|
496
- sh("#{bin("pushy-client")} -v", cwd: cwd)
497
- end
498
- end
499
- end
500
-
501
- # We try and use some chef-sugar code to make sure it loads correctly
502
- add_component "chef-sugar" do |c|
503
- c.gem_base_dir = "chef-sugar"
504
- c.smoke_test do
505
- tmpdir do |cwd|
506
- with_file(File.join(cwd, "foo.rb")) do |f|
507
- f.write <<-EOF
508
- require 'chef/sugar'
509
- log 'something' do
510
- not_if { _64_bit? }
511
- end
512
- EOF
513
- end
514
- sh("chef-apply foo.rb", cwd: cwd)
515
- end
516
- end
517
- end
518
-
519
- attr_reader :verification_threads
520
- attr_reader :verification_results
521
- attr_reader :verification_status
522
-
523
- def initialize
524
- super
525
- @verification_threads = [ ]
526
- @verification_results = [ ]
527
- @verification_status = 0
528
- end
529
-
530
- def run(params = [ ])
531
- err("[WARN] This is an internal command used by the ChefDK development team. If you are a ChefDK user, please do not run it.")
532
- @components_filter = parse_options(params)
533
-
534
- validate_components!
535
- invoke_tests
536
- wait_for_tests
537
- report_results
538
-
539
- verification_status
540
- end
541
-
542
- def omnibus_root
543
- config[:omnibus_dir] || super
544
- end
545
-
546
- def validate_components!
547
- components.each do |component|
548
- component.omnibus_root = omnibus_root
549
- component.assert_present!
550
- end
551
- end
552
-
553
- def components_to_test
554
- if @components_filter.empty?
555
- components
556
- else
557
- components.select do |component|
558
- @components_filter.include?(component.name.to_s)
559
- end
560
- end
561
- end
562
-
563
- def invoke_tests
564
- components_to_test.each do |component|
565
- # Run the component specs in parallel
566
- verification_threads << Thread.new do
567
-
568
- results = []
569
-
570
- results << component.run_smoke_test
571
-
572
- if config[:unit]
573
- results << component.run_unit_test
574
- end
575
-
576
- if config[:integration]
577
- results << component.run_integration_test
578
- end
579
-
580
- if results.any? { |r| r.exitstatus != 0 }
581
- component_status = 1
582
- @verification_status = 1
583
- else
584
- component_status = 0
585
- end
586
-
587
- {
588
- :component => component,
589
- :results => results,
590
- :component_status => component_status,
591
- }
592
- end
593
-
594
- msg("Running verification for component '#{component.name}'")
595
- end
596
- end
597
-
598
- def wait_for_tests
599
- until verification_threads.empty?
600
- verification_threads.each do |t|
601
- if t.join(1)
602
- verification_threads.delete t
603
- verification_results << t.value
604
- t.value[:results].each do |result|
605
- if config[:verbose] || t.value[:component_status] != 0
606
- msg("")
607
- msg(result.stdout)
608
- msg(result.stderr) if result.stderr
609
- end
610
- end
611
- else
612
- $stdout.write "."
613
- end
614
- end
615
- end
616
- end
617
-
618
- def report_results
619
- msg("")
620
- msg("---------------------------------------------")
621
- verification_results.each do |result|
622
- message = result[:component_status] == 0 ? "succeeded" : "failed"
623
- msg("Verification of component '#{result[:component].name}' #{message}.")
624
- end
625
- end
626
-
627
- end
628
- end
629
- end
1
+ #
2
+ # Copyright:: Copyright (c) 2014-2018 Chef Software Inc.
3
+ # License:: Apache License, Version 2.0
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+ #
17
+
18
+ require "chef-dk/command/base"
19
+ require "chef-dk/exceptions"
20
+ require "chef-dk/component_test"
21
+
22
+ module ChefDK
23
+ module Command
24
+ class Verify < ChefDK::Command::Base
25
+
26
+ include ChefDK::Helpers
27
+
28
+ banner "Usage: chef verify [component, ...] [options]"
29
+
30
+ option :omnibus_dir,
31
+ :long => "--omnibus-dir OMNIBUS_DIR",
32
+ :description => "Alternate path to omnibus install (used for testing)"
33
+
34
+ option :unit,
35
+ :long => "--unit",
36
+ :description => "Run bundled app unit tests (only smoke tests run by default)"
37
+
38
+ option :integration,
39
+ :long => "--integration",
40
+ :description => "Run integration tests. Possibly dangerous, for development systems only"
41
+
42
+ option :verbose,
43
+ :long => "--verbose",
44
+ :description => "Display all test output, not just failing tests"
45
+
46
+ class << self
47
+ def add_component(name, _delete_me = nil)
48
+ component = ComponentTest.new(name)
49
+ yield component if block_given? #delete this conditional
50
+ component_map[name] = component
51
+ end
52
+
53
+ def component(name)
54
+ component_map[name]
55
+ end
56
+
57
+ def components
58
+ component_map.values
59
+ end
60
+
61
+ def component_map
62
+ @component_map ||= {}
63
+ end
64
+ end
65
+
66
+ def components
67
+ self.class.components
68
+ end
69
+
70
+ bundle_install_mutex = Mutex.new
71
+
72
+ #
73
+ # Components included in Chef Development kit:
74
+ # :base_dir => Relative path of the component w.r.t. omnibus_apps_dir
75
+ # :gem_base_dir => Takes a gem name instead and uses first gem found
76
+ # :test_cmd => Test command to be launched for the component
77
+ #
78
+ add_component "berkshelf" do |c|
79
+ c.gem_base_dir = "berkshelf"
80
+ # For berks the real command to run is "#{embedded_bin("bundle")} exec thor spec:ci"
81
+ # We can't run it right now since graphviz specs are included in the
82
+ # test suite by default. We will be able to switch to that command when/if
83
+ # Graphviz is added to omnibus.
84
+ c.unit_test do
85
+ bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
86
+ sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} --color --format progress spec/unit --tag ~graphviz")
87
+ end
88
+ c.integration_test do
89
+ bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
90
+ sh("#{embedded_bin("bundle")} exec #{embedded_bin("cucumber")} --color --format progress --tags ~@no_run --tags ~@spawn --tags ~@graphviz --strict")
91
+ end
92
+
93
+ c.smoke_test do
94
+ tmpdir do |cwd|
95
+ FileUtils.touch(File.join(cwd, "Berksfile"))
96
+ sh("#{bin("berks")} install", cwd: cwd)
97
+ end
98
+ end
99
+ end
100
+
101
+ add_component "test-kitchen" do |c|
102
+ c.gem_base_dir = "test-kitchen"
103
+ c.unit_test do
104
+ bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
105
+ sh("#{embedded_bin("bundle")} exec rake unit")
106
+ end
107
+ c.integration_test do
108
+ bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
109
+ sh("#{embedded_bin("bundle")} exec rake features")
110
+ end
111
+
112
+ # NOTE: By default, kitchen tries to be helpful and install a driver
113
+ # gem for you. This causes a race condition when running the tests
114
+ # concurrently, because rubygems breaks when there are partially
115
+ # installed gems in the gem repository. Instructing kitchen to create a
116
+ # gemfile instead avoids the gem installation.
117
+ c.smoke_test { run_in_tmpdir("kitchen init --create-gemfile") }
118
+ end
119
+
120
+ add_component "tk-policyfile-provisioner" do |c|
121
+
122
+ c.gem_base_dir = "chef-dk"
123
+
124
+ c.smoke_test do
125
+ tmpdir do |cwd|
126
+ File.open(File.join(cwd, ".kitchen.yml"), "w+") do |f|
127
+ f.print(<<-KITCHEN_YML)
128
+ ---
129
+ driver:
130
+ name: dummy
131
+ network:
132
+ - ["forwarded_port", {guest: 80, host: 8080}]
133
+
134
+ provisioner:
135
+ name: policyfile_zero
136
+ require_chef_omnibus: 12.3.0
137
+
138
+ platforms:
139
+ - name: ubuntu-14.04
140
+
141
+ suites:
142
+ - name: default
143
+ run_list:
144
+ - recipe[aar::default]
145
+ attributes:
146
+
147
+ KITCHEN_YML
148
+ end
149
+
150
+ sh("kitchen list", cwd: cwd)
151
+
152
+ end
153
+ end
154
+
155
+ end
156
+
157
+ add_component "chef-client" do |c|
158
+ c.gem_base_dir = "chef"
159
+ c.unit_test do
160
+ bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
161
+ sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} -fp -t '~volatile_from_verify' spec/unit")
162
+ end
163
+ c.integration_test do
164
+ bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
165
+ sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} -fp spec/integration spec/functional")
166
+ end
167
+
168
+ c.smoke_test do
169
+ tmpdir do |cwd|
170
+ FileUtils.touch(File.join(cwd, "apply.rb"))
171
+ sh("#{bin("chef-apply")} apply.rb", cwd: cwd)
172
+ end
173
+ end
174
+ end
175
+
176
+ add_component "chef-dk" do |c|
177
+ c.gem_base_dir = "chef-dk"
178
+ c.unit_test do
179
+ bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
180
+ sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")}")
181
+ end
182
+ c.smoke_test do
183
+ run_in_tmpdir("#{bin("chef")} generate cookbook example")
184
+ end
185
+ end
186
+
187
+ # entirely possible this needs to be driven by a utility method in chef-provisioning.
188
+ add_component "chef-provisioning" do |c|
189
+ c.gem_base_dir = "chef-dk"
190
+
191
+ c.smoke_test do
192
+ # ------------
193
+ # we want to avoid hard-coding driver names, but calling Gem::Specification produces a warning;
194
+ # changing $VERBOSE seems to be the best way to silence it.
195
+ verbose = $VERBOSE
196
+ $VERBOSE = nil
197
+
198
+ # construct a hash of { driver_name => [version1, version2, ...]}
199
+ driver_versions = {}
200
+ Gem::Specification.all.map { |gs| [gs.name, gs.version] }.
201
+ select { |n| n[0] =~ /^chef-provisioning-/ }.
202
+ each { |gem, version| (driver_versions[gem] ||= []) << version }
203
+
204
+ drivers = Gem::Specification.all.map { |gs| gs.name }.
205
+ select { |n| n =~ /^chef-provisioning-/ }.
206
+ uniq
207
+
208
+ versions = Gem::Specification.find_all_by_name("chef-provisioning").map { |s| s.version }
209
+ $VERBOSE = verbose
210
+ # ------------
211
+ failures = []
212
+
213
+ # ------------
214
+ # fail the verify if we have more than one version of chef-provisioning or any of its drivers.
215
+ def format_gem_failure(name, versions)
216
+ <<-EOS
217
+ #{name} has multiple versions installed:
218
+ #{versions.sort.map { |gv| " #{gv}" }.join("\n")}
219
+ EOS
220
+ end
221
+
222
+ failures << format_gem_failure("chef-provisioning", versions) if versions.size > 1
223
+
224
+ driver_versions.keys.sort.each do |driver_name|
225
+ v = driver_versions[driver_name]
226
+ failures << format_gem_failure(driver_name, v) if v.size > 1
227
+ end
228
+
229
+ if failures.size > 0
230
+ failures << <<-EOS
231
+
232
+ Some applications may need or prefer different versions of the chef-provisioning gem or its drivers, so
233
+ this multiple-version check can fail if a user has installed new versions of those libraries.
234
+ EOS
235
+ end
236
+
237
+ # ------------
238
+ # load the core gem and all of the drivers (ignoring versions).
239
+ require "chef/provisioning"
240
+ drivers.map { |d| "#{d.tr('-', '/')}_driver" }.each do |driver_gem|
241
+ begin
242
+ begin
243
+ require driver_gem
244
+ rescue LoadError
245
+ # anomalously, chef-provisioning-fog does not have a fog_driver.rb. (9/2015)
246
+ require "#{driver_gem}/driver.rb"
247
+ end
248
+ rescue LoadError => ex
249
+ puts ex
250
+ end
251
+ end
252
+
253
+ # ------------
254
+ # look for version dependency conflicts.
255
+ tmpdir do |cwd|
256
+ versions.each do |provisioning_version|
257
+ gemfile = "chef-provisioning-#{provisioning_version}-chefdk-test.gemfile"
258
+
259
+ # write out the gemfile for this chef-provisioning version, and see if Bundler can make it go.
260
+ with_file(File.join(cwd, gemfile)) do |f|
261
+ f.puts %Q{gem "chef-provisioning", "= #{provisioning_version}"}
262
+ drivers.each { |d| f.puts %Q{gem "#{d}"} }
263
+ end
264
+
265
+ result = bundle_install_mutex.synchronize do
266
+ sh("#{embedded_bin("bundle")} install --local --quiet", cwd: cwd, env: { "BUNDLE_GEMFILE" => gemfile })
267
+ end
268
+
269
+ if result.exitstatus != 0
270
+ failures << result.stdout
271
+ end
272
+ end # end provisioning versions.
273
+
274
+ failures.each { |fail| puts fail }
275
+
276
+ # dubious on Windows.
277
+ # this is weird, but we seem to require a Mixlib::ShellOut as the return value. suggestions
278
+ # welcome.
279
+ sh(failures.size > 0 ? "false" : "true")
280
+ end
281
+ end
282
+ end
283
+
284
+ add_component "chefspec" do |c|
285
+ c.gem_base_dir = "chefspec"
286
+ c.unit_test do
287
+ bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
288
+ sh("#{embedded_bin("bundle")} exec #{embedded_bin("rake")} unit")
289
+ end
290
+ c.smoke_test do
291
+ tmpdir do |cwd|
292
+ FileUtils.mkdir(File.join(cwd, "spec"))
293
+ with_file(File.join(cwd, "spec", "spec_helper.rb")) do |f|
294
+ f.write <<-EOF
295
+ require 'chefspec'
296
+ require 'chefspec/berkshelf'
297
+ require 'chefspec/cacher'
298
+
299
+ RSpec.configure do |config|
300
+ config.expect_with(:rspec) { |c| c.syntax = :expect }
301
+ end
302
+ EOF
303
+ end
304
+ FileUtils.touch(File.join(cwd, "Berksfile"))
305
+ with_file(File.join(cwd, "spec", "foo_spec.rb")) do |f|
306
+ f.write <<-EOF
307
+ require 'spec_helper'
308
+ EOF
309
+ end
310
+ sh(embedded_bin("rspec"), cwd: cwd)
311
+ end
312
+ end
313
+ end
314
+
315
+ add_component "generated-cookbooks-pass-chefspec" do |c|
316
+
317
+ c.gem_base_dir = "chef-dk"
318
+ c.smoke_test do
319
+ tmpdir do |cwd|
320
+ sh("#{bin("chef")} generate cookbook example", cwd: cwd)
321
+ cb_cwd = File.join(cwd, "example")
322
+ sh(embedded_bin("rspec"), cwd: cb_cwd)
323
+ end
324
+ end
325
+ end
326
+
327
+ add_component "fauxhai" do |c|
328
+ c.gem_base_dir = "fauxhai"
329
+ c.smoke_test { sh("#{embedded_bin("gem")} list fauxhai") }
330
+ end
331
+
332
+ add_component "knife-spork" do |c|
333
+ c.gem_base_dir = "knife-spork"
334
+ c.smoke_test { sh("#{bin("knife")} spork info") }
335
+ end
336
+
337
+ add_component "kitchen-vagrant" do |c|
338
+ c.gem_base_dir = "kitchen-vagrant"
339
+ # The build is not passing in travis, so no tests
340
+ c.smoke_test { sh("#{embedded_bin("gem")} list kitchen-vagrant") }
341
+ end
342
+
343
+ add_component "package installation" do |c|
344
+
345
+ c.gem_base_dir = "chef-dk"
346
+
347
+ c.smoke_test do
348
+
349
+ if File.directory?(usr_bin_prefix)
350
+ sh!("#{usr_bin_path("berks")} -v")
351
+ sh!("#{usr_bin_path("chef")} -v")
352
+ sh!("#{usr_bin_path("chef-client")} -v")
353
+ sh!("#{usr_bin_path("chef-solo")} -v")
354
+ sh!("#{usr_bin_path("delivery")} -V") unless Chef::Platform.windows?
355
+
356
+ # In `knife`, `knife -v` follows a different code path that skips
357
+ # command/plugin loading; `knife -h` loads commands and plugins, but
358
+ # it exits with code 1, which is the same as a load error. Running
359
+ # `knife exec` forces command loading to happen and this command
360
+ # exits 0, which runs most of the code.
361
+ #
362
+ # See also: https://github.com/chef/chef-dk/issues/227
363
+ sh!("#{usr_bin_path("knife")} exec -E true")
364
+
365
+ tmpdir do |dir|
366
+ # Kitchen tries to create a .kitchen dir even when just running
367
+ # `kitchen -v`:
368
+ sh!("#{usr_bin_path("kitchen")} -v", cwd: dir)
369
+ end
370
+
371
+ sh!("#{usr_bin_path("ohai")} -v")
372
+ sh!("#{usr_bin_path("foodcritic")} -V")
373
+ sh!("#{usr_bin_path("inspec")} version")
374
+ end
375
+
376
+ # Test blocks are expected to return a Mixlib::ShellOut compatible
377
+ # object:
378
+ ComponentTest::NullTestResult.new
379
+ end
380
+ end
381
+
382
+ add_component "openssl" do |c|
383
+ # https://github.com/chef/chef-dk/issues/420
384
+ c.gem_base_dir = "chef"
385
+
386
+ test = <<-EOF.gsub(/^\s+/, "")
387
+ require "net/http"
388
+
389
+ uris = %w{https://www.google.com https://chef.io/ https://ec2.amazonaws.com}
390
+ uris.each do |uri|
391
+ uri = URI(uri)
392
+ puts "Fetching \#{uri} for SSL check"
393
+ Net::HTTP.get uri
394
+ end
395
+ EOF
396
+
397
+ c.unit_test do
398
+ tmpdir do |cwd|
399
+ with_file(File.join(cwd, "openssl.rb")) do |f|
400
+ f.write test
401
+ end
402
+ sh!("#{Gem.ruby} openssl.rb", cwd: cwd)
403
+ end
404
+ end
405
+ end
406
+
407
+ add_component "inspec" do |c|
408
+ c.gem_base_dir = "inspec"
409
+
410
+ # Commenting out the unit and integration tests for now until we figure
411
+ # out the bundler error
412
+ #c.unit_test { sh("#{embedded_bin("bundle")} exec rake test:isolated") }
413
+ # This runs Test Kitchen (using kitchen-inspec) with some inspec tests
414
+ #c.integration_test { sh("#{embedded_bin("bundle")} exec rake test:vm") }
415
+
416
+ # It would be nice to use a chef generator to create these specs, but
417
+ # we dont have that yet. So we do it manually.
418
+ c.smoke_test do
419
+ tmpdir do |cwd|
420
+ File.open(File.join(cwd, "some_spec.rb"), "w+") do |f|
421
+ f.print <<-INSPEC_TEST
422
+ rule '01' do
423
+ impact 0.7
424
+ title 'Some Test'
425
+ desc 'Make sure inspec is installed and loading correct'
426
+ describe 1 do
427
+ it { should eq(1) }
428
+ end
429
+ end
430
+ INSPEC_TEST
431
+ end
432
+ # TODO when we appbundle inspec, no longer `chef exec`
433
+ sh("#{bin("chef")} exec #{embedded_bin("inspec")} exec .", cwd: cwd)
434
+ end
435
+ end
436
+ end
437
+
438
+ add_component "delivery-cli" do |c|
439
+ # We'll want to come back and revisit getting unit tests added -
440
+ # currently running the tests depends on cargo , which is not included
441
+ # in our package.
442
+ c.base_dir = "bin"
443
+ c.smoke_test do
444
+ tmpdir do |cwd|
445
+ sh!("delivery setup --user=shipit --server=delivery.shipit.io --ent=chef --org=squirrels", cwd: cwd)
446
+ end
447
+ end
448
+ end
449
+
450
+ if Chef::Platform.windows?
451
+ add_component "git" do |c|
452
+ c.base_dir = "embedded/bin"
453
+ c.smoke_test do
454
+ tmpdir do |cwd|
455
+ sh!("#{embedded_bin("git")} config -l")
456
+ sh!("#{embedded_bin("git")} clone https://github.com/chef/chef-provisioning", cwd: cwd)
457
+ end
458
+ end
459
+ end
460
+ else
461
+ add_component "git" do |c|
462
+ c.base_dir = "gitbin"
463
+ c.smoke_test do
464
+ tmpdir do |cwd|
465
+ sh!("#{File.join(omnibus_root, "gitbin", "git")} config -l")
466
+ sh!("#{File.join(omnibus_root, "gitbin", "git")} clone https://github.com/chef/chef-provisioning", cwd: cwd)
467
+
468
+ # If /usr/bin/git is a symlink, fail the test.
469
+ # Note that this test cannot go last because it does not return a
470
+ # Mixlib::Shellout object in the windows case, which will break the tests.
471
+ failure_str = "#{nix_platform_native_bin_dir}/git contains a symlink which might mean we accidentally overwrote system git via chefdk."
472
+ result = sh("readlink #{nix_platform_native_bin_dir}/git")
473
+ # if a symlink was found, test to see if it is in a chefdk install
474
+ if result.status.exitstatus == 0
475
+ raise failure_str if result.stdout =~ /chefdk/
476
+ end
477
+
478
+ # <chef_dk>/bin/ should not contain a git binary.
479
+ failure_str = "`<chef_dk>/bin/git --help` should fail as git should be installed in gitbin"
480
+ fail_if_exit_zero("#{bin("git")} --help", failure_str)
481
+ end
482
+ end
483
+ end
484
+ end
485
+
486
+ add_component "opscode-pushy-client" do |c|
487
+ c.gem_base_dir = "opscode-pushy-client"
488
+ # TODO the unit tests are currently failing in master
489
+ # c.unit_test do
490
+ # bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
491
+ # sh("#{embedded_bin("bundle")} exec rake spec")
492
+ # end
493
+
494
+ c.smoke_test do
495
+ tmpdir do |cwd|
496
+ sh("#{bin("pushy-client")} -v", cwd: cwd)
497
+ end
498
+ end
499
+ end
500
+
501
+ # We try and use some chef-sugar code to make sure it loads correctly
502
+ add_component "chef-sugar" do |c|
503
+ c.gem_base_dir = "chef-sugar"
504
+ c.smoke_test do
505
+ tmpdir do |cwd|
506
+ with_file(File.join(cwd, "foo.rb")) do |f|
507
+ f.write <<-EOF
508
+ require 'chef/sugar'
509
+ log 'something' do
510
+ not_if { _64_bit? }
511
+ end
512
+ EOF
513
+ end
514
+ sh("chef-apply foo.rb", cwd: cwd)
515
+ end
516
+ end
517
+ end
518
+
519
+ attr_reader :verification_threads
520
+ attr_reader :verification_results
521
+ attr_reader :verification_status
522
+
523
+ def initialize
524
+ super
525
+ @verification_threads = [ ]
526
+ @verification_results = [ ]
527
+ @verification_status = 0
528
+ end
529
+
530
+ def run(params = [ ])
531
+ err("[WARN] This is an internal command used by the ChefDK development team. If you are a ChefDK user, please do not run it.")
532
+ @components_filter = parse_options(params)
533
+
534
+ validate_components!
535
+ invoke_tests
536
+ wait_for_tests
537
+ report_results
538
+
539
+ verification_status
540
+ end
541
+
542
+ def omnibus_root
543
+ config[:omnibus_dir] || super
544
+ end
545
+
546
+ def validate_components!
547
+ components.each do |component|
548
+ component.omnibus_root = omnibus_root
549
+ component.assert_present!
550
+ end
551
+ end
552
+
553
+ def components_to_test
554
+ if @components_filter.empty?
555
+ components
556
+ else
557
+ components.select do |component|
558
+ @components_filter.include?(component.name.to_s)
559
+ end
560
+ end
561
+ end
562
+
563
+ def invoke_tests
564
+ components_to_test.each do |component|
565
+ # Run the component specs in parallel
566
+ verification_threads << Thread.new do
567
+
568
+ results = []
569
+
570
+ results << component.run_smoke_test
571
+
572
+ if config[:unit]
573
+ results << component.run_unit_test
574
+ end
575
+
576
+ if config[:integration]
577
+ results << component.run_integration_test
578
+ end
579
+
580
+ if results.any? { |r| r.exitstatus != 0 }
581
+ component_status = 1
582
+ @verification_status = 1
583
+ else
584
+ component_status = 0
585
+ end
586
+
587
+ {
588
+ :component => component,
589
+ :results => results,
590
+ :component_status => component_status,
591
+ }
592
+ end
593
+
594
+ msg("Running verification for component '#{component.name}'")
595
+ end
596
+ end
597
+
598
+ def wait_for_tests
599
+ until verification_threads.empty?
600
+ verification_threads.each do |t|
601
+ if t.join(1)
602
+ verification_threads.delete t
603
+ verification_results << t.value
604
+ t.value[:results].each do |result|
605
+ if config[:verbose] || t.value[:component_status] != 0
606
+ msg("")
607
+ msg(result.stdout)
608
+ msg(result.stderr) if result.stderr
609
+ end
610
+ end
611
+ else
612
+ $stdout.write "."
613
+ end
614
+ end
615
+ end
616
+ end
617
+
618
+ def report_results
619
+ msg("")
620
+ msg("---------------------------------------------")
621
+ verification_results.each do |result|
622
+ message = result[:component_status] == 0 ? "succeeded" : "failed"
623
+ msg("Verification of component '#{result[:component].name}' #{message}.")
624
+ end
625
+ end
626
+
627
+ end
628
+ end
629
+ end