chef-dk 0.11.2 → 0.12.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 (325) hide show
  1. checksums.yaml +4 -4
  2. data/CONTRIBUTING.md +186 -190
  3. data/Gemfile +30 -26
  4. data/LICENSE +201 -201
  5. data/README.md +307 -307
  6. data/Rakefile +29 -27
  7. data/acceptance/.shared/kitchen_acceptance/.kitchen.digitalocean.yml +27 -0
  8. data/acceptance/.shared/kitchen_acceptance/.kitchen.ec2.yml +284 -0
  9. data/acceptance/.shared/kitchen_acceptance/.kitchen.vagrant.yml +52 -0
  10. data/acceptance/.shared/kitchen_acceptance/libraries/kitchen.rb +51 -0
  11. data/acceptance/.shared/kitchen_acceptance/metadata.rb +1 -0
  12. data/acceptance/Gemfile +11 -0
  13. data/acceptance/README.md +132 -0
  14. data/acceptance/trivial/.acceptance/acceptance-cookbook/.gitignore +2 -0
  15. data/acceptance/trivial/.acceptance/acceptance-cookbook/metadata.rb +2 -0
  16. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -0
  17. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -0
  18. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -0
  19. data/acceptance/trivial/.kitchen.yml +7 -0
  20. data/acceptance/trivial/test/integration/chefdk-current-install/inspec/chef_client_spec.rb +5 -0
  21. data/bin/chef +25 -25
  22. data/chef-dk.gemspec +64 -64
  23. data/lib/chef-dk.rb +19 -19
  24. data/lib/chef-dk/authenticated_http.rb +40 -40
  25. data/lib/chef-dk/builtin_commands.rb +60 -60
  26. data/lib/chef-dk/chef_runner.rb +107 -107
  27. data/lib/chef-dk/cli.rb +200 -200
  28. data/lib/chef-dk/command/base.rb +79 -79
  29. data/lib/chef-dk/command/clean_policy_cookbooks.rb +116 -116
  30. data/lib/chef-dk/command/clean_policy_revisions.rb +113 -113
  31. data/lib/chef-dk/command/delete_policy.rb +122 -122
  32. data/lib/chef-dk/command/delete_policy_group.rb +122 -122
  33. data/lib/chef-dk/command/diff.rb +316 -316
  34. data/lib/chef-dk/command/env.rb +90 -90
  35. data/lib/chef-dk/command/exec.rb +45 -45
  36. data/lib/chef-dk/command/export.rb +157 -157
  37. data/lib/chef-dk/command/gem.rb +47 -47
  38. data/lib/chef-dk/command/generate.rb +120 -120
  39. data/lib/chef-dk/command/generator_commands.rb +80 -80
  40. data/lib/chef-dk/command/generator_commands/app.rb +107 -107
  41. data/lib/chef-dk/command/generator_commands/attribute.rb +37 -37
  42. data/lib/chef-dk/command/generator_commands/base.rb +148 -148
  43. data/lib/chef-dk/command/generator_commands/cookbook.rb +153 -153
  44. data/lib/chef-dk/command/generator_commands/cookbook_code_file.rb +100 -100
  45. data/lib/chef-dk/command/generator_commands/cookbook_file.rb +45 -45
  46. data/lib/chef-dk/command/generator_commands/generator_generator.rb +177 -177
  47. data/lib/chef-dk/command/generator_commands/lwrp.rb +36 -36
  48. data/lib/chef-dk/command/generator_commands/policyfile.rb +127 -127
  49. data/lib/chef-dk/command/generator_commands/recipe.rb +36 -36
  50. data/lib/chef-dk/command/generator_commands/repo.rb +125 -125
  51. data/lib/chef-dk/command/generator_commands/template.rb +46 -46
  52. data/lib/chef-dk/command/install.rb +121 -121
  53. data/lib/chef-dk/command/provision.rb +438 -438
  54. data/lib/chef-dk/command/push.rb +118 -118
  55. data/lib/chef-dk/command/push_archive.rb +126 -126
  56. data/lib/chef-dk/command/shell_init.rb +180 -180
  57. data/lib/chef-dk/command/show_policy.rb +165 -165
  58. data/lib/chef-dk/command/undelete.rb +155 -155
  59. data/lib/chef-dk/command/update.rb +148 -148
  60. data/lib/chef-dk/command/verify.rb +534 -534
  61. data/lib/chef-dk/commands_map.rb +115 -115
  62. data/lib/chef-dk/completions/bash.sh.erb +5 -5
  63. data/lib/chef-dk/completions/chef.fish.erb +10 -10
  64. data/lib/chef-dk/completions/zsh.zsh.erb +21 -21
  65. data/lib/chef-dk/component_test.rb +194 -173
  66. data/lib/chef-dk/configurable.rb +69 -69
  67. data/lib/chef-dk/cookbook_metadata.rb +45 -45
  68. data/lib/chef-dk/cookbook_omnifetch.rb +32 -32
  69. data/lib/chef-dk/cookbook_profiler/git.rb +151 -151
  70. data/lib/chef-dk/cookbook_profiler/identifiers.rb +72 -72
  71. data/lib/chef-dk/cookbook_profiler/null_scm.rb +32 -32
  72. data/lib/chef-dk/exceptions.rb +129 -129
  73. data/lib/chef-dk/generator.rb +163 -163
  74. data/lib/chef-dk/helpers.rb +159 -159
  75. data/lib/chef-dk/pager.rb +106 -106
  76. data/lib/chef-dk/policyfile/chef_repo_cookbook_source.rb +138 -138
  77. data/lib/chef-dk/policyfile/chef_server_cookbook_source.rb +54 -54
  78. data/lib/chef-dk/policyfile/community_cookbook_source.rb +97 -97
  79. data/lib/chef-dk/policyfile/comparison_base.rb +124 -124
  80. data/lib/chef-dk/policyfile/cookbook_location_specification.rb +154 -154
  81. data/lib/chef-dk/policyfile/cookbook_locks.rb +466 -466
  82. data/lib/chef-dk/policyfile/cookbook_sources.rb +22 -22
  83. data/lib/chef-dk/policyfile/delivery_supermarket_source.rb +90 -90
  84. data/lib/chef-dk/policyfile/differ.rb +266 -266
  85. data/lib/chef-dk/policyfile/dsl.rb +261 -261
  86. data/lib/chef-dk/policyfile/lister.rb +232 -232
  87. data/lib/chef-dk/policyfile/null_cookbook_source.rb +45 -45
  88. data/lib/chef-dk/policyfile/read_cookbook_for_compat_mode_upload.rb +124 -124
  89. data/lib/chef-dk/policyfile/reports/install.rb +70 -70
  90. data/lib/chef-dk/policyfile/reports/table_printer.rb +58 -58
  91. data/lib/chef-dk/policyfile/reports/upload.rb +70 -70
  92. data/lib/chef-dk/policyfile/solution_dependencies.rb +298 -298
  93. data/lib/chef-dk/policyfile/storage_config.rb +100 -100
  94. data/lib/chef-dk/policyfile/undo_record.rb +142 -142
  95. data/lib/chef-dk/policyfile/undo_stack.rb +130 -130
  96. data/lib/chef-dk/policyfile/uploader.rb +213 -213
  97. data/lib/chef-dk/policyfile_compiler.rb +419 -419
  98. data/lib/chef-dk/policyfile_lock.rb +552 -552
  99. data/lib/chef-dk/policyfile_services/clean_policies.rb +95 -95
  100. data/lib/chef-dk/policyfile_services/clean_policy_cookbooks.rb +125 -125
  101. data/lib/chef-dk/policyfile_services/export_repo.rb +421 -414
  102. data/lib/chef-dk/policyfile_services/install.rb +126 -126
  103. data/lib/chef-dk/policyfile_services/push.rb +114 -114
  104. data/lib/chef-dk/policyfile_services/push_archive.rb +204 -204
  105. data/lib/chef-dk/policyfile_services/rm_policy.rb +142 -142
  106. data/lib/chef-dk/policyfile_services/rm_policy_group.rb +86 -86
  107. data/lib/chef-dk/policyfile_services/show_policy.rb +237 -237
  108. data/lib/chef-dk/policyfile_services/undelete.rb +108 -108
  109. data/lib/chef-dk/policyfile_services/update_attributes.rb +104 -104
  110. data/lib/chef-dk/service_exception_inspectors.rb +25 -25
  111. data/lib/chef-dk/service_exception_inspectors/base.rb +40 -40
  112. data/lib/chef-dk/service_exception_inspectors/http.rb +121 -121
  113. data/lib/chef-dk/service_exceptions.rb +143 -143
  114. data/lib/chef-dk/shell_out.rb +36 -36
  115. data/lib/chef-dk/skeletons/code_generator/files/default/Berksfile +3 -3
  116. data/lib/chef-dk/skeletons/code_generator/files/default/chefignore +102 -102
  117. data/lib/chef-dk/skeletons/code_generator/files/default/cookbook_readmes/README-policy.md +9 -9
  118. data/lib/chef-dk/skeletons/code_generator/files/default/cookbook_readmes/README.md +54 -54
  119. data/lib/chef-dk/skeletons/code_generator/files/default/gitignore +16 -16
  120. data/lib/chef-dk/skeletons/code_generator/files/default/repo/README.md +28 -28
  121. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/README.md +27 -27
  122. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/attributes/default.rb +7 -7
  123. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/metadata.rb +3 -3
  124. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/recipes/default.rb +8 -8
  125. data/lib/chef-dk/skeletons/code_generator/files/default/repo/data_bags/README.md +58 -58
  126. data/lib/chef-dk/skeletons/code_generator/files/default/repo/data_bags/example/example_item.json +3 -3
  127. data/lib/chef-dk/skeletons/code_generator/files/default/repo/dot-chef-repo.txt +6 -6
  128. data/lib/chef-dk/skeletons/code_generator/files/default/repo/environments/README.md +9 -9
  129. data/lib/chef-dk/skeletons/code_generator/files/default/repo/environments/example.json +12 -12
  130. data/lib/chef-dk/skeletons/code_generator/files/default/repo/policies/README.md +24 -24
  131. data/lib/chef-dk/skeletons/code_generator/files/default/repo/roles/README.md +9 -9
  132. data/lib/chef-dk/skeletons/code_generator/files/default/repo/roles/example.json +12 -12
  133. data/lib/chef-dk/skeletons/code_generator/files/default/serverspec_spec_helper.rb +8 -8
  134. data/lib/chef-dk/skeletons/code_generator/files/default/spec_helper.rb +2 -2
  135. data/lib/chef-dk/skeletons/code_generator/files/default/spec_helper_policyfile.rb +2 -2
  136. data/lib/chef-dk/skeletons/code_generator/metadata.rb +8 -8
  137. data/lib/chef-dk/skeletons/code_generator/recipes/app.rb +97 -97
  138. data/lib/chef-dk/skeletons/code_generator/recipes/attribute.rb +12 -12
  139. data/lib/chef-dk/skeletons/code_generator/recipes/cookbook.rb +117 -117
  140. data/lib/chef-dk/skeletons/code_generator/recipes/cookbook_file.rb +24 -24
  141. data/lib/chef-dk/skeletons/code_generator/recipes/lwrp.rb +23 -23
  142. data/lib/chef-dk/skeletons/code_generator/recipes/policyfile.rb +8 -8
  143. data/lib/chef-dk/skeletons/code_generator/recipes/recipe.rb +27 -27
  144. data/lib/chef-dk/skeletons/code_generator/recipes/repo.rb +67 -67
  145. data/lib/chef-dk/skeletons/code_generator/recipes/template.rb +32 -32
  146. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.all_rights.erb +3 -3
  147. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.apache2.erb +201 -201
  148. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.gplv2.erb +339 -339
  149. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.gplv3.erb +674 -674
  150. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.mit.erb +21 -21
  151. data/lib/chef-dk/skeletons/code_generator/templates/default/Policyfile.rb.erb +25 -25
  152. data/lib/chef-dk/skeletons/code_generator/templates/default/README.md.erb +4 -4
  153. data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen.yml.erb +21 -21
  154. data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen_policyfile.yml.erb +32 -32
  155. data/lib/chef-dk/skeletons/code_generator/templates/default/metadata.rb.erb +7 -7
  156. data/lib/chef-dk/skeletons/code_generator/templates/default/recipe.rb.erb +5 -5
  157. data/lib/chef-dk/skeletons/code_generator/templates/default/recipe_spec.rb.erb +20 -20
  158. data/lib/chef-dk/skeletons/code_generator/templates/default/repo/gitignore.erb +11 -11
  159. data/lib/chef-dk/skeletons/code_generator/templates/default/serverspec_default_spec.rb.erb +9 -9
  160. data/lib/chef-dk/ui.rb +58 -58
  161. data/lib/chef-dk/version.rb +20 -20
  162. data/lib/kitchen/provisioner/policyfile_zero.rb +194 -194
  163. data/spec/shared/a_file_generator.rb +125 -125
  164. data/spec/shared/a_generated_file.rb +12 -12
  165. data/spec/shared/command_with_ui_object.rb +11 -11
  166. data/spec/shared/custom_generator_cookbook.rb +130 -130
  167. data/spec/shared/fixture_cookbook_checksums.rb +47 -47
  168. data/spec/shared/setup_git_cookbooks.rb +53 -53
  169. data/spec/spec_helper.rb +51 -50
  170. data/spec/test_helpers.rb +84 -84
  171. data/spec/unit/chef_runner_spec.rb +139 -139
  172. data/spec/unit/cli_spec.rb +357 -357
  173. data/spec/unit/command/base_spec.rb +169 -169
  174. data/spec/unit/command/clean_policy_cookbooks_spec.rb +181 -181
  175. data/spec/unit/command/clean_policy_revisions_spec.rb +181 -181
  176. data/spec/unit/command/delete_policy_group_spec.rb +207 -207
  177. data/spec/unit/command/delete_policy_spec.rb +207 -207
  178. data/spec/unit/command/diff_spec.rb +312 -312
  179. data/spec/unit/command/env_spec.rb +52 -52
  180. data/spec/unit/command/exec_spec.rb +179 -179
  181. data/spec/unit/command/export_spec.rb +200 -200
  182. data/spec/unit/command/generate_spec.rb +142 -142
  183. data/spec/unit/command/generator_commands/app_spec.rb +169 -169
  184. data/spec/unit/command/generator_commands/attribute_spec.rb +32 -32
  185. data/spec/unit/command/generator_commands/base_spec.rb +136 -136
  186. data/spec/unit/command/generator_commands/cookbook_file_spec.rb +32 -32
  187. data/spec/unit/command/generator_commands/cookbook_spec.rb +450 -450
  188. data/spec/unit/command/generator_commands/generator_generator_spec.rb +229 -229
  189. data/spec/unit/command/generator_commands/lwrp_spec.rb +32 -32
  190. data/spec/unit/command/generator_commands/policyfile_spec.rb +225 -225
  191. data/spec/unit/command/generator_commands/recipe_spec.rb +34 -34
  192. data/spec/unit/command/generator_commands/repo_spec.rb +367 -367
  193. data/spec/unit/command/generator_commands/template_spec.rb +32 -32
  194. data/spec/unit/command/install_spec.rb +179 -179
  195. data/spec/unit/command/provision_spec.rb +592 -592
  196. data/spec/unit/command/push_archive_spec.rb +153 -153
  197. data/spec/unit/command/push_spec.rb +199 -199
  198. data/spec/unit/command/shell_init_spec.rb +329 -329
  199. data/spec/unit/command/show_policy_spec.rb +235 -235
  200. data/spec/unit/command/undelete_spec.rb +246 -246
  201. data/spec/unit/command/update_spec.rb +275 -275
  202. data/spec/unit/command/verify_spec.rb +325 -325
  203. data/spec/unit/commands_map_spec.rb +57 -57
  204. data/spec/unit/component_test_spec.rb +126 -126
  205. data/spec/unit/configurable_spec.rb +41 -41
  206. data/spec/unit/cookbook_metadata_spec.rb +98 -98
  207. data/spec/unit/cookbook_profiler/git_spec.rb +176 -176
  208. data/spec/unit/cookbook_profiler/identifiers_spec.rb +83 -83
  209. data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_one.rb +9 -9
  210. data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_two.rb +9 -9
  211. data/spec/unit/fixtures/command/cli_test_command.rb +26 -26
  212. data/spec/unit/fixtures/command/explicit_path_example.rb +7 -7
  213. data/spec/unit/fixtures/configurable/test_config_loader.rb +5 -5
  214. data/spec/unit/fixtures/configurable/test_configurable.rb +10 -10
  215. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -16
  216. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/Berksfile +3 -3
  217. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -4
  218. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/chefignore +96 -96
  219. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -8
  220. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -8
  221. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/.kitchen.yml +16 -16
  222. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/Berksfile +3 -3
  223. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/README.md +4 -4
  224. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/chefignore +96 -96
  225. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/metadata.rb +8 -8
  226. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/recipes/default.rb +8 -8
  227. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/.kitchen.yml +16 -16
  228. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/Berksfile +3 -3
  229. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/README.md +4 -4
  230. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/chefignore +96 -96
  231. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/metadata.rb +8 -8
  232. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/recipes/default.rb +8 -8
  233. data/spec/unit/fixtures/cookbooks_api/pruned_small_universe.json +1321 -1321
  234. data/spec/unit/fixtures/cookbooks_api/small_universe.json +2987 -2987
  235. data/spec/unit/fixtures/cookbooks_api/universe.json +1 -1
  236. data/spec/unit/fixtures/cookbooks_api/update_fixtures.rb +36 -36
  237. data/spec/unit/fixtures/dev_cookbooks/README.md +16 -16
  238. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/integration_test +2 -2
  239. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/verify_me +5 -5
  240. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/chef/verify_me +3 -3
  241. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/test-kitchen/verify_me +2 -2
  242. data/spec/unit/fixtures/example_cookbook/.gitignore +17 -17
  243. data/spec/unit/fixtures/example_cookbook/.kitchen.yml +16 -16
  244. data/spec/unit/fixtures/example_cookbook/Berksfile +3 -3
  245. data/spec/unit/fixtures/example_cookbook/README.md +4 -4
  246. data/spec/unit/fixtures/example_cookbook/chefignore +96 -96
  247. data/spec/unit/fixtures/example_cookbook/metadata.rb +8 -8
  248. data/spec/unit/fixtures/example_cookbook/recipes/default.rb +8 -8
  249. data/spec/unit/fixtures/example_cookbook_metadata_json_only/.gitignore +17 -17
  250. data/spec/unit/fixtures/example_cookbook_metadata_json_only/.kitchen.yml +16 -16
  251. data/spec/unit/fixtures/example_cookbook_metadata_json_only/Berksfile +3 -3
  252. data/spec/unit/fixtures/example_cookbook_metadata_json_only/README.md +4 -4
  253. data/spec/unit/fixtures/example_cookbook_metadata_json_only/chefignore +96 -96
  254. data/spec/unit/fixtures/example_cookbook_metadata_json_only/metadata.json +5 -5
  255. data/spec/unit/fixtures/example_cookbook_metadata_json_only/recipes/default.rb +8 -8
  256. data/spec/unit/fixtures/example_cookbook_no_metadata/.gitignore +17 -17
  257. data/spec/unit/fixtures/example_cookbook_no_metadata/.kitchen.yml +16 -16
  258. data/spec/unit/fixtures/example_cookbook_no_metadata/Berksfile +3 -3
  259. data/spec/unit/fixtures/example_cookbook_no_metadata/README.md +4 -4
  260. data/spec/unit/fixtures/example_cookbook_no_metadata/chefignore +96 -96
  261. data/spec/unit/fixtures/example_cookbook_no_metadata/recipes/default.rb +8 -8
  262. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/README.md +4 -4
  263. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/chefignore +96 -96
  264. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/metadata.rb +8 -8
  265. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/recipes/default.rb +8 -8
  266. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/Berksfile +3 -3
  267. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/README.md +4 -4
  268. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/chefignore +96 -96
  269. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/metadata.rb +9 -9
  270. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/recipes/default.rb +8 -8
  271. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/.kitchen.yml +16 -16
  272. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/Berksfile +3 -3
  273. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/README.md +4 -4
  274. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/chefignore +96 -96
  275. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/extra/extra_file.txt +0 -0
  276. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/metadata.rb +8 -8
  277. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/recipes/default.rb +8 -8
  278. data/spec/unit/fixtures/local_path_cookbooks/metadata-missing/README.md +2 -2
  279. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -16
  280. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -4
  281. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -8
  282. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -8
  283. data/spec/unit/generator_spec.rb +120 -120
  284. data/spec/unit/helpers_spec.rb +92 -92
  285. data/spec/unit/pager_spec.rb +119 -119
  286. data/spec/unit/policyfile/chef_repo_cookbook_source_spec.rb +93 -93
  287. data/spec/unit/policyfile/chef_server_cookbook_source_spec.rb +34 -34
  288. data/spec/unit/policyfile/community_cookbook_source_spec.rb +84 -84
  289. data/spec/unit/policyfile/comparison_base_spec.rb +343 -343
  290. data/spec/unit/policyfile/cookbook_location_specification_spec.rb +277 -277
  291. data/spec/unit/policyfile/cookbook_locks_spec.rb +529 -529
  292. data/spec/unit/policyfile/delivery_supermarket_source_spec.rb +130 -130
  293. data/spec/unit/policyfile/differ_spec.rb +687 -687
  294. data/spec/unit/policyfile/lister_spec.rb +272 -272
  295. data/spec/unit/policyfile/null_cookbook_source_spec.rb +35 -35
  296. data/spec/unit/policyfile/read_cookbook_for_compat_mode_upload_spec.rb +92 -92
  297. data/spec/unit/policyfile/reports/install_spec.rb +115 -115
  298. data/spec/unit/policyfile/reports/upload_spec.rb +96 -96
  299. data/spec/unit/policyfile/solution_dependencies_spec.rb +145 -145
  300. data/spec/unit/policyfile/storage_config_spec.rb +172 -172
  301. data/spec/unit/policyfile/undo_record_spec.rb +260 -260
  302. data/spec/unit/policyfile/undo_stack_spec.rb +266 -266
  303. data/spec/unit/policyfile/uploader_spec.rb +410 -410
  304. data/spec/unit/policyfile_demands_spec.rb +1203 -1203
  305. data/spec/unit/policyfile_evaluation_spec.rb +642 -642
  306. data/spec/unit/policyfile_lock_build_spec.rb +1056 -1056
  307. data/spec/unit/policyfile_lock_install_spec.rb +138 -138
  308. data/spec/unit/policyfile_lock_serialization_spec.rb +425 -425
  309. data/spec/unit/policyfile_lock_validation_spec.rb +611 -611
  310. data/spec/unit/policyfile_services/clean_policies_spec.rb +236 -236
  311. data/spec/unit/policyfile_services/clean_policy_cookbooks_spec.rb +275 -275
  312. data/spec/unit/policyfile_services/export_repo_spec.rb +481 -481
  313. data/spec/unit/policyfile_services/install_spec.rb +211 -211
  314. data/spec/unit/policyfile_services/push_archive_spec.rb +378 -378
  315. data/spec/unit/policyfile_services/push_spec.rb +233 -233
  316. data/spec/unit/policyfile_services/rm_policy_group_spec.rb +241 -241
  317. data/spec/unit/policyfile_services/rm_policy_spec.rb +266 -266
  318. data/spec/unit/policyfile_services/show_policy_spec.rb +889 -889
  319. data/spec/unit/policyfile_services/undelete_spec.rb +304 -304
  320. data/spec/unit/policyfile_services/update_attributes_spec.rb +217 -217
  321. data/spec/unit/service_exception_inspectors/base_spec.rb +43 -43
  322. data/spec/unit/service_exception_inspectors/http_spec.rb +140 -140
  323. data/spec/unit/shell_out_spec.rb +34 -34
  324. data/warning.txt +9 -9
  325. metadata +24 -19
@@ -1,46 +1,46 @@
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/generator_commands/cookbook_code_file'
19
-
20
- module ChefDK
21
- module Command
22
- module GeneratorCommands
23
- # chef generate template [path/to/cookbook_root] name --source=source_file
24
- class Template < CookbookCodeFile
25
-
26
- option :source,
27
- :short => "-s SOURCE_FILE",
28
- :long => "--source SOURCE_FILE",
29
- :description => "Copy content from SOURCE_FILE"
30
-
31
- banner "Usage: chef generate template [path/to/cookbook] NAME [options]"
32
-
33
- options.merge!(SharedGeneratorOptions.options)
34
-
35
- def recipe
36
- 'template'
37
- end
38
-
39
- def setup_context
40
- super
41
- Generator.add_attr_to_context(:content_source, config[:source])
42
- end
43
- end
44
- end
45
- end
46
- end
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/generator_commands/cookbook_code_file'
19
+
20
+ module ChefDK
21
+ module Command
22
+ module GeneratorCommands
23
+ # chef generate template [path/to/cookbook_root] name --source=source_file
24
+ class Template < CookbookCodeFile
25
+
26
+ option :source,
27
+ :short => "-s SOURCE_FILE",
28
+ :long => "--source SOURCE_FILE",
29
+ :description => "Copy content from SOURCE_FILE"
30
+
31
+ banner "Usage: chef generate template [path/to/cookbook] NAME [options]"
32
+
33
+ options.merge!(SharedGeneratorOptions.options)
34
+
35
+ def recipe
36
+ 'template'
37
+ end
38
+
39
+ def setup_context
40
+ super
41
+ Generator.add_attr_to_context(:content_source, config[:source])
42
+ end
43
+ end
44
+ end
45
+ end
46
+ end
@@ -1,121 +1,121 @@
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/ui'
20
- require 'chef-dk/policyfile_services/install'
21
- require 'chef-dk/configurable'
22
-
23
- module ChefDK
24
- module Command
25
-
26
- class Install < Base
27
-
28
- include Configurable
29
-
30
- banner(<<-E)
31
- Usage: chef install [ POLICY_FILE ] [options]
32
-
33
- `chef install` evaluates a `Policyfile.rb` to find a compatible set of
34
- cookbooks for the policy's run_list and caches them locally. It emits a
35
- Policyfile.lock.json describing the locked cookbook set. You can use the
36
- lockfile to install the locked cookbooks on another machine. You can also push
37
- the lockfile to a "policy group" on a Chef Server and apply that exact set of
38
- cookbooks to nodes in your infrastructure.
39
-
40
- See our detailed README for more information:
41
-
42
- https://github.com/opscode/chef-dk/blob/master/POLICYFILE_README.md
43
-
44
- Options:
45
-
46
- E
47
-
48
- option :config_file,
49
- short: "-c CONFIG_FILE",
50
- long: "--config CONFIG_FILE",
51
- description: "Path to configuration file"
52
-
53
- option :debug,
54
- short: "-D",
55
- long: "--debug",
56
- description: "Enable stacktraces and other debug output",
57
- default: false
58
-
59
- attr_reader :policyfile_relative_path
60
-
61
- attr_accessor :ui
62
-
63
- def initialize(*args)
64
- super
65
- @ui = UI.new
66
-
67
- @policyfile_relative_path = nil
68
- @installer = nil
69
- end
70
-
71
- def run(params = [])
72
- return 1 unless apply_params!(params)
73
- # Force config file to be loaded. We don't use the configuration
74
- # directly, but the user may have SSL configuration options that they
75
- # need to talk to a private supermarket (e.g., trusted_certs or
76
- # ssl_verify_mode)
77
- chef_config
78
- installer.run
79
- 0
80
- rescue PolicyfileServiceError => e
81
- handle_error(e)
82
- 1
83
- end
84
-
85
- def installer
86
- @installer ||= PolicyfileServices::Install.new(policyfile: policyfile_relative_path, ui: ui, root_dir: Dir.pwd)
87
- end
88
-
89
- def debug?
90
- !!config[:debug]
91
- end
92
-
93
- def config_path
94
- config[:config_file]
95
- end
96
-
97
- def handle_error(error)
98
- ui.err("Error: #{error.message}")
99
- if error.respond_to?(:reason)
100
- ui.err("Reason: #{error.reason}")
101
- ui.err("")
102
- ui.err(error.extended_error_info) if debug?
103
- ui.err(error.cause.backtrace.join("\n")) if debug?
104
- end
105
- end
106
-
107
- def apply_params!(params)
108
- remaining_args = parse_options(params)
109
- if remaining_args.size > 1
110
- ui.err(opt_parser)
111
- return false
112
- else
113
- @policyfile_relative_path = remaining_args.first
114
- true
115
- end
116
- end
117
-
118
- end
119
- end
120
- end
121
-
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/ui'
20
+ require 'chef-dk/policyfile_services/install'
21
+ require 'chef-dk/configurable'
22
+
23
+ module ChefDK
24
+ module Command
25
+
26
+ class Install < Base
27
+
28
+ include Configurable
29
+
30
+ banner(<<-E)
31
+ Usage: chef install [ POLICY_FILE ] [options]
32
+
33
+ `chef install` evaluates a `Policyfile.rb` to find a compatible set of
34
+ cookbooks for the policy's run_list and caches them locally. It emits a
35
+ Policyfile.lock.json describing the locked cookbook set. You can use the
36
+ lockfile to install the locked cookbooks on another machine. You can also push
37
+ the lockfile to a "policy group" on a Chef Server and apply that exact set of
38
+ cookbooks to nodes in your infrastructure.
39
+
40
+ See our detailed README for more information:
41
+
42
+ https://github.com/chef/chef-dk/blob/master/POLICYFILE_README.md
43
+
44
+ Options:
45
+
46
+ E
47
+
48
+ option :config_file,
49
+ short: "-c CONFIG_FILE",
50
+ long: "--config CONFIG_FILE",
51
+ description: "Path to configuration file"
52
+
53
+ option :debug,
54
+ short: "-D",
55
+ long: "--debug",
56
+ description: "Enable stacktraces and other debug output",
57
+ default: false
58
+
59
+ attr_reader :policyfile_relative_path
60
+
61
+ attr_accessor :ui
62
+
63
+ def initialize(*args)
64
+ super
65
+ @ui = UI.new
66
+
67
+ @policyfile_relative_path = nil
68
+ @installer = nil
69
+ end
70
+
71
+ def run(params = [])
72
+ return 1 unless apply_params!(params)
73
+ # Force config file to be loaded. We don't use the configuration
74
+ # directly, but the user may have SSL configuration options that they
75
+ # need to talk to a private supermarket (e.g., trusted_certs or
76
+ # ssl_verify_mode)
77
+ chef_config
78
+ installer.run
79
+ 0
80
+ rescue PolicyfileServiceError => e
81
+ handle_error(e)
82
+ 1
83
+ end
84
+
85
+ def installer
86
+ @installer ||= PolicyfileServices::Install.new(policyfile: policyfile_relative_path, ui: ui, root_dir: Dir.pwd)
87
+ end
88
+
89
+ def debug?
90
+ !!config[:debug]
91
+ end
92
+
93
+ def config_path
94
+ config[:config_file]
95
+ end
96
+
97
+ def handle_error(error)
98
+ ui.err("Error: #{error.message}")
99
+ if error.respond_to?(:reason)
100
+ ui.err("Reason: #{error.reason}")
101
+ ui.err("")
102
+ ui.err(error.extended_error_info) if debug?
103
+ ui.err(error.cause.backtrace.join("\n")) if debug?
104
+ end
105
+ end
106
+
107
+ def apply_params!(params)
108
+ remaining_args = parse_options(params)
109
+ if remaining_args.size > 1
110
+ ui.err(opt_parser)
111
+ return false
112
+ else
113
+ @policyfile_relative_path = remaining_args.first
114
+ true
115
+ end
116
+ end
117
+
118
+ end
119
+ end
120
+ end
121
+
@@ -1,438 +1,438 @@
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 'ostruct'
19
-
20
- require 'chef-dk/command/base'
21
- require 'chef-dk/configurable'
22
- require 'chef-dk/chef_runner'
23
- require 'chef-dk/policyfile_services/push'
24
-
25
- require 'chef/provisioning'
26
-
27
- module ChefDK
28
-
29
- module ProvisioningData
30
-
31
- def self.reset
32
- @context = nil
33
- end
34
-
35
- def self.context
36
- @context ||= Context.new
37
- end
38
-
39
- class Context
40
-
41
- attr_accessor :action
42
-
43
- attr_accessor :node_name
44
-
45
- attr_accessor :target
46
-
47
- attr_accessor :enable_policyfile
48
-
49
- attr_accessor :policy_group
50
-
51
- attr_accessor :policy_name
52
-
53
- attr_accessor :extra_chef_config
54
-
55
- attr_accessor :opts
56
-
57
- def initialize
58
- @extra_chef_config = ""
59
- @opts = nil
60
- end
61
-
62
- def set_user_opts(hash)
63
- @opts = OpenStruct.new(hash)
64
- end
65
-
66
- def convergence_options
67
- {
68
- chef_server: Chef::Config.chef_server_url,
69
- chef_config: chef_config
70
- }
71
- end
72
-
73
- def chef_config
74
- config=<<-CONFIG
75
- # SSL Settings:
76
- ssl_verify_mode #{Chef::Config.ssl_verify_mode.inspect}
77
-
78
- CONFIG
79
- if enable_policyfile
80
- policyfile_config=<<-CONFIG
81
- # Policyfile Settings:
82
- use_policyfile true
83
- policy_document_native_api true
84
-
85
- policy_group "#{policy_group}"
86
- policy_name "#{policy_name}"
87
-
88
- CONFIG
89
- config << policyfile_config
90
- end
91
-
92
- config << extra_chef_config.to_s
93
- config
94
- end
95
-
96
- end
97
- end
98
-
99
- module Command
100
-
101
- class Provision < Base
102
-
103
- banner(<<-E)
104
- Usage: chef provision POLICY_GROUP --policy-name POLICY_NAME [options]
105
- chef provision POLICY_GROUP --sync [POLICYFILE_PATH] [options]
106
- chef provision --no-policy [options]
107
-
108
- `chef provision` invokes an embedded chef-client run to provision machines
109
- using Chef Provisioning. If not otherwise specified, `chef provision` will
110
- expect to find a cookbook named 'provision' in the current working directory.
111
- It runs a recipe in this cookbook which should use Chef Provisioning to create
112
- one or more machines (or other infrastructure).
113
-
114
- `chef provision` provides three forms of operation:
115
-
116
- ### chef provision POLICY_GROUP --policy-name POLICY_NAME
117
-
118
- In the first form of the command, `chef provision` creates machines that will
119
- operate in policyfile mode. The chef configuration passed to the cookbook will
120
- set the policy group and policy name as given.
121
-
122
- ### chef provision POLICY_GROUP --sync [POLICYFILE_PATH] [options]
123
-
124
- In the second form of the command, `chef provision` create machines that will
125
- operate in policyfile mode and syncronizes a local policyfile to the server
126
- before converging the machine(s) defined in the provision cookbook.
127
-
128
- ### chef provision --no-policy [options]
129
-
130
- In the third form of the command, `chef provision` expects to create machines
131
- that will not operate in policyfile mode.
132
-
133
- Chef Provisioning is documented at https://docs.chef.io/provisioning.html
134
-
135
- Options:
136
-
137
- E
138
- include Configurable
139
-
140
- option :config_file,
141
- short: "-c CONFIG_FILE",
142
- long: "--config CONFIG_FILE",
143
- description: "Path to configuration file"
144
-
145
- option :policy_name,
146
- short: "-p POLICY_NAME",
147
- long: "--policy-name POLICY_NAME",
148
- description: "Set the default policy name for provisioned machines"
149
-
150
- option :sync,
151
- short: "-s [POLICYFILE_PATH]",
152
- long: "--sync [POLICYFILE_PATH]",
153
- description: "Push policyfile to the server before converging node(s)"
154
-
155
- option :enable_policyfile,
156
- long: "--[no-]policy",
157
- description: "Enable/disable policyfile integration (defaults to enabled, use --no-policy to disable)",
158
- default: true
159
-
160
- option :destroy,
161
- short: "-d",
162
- long: "--destroy",
163
- description: "Set default machine action to :destroy",
164
- default: false,
165
- boolean: true
166
-
167
- option :machine_recipe,
168
- short: "-r RECIPE",
169
- long: "--recipe RECIPE",
170
- description: "Machine recipe to use",
171
- default: "default"
172
-
173
- option :cookbook,
174
- long: "--cookbook COOKBOOK_PATH",
175
- description: "Path to your provisioning cookbook",
176
- default: "./provision"
177
-
178
- option :node_name,
179
- short: "-n NODE_NAME",
180
- long: "--node-name NODE_NAME",
181
- description: "Set default node name (may be overriden by provisioning cookbook)"
182
-
183
- option :target,
184
- short: "-t REMOTE_HOST",
185
- long: "--target REMOTE_HOST",
186
- description: "Set hostname or IP of the host to converge (may be overriden by provisioning cookbook)"
187
-
188
- OPT_SEPARATOR = /[=\s]+/.freeze
189
-
190
- def self.split_opt(key_value)
191
- key, _separator, value = key_value.partition(OPT_SEPARATOR)
192
- [key, value]
193
- end
194
-
195
- opts={}
196
-
197
- option :opts,
198
- short: "-o OPT=VALUE",
199
- long: "--opt OPT=VALUE",
200
- description: "Set arbitrary option OPT on the provisioning context",
201
- proc: lambda { |arg| key, value = split_opt(arg); opts[key] = value; opts },
202
- default: {}
203
-
204
- option :debug,
205
- short: "-D",
206
- long: "--debug",
207
- description: "Enable stacktraces and other debug output",
208
- default: false
209
-
210
-
211
- attr_reader :params
212
- attr_reader :policyfile_relative_path
213
- attr_reader :policy_group
214
-
215
- attr_accessor :ui
216
-
217
- def initialize(*args)
218
- super
219
-
220
- @ui = UI.new
221
-
222
- @policyfile_relative_path = nil
223
- @policy_group = nil
224
-
225
- @provisioning_cookbook_path = nil
226
- @provisioning_cookbook_name = nil
227
- end
228
-
229
- def run(params = [])
230
- return 1 unless apply_params!(params)
231
- chef_config # force chef config to load
232
- return 1 unless check_cookbook_and_recipe_path
233
-
234
- push.run if sync_policy?
235
-
236
- setup_context
237
-
238
- chef_runner.converge
239
- 0
240
- rescue ChefRunnerError, PolicyfileServiceError => e
241
- handle_error(e)
242
- 1
243
- # Chef Provisioning doesn't fail gracefully when a driver is missing:
244
- # https://github.com/chef/chef-provisioning/issues/338
245
- rescue StandardError, LoadError => error
246
- ui.err("Error: #{error.message}")
247
- 1
248
- end
249
-
250
- # An instance of ChefRunner. Calling ChefRunner#converge will trigger
251
- # convergence and generate the desired code.
252
- def chef_runner
253
- @chef_runner ||= ChefRunner.new(provisioning_cookbook_path, ["recipe[#{provisioning_cookbook_name}::#{recipe}]"])
254
- end
255
-
256
- def push
257
- @push ||= PolicyfileServices::Push.new(policyfile: policyfile_relative_path,
258
- ui: ui,
259
- policy_group: policy_group,
260
- config: chef_config,
261
- root_dir: Dir.pwd)
262
- end
263
-
264
- def setup_context
265
- ProvisioningData.context.tap do |c|
266
-
267
- c.action = default_action
268
- c.node_name = node_name
269
- c.target = target
270
-
271
- c.set_user_opts(user_opts)
272
-
273
- c.enable_policyfile = enable_policyfile?
274
-
275
- if enable_policyfile?
276
- c.policy_group = policy_group
277
- c.policy_name = policy_name
278
- end
279
-
280
- end
281
- end
282
-
283
- def policy_name
284
- if sync_policy?
285
- push.policy_data["name"]
286
- else
287
- config[:policy_name]
288
- end
289
- end
290
-
291
- def default_action
292
- if config[:destroy]
293
- :destroy
294
- else
295
- :converge
296
- end
297
- end
298
-
299
- def node_name
300
- config[:node_name]
301
- end
302
-
303
- def target
304
- config[:target]
305
- end
306
-
307
- def user_opts
308
- config[:opts]
309
- end
310
-
311
- def recipe
312
- config[:machine_recipe]
313
- end
314
-
315
- # Gives the `cookbook_path` in the chef-client sense, which is the
316
- # directory that contains the provisioning cookbook.
317
- def provisioning_cookbook_path
318
- detect_provisioning_cookbook_name_and_path! unless @provisioning_cookbook_path
319
- @provisioning_cookbook_path
320
- end
321
-
322
- # The name of the provisioning cookbook
323
- def provisioning_cookbook_name
324
- detect_provisioning_cookbook_name_and_path! unless @provisioning_cookbook_name
325
- @provisioning_cookbook_name
326
- end
327
-
328
- def cookbook_path
329
- config[:cookbook]
330
- end
331
-
332
- def enable_policyfile?
333
- config[:enable_policyfile]
334
- end
335
-
336
- def apply_params!(params)
337
- remaining_args = parse_options(params)
338
- if enable_policyfile?
339
- handle_policy_argv(remaining_args)
340
- else
341
- handle_no_policy_argv(remaining_args)
342
- end
343
- end
344
-
345
- def debug?
346
- !!config[:debug]
347
- end
348
-
349
- def sync_policy?
350
- config.key?(:sync)
351
- end
352
-
353
- private
354
-
355
- def detect_provisioning_cookbook_name_and_path!
356
- given_path = File.expand_path(cookbook_path, Dir.pwd)
357
- @provisioning_cookbook_name = File.basename(given_path)
358
- @provisioning_cookbook_path = File.dirname(given_path)
359
- end
360
-
361
- def check_cookbook_and_recipe_path
362
- if !File.exist?(cookbook_expanded_path)
363
- ui.err("ERROR: Provisioning cookbook not found at path #{cookbook_expanded_path}")
364
- false
365
- elsif !File.exist?(provisioning_recipe_path)
366
- ui.err("ERROR: Provisioning recipe not found at path #{provisioning_recipe_path}")
367
- false
368
- else
369
- true
370
- end
371
- end
372
-
373
- def provisioning_recipe_path
374
- File.join(cookbook_expanded_path, 'recipes', "#{recipe}.rb")
375
- end
376
-
377
- def cookbook_expanded_path
378
- File.join(chef_runner.cookbook_path, provisioning_cookbook_name)
379
- end
380
-
381
- def handle_no_policy_argv(remaining_args)
382
- if remaining_args.empty?
383
- true
384
- else
385
- ui.err("The --no-policy flag cannot be combined with policyfile arguments")
386
- ui.err("")
387
- ui.err(opt_parser)
388
- return false
389
- end
390
- end
391
-
392
- def handle_policy_argv(remaining_args)
393
- if remaining_args.size > 1
394
- ui.err("Too many arguments")
395
- ui.err("")
396
- ui.err(opt_parser)
397
- false
398
- elsif remaining_args.size < 1
399
- ui.err("You must specify a POLICY_GROUP or disable policyfiles with --no-policy")
400
- ui.err("")
401
- ui.err(opt_parser)
402
- false
403
- elsif !sync_policy? && config[:policy_name].nil?
404
- ui.err("You must pass either --sync or --policy-name to provision machines in policyfile mode")
405
- ui.err("")
406
- ui.err(opt_parser)
407
- false
408
- elsif sync_policy? && config[:policy_name]
409
- ui.err("The --policy-name and --sync arguments cannot be combined")
410
- ui.err("")
411
- ui.err(opt_parser)
412
- false
413
- elsif sync_policy?
414
- @policy_group = remaining_args[0]
415
- @policyfile_relative_path = config[:sync]
416
- true
417
- elsif config[:policy_name]
418
- @policy_group = remaining_args[0]
419
- true
420
- else
421
- raise BUG, "Cannot properly parse input argv '#{ARGV.inspect}'"
422
- end
423
- end
424
-
425
- def handle_error(error)
426
- ui.err("Error: #{error.message}")
427
- if error.respond_to?(:reason)
428
- ui.err("Reason: #{error.reason}")
429
- ui.err("")
430
- ui.err(error.extended_error_info) if debug?
431
- ui.err(error.cause.backtrace.join("\n")) if debug?
432
- end
433
- end
434
-
435
- end
436
- end
437
- end
438
-
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 'ostruct'
19
+
20
+ require 'chef-dk/command/base'
21
+ require 'chef-dk/configurable'
22
+ require 'chef-dk/chef_runner'
23
+ require 'chef-dk/policyfile_services/push'
24
+
25
+ require 'chef/provisioning'
26
+
27
+ module ChefDK
28
+
29
+ module ProvisioningData
30
+
31
+ def self.reset
32
+ @context = nil
33
+ end
34
+
35
+ def self.context
36
+ @context ||= Context.new
37
+ end
38
+
39
+ class Context
40
+
41
+ attr_accessor :action
42
+
43
+ attr_accessor :node_name
44
+
45
+ attr_accessor :target
46
+
47
+ attr_accessor :enable_policyfile
48
+
49
+ attr_accessor :policy_group
50
+
51
+ attr_accessor :policy_name
52
+
53
+ attr_accessor :extra_chef_config
54
+
55
+ attr_accessor :opts
56
+
57
+ def initialize
58
+ @extra_chef_config = ""
59
+ @opts = nil
60
+ end
61
+
62
+ def set_user_opts(hash)
63
+ @opts = OpenStruct.new(hash)
64
+ end
65
+
66
+ def convergence_options
67
+ {
68
+ chef_server: Chef::Config.chef_server_url,
69
+ chef_config: chef_config
70
+ }
71
+ end
72
+
73
+ def chef_config
74
+ config=<<-CONFIG
75
+ # SSL Settings:
76
+ ssl_verify_mode #{Chef::Config.ssl_verify_mode.inspect}
77
+
78
+ CONFIG
79
+ if enable_policyfile
80
+ policyfile_config=<<-CONFIG
81
+ # Policyfile Settings:
82
+ use_policyfile true
83
+ policy_document_native_api true
84
+
85
+ policy_group "#{policy_group}"
86
+ policy_name "#{policy_name}"
87
+
88
+ CONFIG
89
+ config << policyfile_config
90
+ end
91
+
92
+ config << extra_chef_config.to_s
93
+ config
94
+ end
95
+
96
+ end
97
+ end
98
+
99
+ module Command
100
+
101
+ class Provision < Base
102
+
103
+ banner(<<-E)
104
+ Usage: chef provision POLICY_GROUP --policy-name POLICY_NAME [options]
105
+ chef provision POLICY_GROUP --sync [POLICYFILE_PATH] [options]
106
+ chef provision --no-policy [options]
107
+
108
+ `chef provision` invokes an embedded chef-client run to provision machines
109
+ using Chef Provisioning. If not otherwise specified, `chef provision` will
110
+ expect to find a cookbook named 'provision' in the current working directory.
111
+ It runs a recipe in this cookbook which should use Chef Provisioning to create
112
+ one or more machines (or other infrastructure).
113
+
114
+ `chef provision` provides three forms of operation:
115
+
116
+ ### chef provision POLICY_GROUP --policy-name POLICY_NAME
117
+
118
+ In the first form of the command, `chef provision` creates machines that will
119
+ operate in policyfile mode. The chef configuration passed to the cookbook will
120
+ set the policy group and policy name as given.
121
+
122
+ ### chef provision POLICY_GROUP --sync [POLICYFILE_PATH] [options]
123
+
124
+ In the second form of the command, `chef provision` create machines that will
125
+ operate in policyfile mode and syncronizes a local policyfile to the server
126
+ before converging the machine(s) defined in the provision cookbook.
127
+
128
+ ### chef provision --no-policy [options]
129
+
130
+ In the third form of the command, `chef provision` expects to create machines
131
+ that will not operate in policyfile mode.
132
+
133
+ Chef Provisioning is documented at https://docs.chef.io/provisioning.html
134
+
135
+ Options:
136
+
137
+ E
138
+ include Configurable
139
+
140
+ option :config_file,
141
+ short: "-c CONFIG_FILE",
142
+ long: "--config CONFIG_FILE",
143
+ description: "Path to configuration file"
144
+
145
+ option :policy_name,
146
+ short: "-p POLICY_NAME",
147
+ long: "--policy-name POLICY_NAME",
148
+ description: "Set the default policy name for provisioned machines"
149
+
150
+ option :sync,
151
+ short: "-s [POLICYFILE_PATH]",
152
+ long: "--sync [POLICYFILE_PATH]",
153
+ description: "Push policyfile to the server before converging node(s)"
154
+
155
+ option :enable_policyfile,
156
+ long: "--[no-]policy",
157
+ description: "Enable/disable policyfile integration (defaults to enabled, use --no-policy to disable)",
158
+ default: true
159
+
160
+ option :destroy,
161
+ short: "-d",
162
+ long: "--destroy",
163
+ description: "Set default machine action to :destroy",
164
+ default: false,
165
+ boolean: true
166
+
167
+ option :machine_recipe,
168
+ short: "-r RECIPE",
169
+ long: "--recipe RECIPE",
170
+ description: "Machine recipe to use",
171
+ default: "default"
172
+
173
+ option :cookbook,
174
+ long: "--cookbook COOKBOOK_PATH",
175
+ description: "Path to your provisioning cookbook",
176
+ default: "./provision"
177
+
178
+ option :node_name,
179
+ short: "-n NODE_NAME",
180
+ long: "--node-name NODE_NAME",
181
+ description: "Set default node name (may be overriden by provisioning cookbook)"
182
+
183
+ option :target,
184
+ short: "-t REMOTE_HOST",
185
+ long: "--target REMOTE_HOST",
186
+ description: "Set hostname or IP of the host to converge (may be overriden by provisioning cookbook)"
187
+
188
+ OPT_SEPARATOR = /[=\s]+/.freeze
189
+
190
+ def self.split_opt(key_value)
191
+ key, _separator, value = key_value.partition(OPT_SEPARATOR)
192
+ [key, value]
193
+ end
194
+
195
+ opts={}
196
+
197
+ option :opts,
198
+ short: "-o OPT=VALUE",
199
+ long: "--opt OPT=VALUE",
200
+ description: "Set arbitrary option OPT on the provisioning context",
201
+ proc: lambda { |arg| key, value = split_opt(arg); opts[key] = value; opts },
202
+ default: {}
203
+
204
+ option :debug,
205
+ short: "-D",
206
+ long: "--debug",
207
+ description: "Enable stacktraces and other debug output",
208
+ default: false
209
+
210
+
211
+ attr_reader :params
212
+ attr_reader :policyfile_relative_path
213
+ attr_reader :policy_group
214
+
215
+ attr_accessor :ui
216
+
217
+ def initialize(*args)
218
+ super
219
+
220
+ @ui = UI.new
221
+
222
+ @policyfile_relative_path = nil
223
+ @policy_group = nil
224
+
225
+ @provisioning_cookbook_path = nil
226
+ @provisioning_cookbook_name = nil
227
+ end
228
+
229
+ def run(params = [])
230
+ return 1 unless apply_params!(params)
231
+ chef_config # force chef config to load
232
+ return 1 unless check_cookbook_and_recipe_path
233
+
234
+ push.run if sync_policy?
235
+
236
+ setup_context
237
+
238
+ chef_runner.converge
239
+ 0
240
+ rescue ChefRunnerError, PolicyfileServiceError => e
241
+ handle_error(e)
242
+ 1
243
+ # Chef Provisioning doesn't fail gracefully when a driver is missing:
244
+ # https://github.com/chef/chef-provisioning/issues/338
245
+ rescue StandardError, LoadError => error
246
+ ui.err("Error: #{error.message}")
247
+ 1
248
+ end
249
+
250
+ # An instance of ChefRunner. Calling ChefRunner#converge will trigger
251
+ # convergence and generate the desired code.
252
+ def chef_runner
253
+ @chef_runner ||= ChefRunner.new(provisioning_cookbook_path, ["recipe[#{provisioning_cookbook_name}::#{recipe}]"])
254
+ end
255
+
256
+ def push
257
+ @push ||= PolicyfileServices::Push.new(policyfile: policyfile_relative_path,
258
+ ui: ui,
259
+ policy_group: policy_group,
260
+ config: chef_config,
261
+ root_dir: Dir.pwd)
262
+ end
263
+
264
+ def setup_context
265
+ ProvisioningData.context.tap do |c|
266
+
267
+ c.action = default_action
268
+ c.node_name = node_name
269
+ c.target = target
270
+
271
+ c.set_user_opts(user_opts)
272
+
273
+ c.enable_policyfile = enable_policyfile?
274
+
275
+ if enable_policyfile?
276
+ c.policy_group = policy_group
277
+ c.policy_name = policy_name
278
+ end
279
+
280
+ end
281
+ end
282
+
283
+ def policy_name
284
+ if sync_policy?
285
+ push.policy_data["name"]
286
+ else
287
+ config[:policy_name]
288
+ end
289
+ end
290
+
291
+ def default_action
292
+ if config[:destroy]
293
+ :destroy
294
+ else
295
+ :converge
296
+ end
297
+ end
298
+
299
+ def node_name
300
+ config[:node_name]
301
+ end
302
+
303
+ def target
304
+ config[:target]
305
+ end
306
+
307
+ def user_opts
308
+ config[:opts]
309
+ end
310
+
311
+ def recipe
312
+ config[:machine_recipe]
313
+ end
314
+
315
+ # Gives the `cookbook_path` in the chef-client sense, which is the
316
+ # directory that contains the provisioning cookbook.
317
+ def provisioning_cookbook_path
318
+ detect_provisioning_cookbook_name_and_path! unless @provisioning_cookbook_path
319
+ @provisioning_cookbook_path
320
+ end
321
+
322
+ # The name of the provisioning cookbook
323
+ def provisioning_cookbook_name
324
+ detect_provisioning_cookbook_name_and_path! unless @provisioning_cookbook_name
325
+ @provisioning_cookbook_name
326
+ end
327
+
328
+ def cookbook_path
329
+ config[:cookbook]
330
+ end
331
+
332
+ def enable_policyfile?
333
+ config[:enable_policyfile]
334
+ end
335
+
336
+ def apply_params!(params)
337
+ remaining_args = parse_options(params)
338
+ if enable_policyfile?
339
+ handle_policy_argv(remaining_args)
340
+ else
341
+ handle_no_policy_argv(remaining_args)
342
+ end
343
+ end
344
+
345
+ def debug?
346
+ !!config[:debug]
347
+ end
348
+
349
+ def sync_policy?
350
+ config.key?(:sync)
351
+ end
352
+
353
+ private
354
+
355
+ def detect_provisioning_cookbook_name_and_path!
356
+ given_path = File.expand_path(cookbook_path, Dir.pwd)
357
+ @provisioning_cookbook_name = File.basename(given_path)
358
+ @provisioning_cookbook_path = File.dirname(given_path)
359
+ end
360
+
361
+ def check_cookbook_and_recipe_path
362
+ if !File.exist?(cookbook_expanded_path)
363
+ ui.err("ERROR: Provisioning cookbook not found at path #{cookbook_expanded_path}")
364
+ false
365
+ elsif !File.exist?(provisioning_recipe_path)
366
+ ui.err("ERROR: Provisioning recipe not found at path #{provisioning_recipe_path}")
367
+ false
368
+ else
369
+ true
370
+ end
371
+ end
372
+
373
+ def provisioning_recipe_path
374
+ File.join(cookbook_expanded_path, 'recipes', "#{recipe}.rb")
375
+ end
376
+
377
+ def cookbook_expanded_path
378
+ File.join(chef_runner.cookbook_path, provisioning_cookbook_name)
379
+ end
380
+
381
+ def handle_no_policy_argv(remaining_args)
382
+ if remaining_args.empty?
383
+ true
384
+ else
385
+ ui.err("The --no-policy flag cannot be combined with policyfile arguments")
386
+ ui.err("")
387
+ ui.err(opt_parser)
388
+ return false
389
+ end
390
+ end
391
+
392
+ def handle_policy_argv(remaining_args)
393
+ if remaining_args.size > 1
394
+ ui.err("Too many arguments")
395
+ ui.err("")
396
+ ui.err(opt_parser)
397
+ false
398
+ elsif remaining_args.size < 1
399
+ ui.err("You must specify a POLICY_GROUP or disable policyfiles with --no-policy")
400
+ ui.err("")
401
+ ui.err(opt_parser)
402
+ false
403
+ elsif !sync_policy? && config[:policy_name].nil?
404
+ ui.err("You must pass either --sync or --policy-name to provision machines in policyfile mode")
405
+ ui.err("")
406
+ ui.err(opt_parser)
407
+ false
408
+ elsif sync_policy? && config[:policy_name]
409
+ ui.err("The --policy-name and --sync arguments cannot be combined")
410
+ ui.err("")
411
+ ui.err(opt_parser)
412
+ false
413
+ elsif sync_policy?
414
+ @policy_group = remaining_args[0]
415
+ @policyfile_relative_path = config[:sync]
416
+ true
417
+ elsif config[:policy_name]
418
+ @policy_group = remaining_args[0]
419
+ true
420
+ else
421
+ raise BUG, "Cannot properly parse input argv '#{ARGV.inspect}'"
422
+ end
423
+ end
424
+
425
+ def handle_error(error)
426
+ ui.err("Error: #{error.message}")
427
+ if error.respond_to?(:reason)
428
+ ui.err("Reason: #{error.reason}")
429
+ ui.err("")
430
+ ui.err(error.extended_error_info) if debug?
431
+ ui.err(error.cause.backtrace.join("\n")) if debug?
432
+ end
433
+ end
434
+
435
+ end
436
+ end
437
+ end
438
+