chef-dk 0.8.0 → 0.9.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 (299) hide show
  1. checksums.yaml +4 -4
  2. data/CONTRIBUTING.md +190 -190
  3. data/Gemfile +26 -0
  4. data/LICENSE +201 -201
  5. data/README.md +276 -276
  6. data/Rakefile +18 -18
  7. data/bin/chef +25 -25
  8. data/lib/chef-dk.rb +19 -19
  9. data/lib/chef-dk/authenticated_http.rb +40 -40
  10. data/lib/chef-dk/builtin_commands.rb +60 -60
  11. data/lib/chef-dk/chef_runner.rb +98 -98
  12. data/lib/chef-dk/cli.rb +200 -200
  13. data/lib/chef-dk/command/base.rb +79 -75
  14. data/lib/chef-dk/command/clean_policy_cookbooks.rb +116 -116
  15. data/lib/chef-dk/command/clean_policy_revisions.rb +113 -113
  16. data/lib/chef-dk/command/delete_policy.rb +122 -122
  17. data/lib/chef-dk/command/delete_policy_group.rb +122 -122
  18. data/lib/chef-dk/command/diff.rb +316 -316
  19. data/lib/chef-dk/command/env.rb +90 -90
  20. data/lib/chef-dk/command/exec.rb +45 -45
  21. data/lib/chef-dk/command/export.rb +151 -153
  22. data/lib/chef-dk/command/gem.rb +47 -47
  23. data/lib/chef-dk/command/generate.rb +120 -118
  24. data/lib/chef-dk/command/generator_commands.rb +80 -80
  25. data/lib/chef-dk/command/generator_commands/app.rb +107 -107
  26. data/lib/chef-dk/command/generator_commands/attribute.rb +37 -37
  27. data/lib/chef-dk/command/generator_commands/base.rb +121 -121
  28. data/lib/chef-dk/command/generator_commands/cookbook.rb +119 -108
  29. data/lib/chef-dk/command/generator_commands/cookbook_code_file.rb +100 -100
  30. data/lib/chef-dk/command/generator_commands/cookbook_file.rb +45 -45
  31. data/lib/chef-dk/command/generator_commands/generator_generator.rb +177 -0
  32. data/lib/chef-dk/command/generator_commands/lwrp.rb +36 -36
  33. data/lib/chef-dk/command/generator_commands/policyfile.rb +86 -83
  34. data/lib/chef-dk/command/generator_commands/recipe.rb +36 -36
  35. data/lib/chef-dk/command/generator_commands/repo.rb +96 -96
  36. data/lib/chef-dk/command/generator_commands/template.rb +46 -46
  37. data/lib/chef-dk/command/install.rb +121 -121
  38. data/lib/chef-dk/command/provision.rb +438 -438
  39. data/lib/chef-dk/command/push.rb +118 -118
  40. data/lib/chef-dk/command/push_archive.rb +126 -126
  41. data/lib/chef-dk/command/shell_init.rb +180 -180
  42. data/lib/chef-dk/command/show_policy.rb +165 -165
  43. data/lib/chef-dk/command/undelete.rb +155 -155
  44. data/lib/chef-dk/command/update.rb +129 -129
  45. data/lib/chef-dk/command/verify.rb +490 -453
  46. data/lib/chef-dk/commands_map.rb +115 -115
  47. data/lib/chef-dk/completions/bash.sh.erb +5 -5
  48. data/lib/chef-dk/completions/chef.fish.erb +10 -10
  49. data/lib/chef-dk/completions/zsh.zsh.erb +21 -21
  50. data/lib/chef-dk/component_test.rb +171 -171
  51. data/lib/chef-dk/configurable.rb +57 -52
  52. data/lib/chef-dk/cookbook_metadata.rb +45 -45
  53. data/lib/chef-dk/cookbook_omnifetch.rb +32 -32
  54. data/lib/chef-dk/cookbook_profiler/git.rb +151 -151
  55. data/lib/chef-dk/cookbook_profiler/identifiers.rb +72 -72
  56. data/lib/chef-dk/cookbook_profiler/null_scm.rb +32 -32
  57. data/lib/chef-dk/exceptions.rb +113 -113
  58. data/lib/chef-dk/generator.rb +163 -162
  59. data/lib/chef-dk/helpers.rb +159 -159
  60. data/lib/chef-dk/pager.rb +106 -106
  61. data/lib/chef-dk/policyfile/chef_repo_cookbook_source.rb +122 -122
  62. data/lib/chef-dk/policyfile/chef_server_cookbook_source.rb +54 -54
  63. data/lib/chef-dk/policyfile/community_cookbook_source.rb +82 -82
  64. data/lib/chef-dk/policyfile/comparison_base.rb +124 -124
  65. data/lib/chef-dk/policyfile/cookbook_location_specification.rb +133 -133
  66. data/lib/chef-dk/policyfile/cookbook_locks.rb +466 -466
  67. data/lib/chef-dk/policyfile/cookbook_sources.rb +21 -21
  68. data/lib/chef-dk/policyfile/differ.rb +266 -266
  69. data/lib/chef-dk/policyfile/dsl.rb +197 -197
  70. data/lib/chef-dk/policyfile/lister.rb +232 -232
  71. data/lib/chef-dk/policyfile/null_cookbook_source.rb +45 -45
  72. data/lib/chef-dk/policyfile/read_cookbook_for_compat_mode_upload.rb +124 -124
  73. data/lib/chef-dk/policyfile/reports/install.rb +70 -70
  74. data/lib/chef-dk/policyfile/reports/table_printer.rb +58 -58
  75. data/lib/chef-dk/policyfile/reports/upload.rb +70 -70
  76. data/lib/chef-dk/policyfile/solution_dependencies.rb +298 -298
  77. data/lib/chef-dk/policyfile/storage_config.rb +100 -100
  78. data/lib/chef-dk/policyfile/undo_record.rb +142 -142
  79. data/lib/chef-dk/policyfile/undo_stack.rb +130 -130
  80. data/lib/chef-dk/policyfile/uploader.rb +213 -213
  81. data/lib/chef-dk/policyfile_compiler.rb +322 -322
  82. data/lib/chef-dk/policyfile_lock.rb +552 -552
  83. data/lib/chef-dk/policyfile_services/clean_policies.rb +95 -95
  84. data/lib/chef-dk/policyfile_services/clean_policy_cookbooks.rb +125 -125
  85. data/lib/chef-dk/policyfile_services/export_repo.rb +309 -281
  86. data/lib/chef-dk/policyfile_services/install.rb +125 -125
  87. data/lib/chef-dk/policyfile_services/push.rb +114 -114
  88. data/lib/chef-dk/policyfile_services/push_archive.rb +173 -173
  89. data/lib/chef-dk/policyfile_services/rm_policy.rb +142 -142
  90. data/lib/chef-dk/policyfile_services/rm_policy_group.rb +86 -86
  91. data/lib/chef-dk/policyfile_services/show_policy.rb +237 -237
  92. data/lib/chef-dk/policyfile_services/undelete.rb +108 -108
  93. data/lib/chef-dk/policyfile_services/update_attributes.rb +104 -104
  94. data/lib/chef-dk/service_exception_inspectors.rb +25 -25
  95. data/lib/chef-dk/service_exception_inspectors/base.rb +40 -40
  96. data/lib/chef-dk/service_exception_inspectors/http.rb +121 -121
  97. data/lib/chef-dk/service_exceptions.rb +143 -143
  98. data/lib/chef-dk/shell_out.rb +36 -36
  99. data/lib/chef-dk/skeletons/code_generator/files/default/Berksfile +3 -3
  100. data/lib/chef-dk/skeletons/code_generator/files/default/chefignore +100 -100
  101. data/lib/chef-dk/skeletons/code_generator/files/default/cookbook_readmes/README-policy.md +9 -9
  102. data/lib/chef-dk/skeletons/code_generator/files/default/cookbook_readmes/README.md +54 -54
  103. data/lib/chef-dk/skeletons/code_generator/files/default/gitignore +16 -16
  104. data/lib/chef-dk/skeletons/code_generator/files/default/repo/README.md +28 -28
  105. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/README.md +27 -0
  106. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/attributes/default.rb +7 -7
  107. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/metadata.rb +3 -3
  108. data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/recipes/default.rb +8 -8
  109. data/lib/chef-dk/skeletons/code_generator/files/default/repo/data_bags/README.md +57 -57
  110. data/lib/chef-dk/skeletons/code_generator/files/default/repo/data_bags/example/example_item.json +3 -3
  111. data/lib/chef-dk/skeletons/code_generator/files/default/repo/environments/README.md +9 -9
  112. data/lib/chef-dk/skeletons/code_generator/files/default/repo/environments/example.json +12 -12
  113. data/lib/chef-dk/skeletons/code_generator/files/default/repo/roles/README.md +8 -8
  114. data/lib/chef-dk/skeletons/code_generator/files/default/repo/roles/example.json +12 -12
  115. data/lib/chef-dk/skeletons/code_generator/files/default/serverspec_spec_helper.rb +8 -3
  116. data/lib/chef-dk/skeletons/code_generator/files/default/spec_helper.rb +2 -2
  117. data/lib/chef-dk/skeletons/code_generator/metadata.rb +8 -8
  118. data/lib/chef-dk/skeletons/code_generator/recipes/app.rb +97 -97
  119. data/lib/chef-dk/skeletons/code_generator/recipes/attribute.rb +12 -12
  120. data/lib/chef-dk/skeletons/code_generator/recipes/cookbook.rb +104 -92
  121. data/lib/chef-dk/skeletons/code_generator/recipes/cookbook_file.rb +24 -24
  122. data/lib/chef-dk/skeletons/code_generator/recipes/lwrp.rb +23 -23
  123. data/lib/chef-dk/skeletons/code_generator/recipes/policyfile.rb +8 -8
  124. data/lib/chef-dk/skeletons/code_generator/recipes/recipe.rb +27 -27
  125. data/lib/chef-dk/skeletons/code_generator/recipes/repo.rb +48 -47
  126. data/lib/chef-dk/skeletons/code_generator/recipes/template.rb +32 -32
  127. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.all_rights.erb +3 -3
  128. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.apache2.erb +201 -201
  129. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.gplv2.erb +339 -339
  130. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.gplv3.erb +674 -674
  131. data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.mit.erb +21 -21
  132. data/lib/chef-dk/skeletons/code_generator/templates/default/Policyfile.rb.erb +20 -16
  133. data/lib/chef-dk/skeletons/code_generator/templates/default/README.md.erb +4 -4
  134. data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen.yml.erb +16 -16
  135. data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen_policyfile.yml.erb +27 -0
  136. data/lib/chef-dk/skeletons/code_generator/templates/default/metadata.rb.erb +7 -7
  137. data/lib/chef-dk/skeletons/code_generator/templates/default/recipe.rb.erb +5 -5
  138. data/lib/chef-dk/skeletons/code_generator/templates/default/recipe_spec.rb.erb +20 -20
  139. data/lib/chef-dk/skeletons/code_generator/templates/default/repo/gitignore.erb +11 -11
  140. data/lib/chef-dk/skeletons/code_generator/templates/default/serverspec_default_spec.rb.erb +9 -9
  141. data/lib/chef-dk/ui.rb +58 -58
  142. data/lib/chef-dk/version.rb +20 -20
  143. data/lib/kitchen/provisioner/policyfile_zero.rb +193 -164
  144. data/spec/shared/a_file_generator.rb +125 -125
  145. data/spec/shared/a_generated_file.rb +12 -12
  146. data/spec/shared/command_with_ui_object.rb +11 -11
  147. data/spec/shared/custom_generator_cookbook.rb +117 -117
  148. data/spec/shared/fixture_cookbook_checksums.rb +47 -47
  149. data/spec/shared/setup_git_cookbooks.rb +53 -53
  150. data/spec/spec_helper.rb +49 -48
  151. data/spec/test_helpers.rb +84 -84
  152. data/spec/unit/chef_runner_spec.rb +111 -110
  153. data/spec/unit/cli_spec.rb +357 -357
  154. data/spec/unit/command/base_spec.rb +169 -136
  155. data/spec/unit/command/clean_policy_cookbooks_spec.rb +181 -181
  156. data/spec/unit/command/clean_policy_revisions_spec.rb +181 -181
  157. data/spec/unit/command/delete_policy_group_spec.rb +207 -207
  158. data/spec/unit/command/delete_policy_spec.rb +207 -207
  159. data/spec/unit/command/diff_spec.rb +312 -312
  160. data/spec/unit/command/env_spec.rb +52 -52
  161. data/spec/unit/command/exec_spec.rb +179 -179
  162. data/spec/unit/command/export_spec.rb +189 -189
  163. data/spec/unit/command/generate_spec.rb +142 -142
  164. data/spec/unit/command/generator_commands/app_spec.rb +169 -169
  165. data/spec/unit/command/generator_commands/attribute_spec.rb +32 -32
  166. data/spec/unit/command/generator_commands/cookbook_file_spec.rb +32 -32
  167. data/spec/unit/command/generator_commands/cookbook_spec.rb +320 -240
  168. data/spec/unit/command/generator_commands/generator_generator_spec.rb +229 -0
  169. data/spec/unit/command/generator_commands/lwrp_spec.rb +32 -32
  170. data/spec/unit/command/generator_commands/policyfile_spec.rb +125 -125
  171. data/spec/unit/command/generator_commands/recipe_spec.rb +34 -34
  172. data/spec/unit/command/generator_commands/repo_spec.rb +283 -283
  173. data/spec/unit/command/generator_commands/template_spec.rb +32 -32
  174. data/spec/unit/command/install_spec.rb +179 -179
  175. data/spec/unit/command/provision_spec.rb +592 -592
  176. data/spec/unit/command/push_archive_spec.rb +153 -153
  177. data/spec/unit/command/push_spec.rb +199 -199
  178. data/spec/unit/command/shell_init_spec.rb +329 -329
  179. data/spec/unit/command/show_policy_spec.rb +235 -235
  180. data/spec/unit/command/undelete_spec.rb +246 -246
  181. data/spec/unit/command/update_spec.rb +251 -251
  182. data/spec/unit/command/verify_spec.rb +323 -322
  183. data/spec/unit/commands_map_spec.rb +57 -57
  184. data/spec/unit/component_test_spec.rb +126 -126
  185. data/spec/unit/cookbook_metadata_spec.rb +98 -98
  186. data/spec/unit/cookbook_profiler/git_spec.rb +176 -176
  187. data/spec/unit/cookbook_profiler/identifiers_spec.rb +83 -83
  188. data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_one.rb +9 -9
  189. data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_two.rb +9 -9
  190. data/spec/unit/fixtures/command/cli_test_command.rb +26 -26
  191. data/spec/unit/fixtures/command/explicit_path_example.rb +7 -7
  192. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -16
  193. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/Berksfile +3 -3
  194. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -4
  195. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/chefignore +96 -96
  196. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -8
  197. data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -8
  198. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/.kitchen.yml +16 -16
  199. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/Berksfile +3 -3
  200. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/README.md +4 -4
  201. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/chefignore +96 -96
  202. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/metadata.rb +8 -8
  203. data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/recipes/default.rb +8 -8
  204. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/.kitchen.yml +16 -16
  205. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/Berksfile +3 -3
  206. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/README.md +4 -4
  207. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/chefignore +96 -96
  208. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/metadata.rb +8 -8
  209. data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/recipes/default.rb +8 -8
  210. data/spec/unit/fixtures/cookbooks_api/pruned_small_universe.json +1321 -1321
  211. data/spec/unit/fixtures/cookbooks_api/small_universe.json +2987 -2987
  212. data/spec/unit/fixtures/cookbooks_api/universe.json +1 -1
  213. data/spec/unit/fixtures/cookbooks_api/update_fixtures.rb +36 -36
  214. data/spec/unit/fixtures/dev_cookbooks/README.md +16 -16
  215. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/integration_test +2 -2
  216. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/verify_me +5 -5
  217. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/chef/verify_me +3 -3
  218. data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/test-kitchen/verify_me +2 -2
  219. data/spec/unit/fixtures/example_cookbook/.gitignore +17 -17
  220. data/spec/unit/fixtures/example_cookbook/.kitchen.yml +16 -16
  221. data/spec/unit/fixtures/example_cookbook/Berksfile +3 -3
  222. data/spec/unit/fixtures/example_cookbook/README.md +4 -4
  223. data/spec/unit/fixtures/example_cookbook/chefignore +96 -96
  224. data/spec/unit/fixtures/example_cookbook/metadata.rb +8 -8
  225. data/spec/unit/fixtures/example_cookbook/recipes/default.rb +8 -8
  226. data/spec/unit/fixtures/example_cookbook_metadata_json_only/.gitignore +17 -17
  227. data/spec/unit/fixtures/example_cookbook_metadata_json_only/.kitchen.yml +16 -16
  228. data/spec/unit/fixtures/example_cookbook_metadata_json_only/Berksfile +3 -3
  229. data/spec/unit/fixtures/example_cookbook_metadata_json_only/README.md +4 -4
  230. data/spec/unit/fixtures/example_cookbook_metadata_json_only/chefignore +96 -96
  231. data/spec/unit/fixtures/example_cookbook_metadata_json_only/metadata.json +5 -5
  232. data/spec/unit/fixtures/example_cookbook_metadata_json_only/recipes/default.rb +8 -8
  233. data/spec/unit/fixtures/example_cookbook_no_metadata/.gitignore +17 -17
  234. data/spec/unit/fixtures/example_cookbook_no_metadata/.kitchen.yml +16 -16
  235. data/spec/unit/fixtures/example_cookbook_no_metadata/Berksfile +3 -3
  236. data/spec/unit/fixtures/example_cookbook_no_metadata/README.md +4 -4
  237. data/spec/unit/fixtures/example_cookbook_no_metadata/chefignore +96 -96
  238. data/spec/unit/fixtures/example_cookbook_no_metadata/recipes/default.rb +8 -8
  239. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/README.md +4 -4
  240. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/chefignore +96 -96
  241. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/metadata.rb +8 -8
  242. data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/recipes/default.rb +8 -8
  243. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/Berksfile +3 -3
  244. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/README.md +4 -4
  245. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/chefignore +96 -96
  246. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/metadata.rb +9 -9
  247. data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/recipes/default.rb +8 -8
  248. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/.kitchen.yml +16 -16
  249. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/Berksfile +3 -3
  250. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/README.md +4 -4
  251. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/chefignore +96 -96
  252. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/metadata.rb +8 -8
  253. data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/recipes/default.rb +8 -8
  254. data/spec/unit/fixtures/local_path_cookbooks/metadata-missing/README.md +2 -2
  255. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -16
  256. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -4
  257. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -8
  258. data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -8
  259. data/spec/unit/generator_spec.rb +120 -120
  260. data/spec/unit/helpers_spec.rb +92 -92
  261. data/spec/unit/pager_spec.rb +119 -119
  262. data/spec/unit/policyfile/chef_repo_cookbook_source_spec.rb +66 -66
  263. data/spec/unit/policyfile/chef_server_cookbook_source_spec.rb +34 -34
  264. data/spec/unit/policyfile/community_cookbook_source_spec.rb +51 -51
  265. data/spec/unit/policyfile/comparison_base_spec.rb +343 -343
  266. data/spec/unit/policyfile/cookbook_location_specification_spec.rb +252 -252
  267. data/spec/unit/policyfile/cookbook_locks_spec.rb +529 -529
  268. data/spec/unit/policyfile/differ_spec.rb +687 -687
  269. data/spec/unit/policyfile/lister_spec.rb +272 -272
  270. data/spec/unit/policyfile/null_cookbook_source_spec.rb +35 -35
  271. data/spec/unit/policyfile/read_cookbook_for_compat_mode_upload_spec.rb +92 -92
  272. data/spec/unit/policyfile/reports/install_spec.rb +115 -115
  273. data/spec/unit/policyfile/reports/upload_spec.rb +96 -96
  274. data/spec/unit/policyfile/solution_dependencies_spec.rb +145 -145
  275. data/spec/unit/policyfile/storage_config_spec.rb +172 -172
  276. data/spec/unit/policyfile/undo_record_spec.rb +260 -260
  277. data/spec/unit/policyfile/undo_stack_spec.rb +266 -266
  278. data/spec/unit/policyfile/uploader_spec.rb +410 -410
  279. data/spec/unit/policyfile_demands_spec.rb +876 -876
  280. data/spec/unit/policyfile_evaluation_spec.rb +441 -441
  281. data/spec/unit/policyfile_lock_build_spec.rb +1056 -1056
  282. data/spec/unit/policyfile_lock_install_spec.rb +138 -138
  283. data/spec/unit/policyfile_lock_serialization_spec.rb +425 -425
  284. data/spec/unit/policyfile_lock_validation_spec.rb +611 -611
  285. data/spec/unit/policyfile_services/clean_policies_spec.rb +236 -236
  286. data/spec/unit/policyfile_services/clean_policy_cookbooks_spec.rb +275 -275
  287. data/spec/unit/policyfile_services/export_repo_spec.rb +439 -416
  288. data/spec/unit/policyfile_services/install_spec.rb +191 -191
  289. data/spec/unit/policyfile_services/push_archive_spec.rb +345 -345
  290. data/spec/unit/policyfile_services/push_spec.rb +233 -233
  291. data/spec/unit/policyfile_services/rm_policy_group_spec.rb +241 -241
  292. data/spec/unit/policyfile_services/rm_policy_spec.rb +266 -266
  293. data/spec/unit/policyfile_services/show_policy_spec.rb +889 -889
  294. data/spec/unit/policyfile_services/undelete_spec.rb +304 -304
  295. data/spec/unit/policyfile_services/update_attributes_spec.rb +217 -217
  296. data/spec/unit/service_exception_inspectors/base_spec.rb +43 -43
  297. data/spec/unit/service_exception_inspectors/http_spec.rb +140 -140
  298. data/spec/unit/shell_out_spec.rb +34 -34
  299. metadata +9 -3
@@ -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
+