chef-dk 0.11.2 → 0.12.0

Sign up to get free protection for your applications and to get access to all the features.
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,194 +1,194 @@
1
- # -*- encoding: utf-8 -*-
2
- #
3
- # Author:: Fletcher Nichol (<fnichol@nichol.ca>)
4
- #
5
- # Copyright (C) 2013, Fletcher Nichol
6
- #
7
- # Licensed under the Apache License, Version 2.0 (the "License");
8
- # you may not use this file except in compliance with the License.
9
- # You may obtain a copy of the License at
10
- #
11
- # http://www.apache.org/licenses/LICENSE-2.0
12
- #
13
- # Unless required by applicable law or agreed to in writing, software
14
- # distributed under the License is distributed on an "AS IS" BASIS,
15
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
- # See the License for the specific language governing permissions and
17
- # limitations under the License.
18
-
19
- require "kitchen/provisioner/chef_base"
20
-
21
- # TODO: chef-dk and kitchen can only co-exist if kitchen and chef-dk agree on
22
- # the version of mixlib-shellout to use. Kitchen currently locked at 1.4,
23
- # chef-dk is on 2.x
24
- require 'chef-dk/policyfile_services/export_repo'
25
-
26
- module Kitchen
27
-
28
- module Provisioner
29
-
30
- class Base
31
-
32
- # PolicyfileZero needs to access the base behavior of creating the
33
- # sandbox directory without invoking the behavior of
34
- # ChefBase#create_sandbox, because that will trigger the use of
35
- # Chef::CommonSandbox, which we need to override.
36
- alias_method :create_sandbox_directory, :create_sandbox
37
-
38
- end
39
-
40
- class PolicyfileSandbox < Chef::CommonSandbox
41
-
42
- # Stub #prepare_cookbooks because we have implemented this in the
43
- # provisioner, below. If a Berksfile is present, the default
44
- # implementation will try to run Berkshelf, which can lead to dependency
45
- # issues since berks is not yet using Solve 2.x. See also
46
- # PolicyfileZero#load_needed_dependencies! which is stubbed to prevent
47
- # berks from loading.
48
- def prepare_cookbooks
49
- end
50
-
51
- end
52
-
53
- # Policyfile + Chef Zero provisioner.
54
- #
55
- # @author Daniel DeLeo <dan@chef.io>
56
- class PolicyfileZero < ChefBase
57
-
58
- # This provsioner will forcibly set the following config options:
59
- # * `use_policyfile`: `true`
60
- # * `versioned_cookbooks`: `true`
61
- # * `deployment_group`: `POLICY_NAME-local`
62
- # Since it makes no sense to modify these, they are hardcoded elsewhere.
63
- default_config :client_rb, {}
64
- default_config :json_attributes, true
65
- default_config :named_run_list, nil
66
- default_config :chef_zero_host, nil
67
- default_config :chef_zero_port, 8889
68
- default_config :policyfile, "Policyfile.rb"
69
-
70
- default_config :chef_client_path do |provisioner|
71
- provisioner.
72
- remote_path_join(%W[#{provisioner[:chef_omnibus_root]} bin chef-client]).
73
- tap { |path| path.concat(".bat") if provisioner.windows_os? }
74
- end
75
-
76
- default_config :ruby_bindir do |provisioner|
77
- provisioner.
78
- remote_path_join(%W[#{provisioner[:chef_omnibus_root]} embedded bin])
79
- end
80
-
81
- # (see Base#finalize_config!)
82
- def finalize_config!(*args)
83
- super
84
- banner("Using policyfile mode for chef-client")
85
- end
86
-
87
- # (see Base#create_sandbox)
88
- def create_sandbox
89
- create_sandbox_directory
90
- PolicyfileSandbox.new(config, sandbox_path, instance).populate
91
- prepare_cookbooks
92
- prepare_validation_pem
93
- prepare_client_rb
94
- end
95
-
96
- # (see Base#run_command)
97
- def run_command
98
- level = config[:log_level] == :info ? :auto : config[:log_level]
99
- chef_client_bin = sudo(config[:chef_client_path])
100
-
101
- cmd = "#{chef_client_bin} --local-mode"
102
- args = [
103
- "--config #{config[:root_path]}/client.rb",
104
- "--log_level #{level}",
105
- "--force-formatter",
106
- "--no-color"
107
- ]
108
- if config[:chef_zero_port]
109
- args << "--chef-zero-port #{config[:chef_zero_port]}"
110
- end
111
- if config[:log_file]
112
- args << "--logfile #{config[:log_file]}"
113
- end
114
-
115
- if config[:named_run_list]
116
- args << "--named-run-list #{config[:named_run_list]}"
117
- end
118
-
119
- wrap_shell_code(
120
- [cmd, *args].join(" ").
121
- tap { |str| str.insert(0, reload_ps1_path) if windows_os? }
122
- )
123
- end
124
-
125
- # We don't want to load Berkshelf or Librarian; Policyfile is managing
126
- # dependencies, so these can only cause trouble.
127
- def load_needed_dependencies!
128
- end
129
-
130
- private
131
-
132
- # Overrides behavior of parent class so that dna.json isn't created; we
133
- # don't need it.
134
- #
135
- # @api private
136
- def prepare_json
137
- end
138
-
139
- # Copies the policyfile's cookbooks to the sandbox.
140
- #
141
- # @api private
142
- def prepare_cookbooks
143
- Kitchen.mutex.synchronize do
144
- policy_exporter.run
145
- end
146
- end
147
-
148
- # An instance of ChefDK::PolicyfileServices::ExportRepo, configured with
149
- # the sandbox path. Calling `#run` on this copies the cookbooks to the
150
- # sandbox. Calling `#policy_name` returns the policy's name.
151
- #
152
- # @api private
153
- def policy_exporter
154
- # Must force this because TK by default copies the current cookbook to the sandbox
155
- # See ChefDK::PolicyfileServices::ExportRepo#assert_export_dir_clean!
156
- @policy_exporter ||= ChefDK::PolicyfileServices::ExportRepo.new(policyfile: config[:policyfile],
157
- export_dir: sandbox_path,
158
- force: true)
159
- end
160
-
161
- # Writes a fake (but valid) validation.pem into the sandbox directory.
162
- #
163
- # @api private
164
- def prepare_validation_pem
165
- info("Preparing validation.pem")
166
- debug("Using a dummy validation.pem")
167
-
168
- source = File.join(Kitchen.source_root, %w[support dummy-validation.pem])
169
- FileUtils.cp(source, File.join(sandbox_path, "validation.pem"))
170
- end
171
-
172
- # Writes a client.rb configuration file to the sandbox directory.
173
- #
174
- # @api private
175
- def prepare_client_rb
176
- data = default_config_rb.merge(config[:client_rb])
177
-
178
- data["use_policyfile"] = true
179
- data["versioned_cookbooks"] = true
180
- data["policy_name"] = policy_exporter.policy_name
181
- data["policy_group"] = "local"
182
- data["policy_document_native_api"] = true
183
-
184
- info("Preparing client.rb")
185
- debug("Creating client.rb from #{data.inspect}")
186
-
187
- File.open(File.join(sandbox_path, "client.rb"), "wb") do |file|
188
- file.write(format_config_file(data))
189
- end
190
- end
191
-
192
- end
193
- end
194
- end
1
+ # -*- encoding: utf-8 -*-
2
+ #
3
+ # Author:: Fletcher Nichol (<fnichol@nichol.ca>)
4
+ #
5
+ # Copyright (C) 2013, Fletcher Nichol
6
+ #
7
+ # Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ # See the License for the specific language governing permissions and
17
+ # limitations under the License.
18
+
19
+ require "kitchen/provisioner/chef_base"
20
+
21
+ # TODO: chef-dk and kitchen can only co-exist if kitchen and chef-dk agree on
22
+ # the version of mixlib-shellout to use. Kitchen currently locked at 1.4,
23
+ # chef-dk is on 2.x
24
+ require 'chef-dk/policyfile_services/export_repo'
25
+
26
+ module Kitchen
27
+
28
+ module Provisioner
29
+
30
+ class Base
31
+
32
+ # PolicyfileZero needs to access the base behavior of creating the
33
+ # sandbox directory without invoking the behavior of
34
+ # ChefBase#create_sandbox, because that will trigger the use of
35
+ # Chef::CommonSandbox, which we need to override.
36
+ alias_method :create_sandbox_directory, :create_sandbox
37
+
38
+ end
39
+
40
+ class PolicyfileSandbox < Chef::CommonSandbox
41
+
42
+ # Stub #prepare_cookbooks because we have implemented this in the
43
+ # provisioner, below. If a Berksfile is present, the default
44
+ # implementation will try to run Berkshelf, which can lead to dependency
45
+ # issues since berks is not yet using Solve 2.x. See also
46
+ # PolicyfileZero#load_needed_dependencies! which is stubbed to prevent
47
+ # berks from loading.
48
+ def prepare_cookbooks
49
+ end
50
+
51
+ end
52
+
53
+ # Policyfile + Chef Zero provisioner.
54
+ #
55
+ # @author Daniel DeLeo <dan@chef.io>
56
+ class PolicyfileZero < ChefBase
57
+
58
+ # This provsioner will forcibly set the following config options:
59
+ # * `use_policyfile`: `true`
60
+ # * `versioned_cookbooks`: `true`
61
+ # * `deployment_group`: `POLICY_NAME-local`
62
+ # Since it makes no sense to modify these, they are hardcoded elsewhere.
63
+ default_config :client_rb, {}
64
+ default_config :json_attributes, true
65
+ default_config :named_run_list, nil
66
+ default_config :chef_zero_host, nil
67
+ default_config :chef_zero_port, 8889
68
+ default_config :policyfile, "Policyfile.rb"
69
+
70
+ default_config :chef_client_path do |provisioner|
71
+ provisioner.
72
+ remote_path_join(%W[#{provisioner[:chef_omnibus_root]} bin chef-client]).
73
+ tap { |path| path.concat(".bat") if provisioner.windows_os? }
74
+ end
75
+
76
+ default_config :ruby_bindir do |provisioner|
77
+ provisioner.
78
+ remote_path_join(%W[#{provisioner[:chef_omnibus_root]} embedded bin])
79
+ end
80
+
81
+ # (see Base#finalize_config!)
82
+ def finalize_config!(*args)
83
+ super
84
+ banner("Using policyfile mode for chef-client")
85
+ end
86
+
87
+ # (see Base#create_sandbox)
88
+ def create_sandbox
89
+ create_sandbox_directory
90
+ PolicyfileSandbox.new(config, sandbox_path, instance).populate
91
+ prepare_cookbooks
92
+ prepare_validation_pem
93
+ prepare_client_rb
94
+ end
95
+
96
+ # (see Base#run_command)
97
+ def run_command
98
+ level = config[:log_level] == :info ? :auto : config[:log_level]
99
+ chef_client_bin = sudo(config[:chef_client_path])
100
+
101
+ cmd = "#{chef_client_bin} --local-mode"
102
+ args = [
103
+ "--config #{config[:root_path]}/client.rb",
104
+ "--log_level #{level}",
105
+ "--force-formatter",
106
+ "--no-color"
107
+ ]
108
+ if config[:chef_zero_port]
109
+ args << "--chef-zero-port #{config[:chef_zero_port]}"
110
+ end
111
+ if config[:log_file]
112
+ args << "--logfile #{config[:log_file]}"
113
+ end
114
+
115
+ if config[:named_run_list]
116
+ args << "--named-run-list #{config[:named_run_list]}"
117
+ end
118
+
119
+ wrap_shell_code(
120
+ [cmd, *args].join(" ").
121
+ tap { |str| str.insert(0, reload_ps1_path) if windows_os? }
122
+ )
123
+ end
124
+
125
+ # We don't want to load Berkshelf or Librarian; Policyfile is managing
126
+ # dependencies, so these can only cause trouble.
127
+ def load_needed_dependencies!
128
+ end
129
+
130
+ private
131
+
132
+ # Overrides behavior of parent class so that dna.json isn't created; we
133
+ # don't need it.
134
+ #
135
+ # @api private
136
+ def prepare_json
137
+ end
138
+
139
+ # Copies the policyfile's cookbooks to the sandbox.
140
+ #
141
+ # @api private
142
+ def prepare_cookbooks
143
+ Kitchen.mutex.synchronize do
144
+ policy_exporter.run
145
+ end
146
+ end
147
+
148
+ # An instance of ChefDK::PolicyfileServices::ExportRepo, configured with
149
+ # the sandbox path. Calling `#run` on this copies the cookbooks to the
150
+ # sandbox. Calling `#policy_name` returns the policy's name.
151
+ #
152
+ # @api private
153
+ def policy_exporter
154
+ # Must force this because TK by default copies the current cookbook to the sandbox
155
+ # See ChefDK::PolicyfileServices::ExportRepo#assert_export_dir_clean!
156
+ @policy_exporter ||= ChefDK::PolicyfileServices::ExportRepo.new(policyfile: config[:policyfile],
157
+ export_dir: sandbox_path,
158
+ force: true)
159
+ end
160
+
161
+ # Writes a fake (but valid) validation.pem into the sandbox directory.
162
+ #
163
+ # @api private
164
+ def prepare_validation_pem
165
+ info("Preparing validation.pem")
166
+ debug("Using a dummy validation.pem")
167
+
168
+ source = File.join(Kitchen.source_root, %w[support dummy-validation.pem])
169
+ FileUtils.cp(source, File.join(sandbox_path, "validation.pem"))
170
+ end
171
+
172
+ # Writes a client.rb configuration file to the sandbox directory.
173
+ #
174
+ # @api private
175
+ def prepare_client_rb
176
+ data = default_config_rb.merge(config[:client_rb])
177
+
178
+ data["use_policyfile"] = true
179
+ data["versioned_cookbooks"] = true
180
+ data["policy_name"] = policy_exporter.policy_name
181
+ data["policy_group"] = "local"
182
+ data["policy_document_native_api"] = true
183
+
184
+ info("Preparing client.rb")
185
+ debug("Creating client.rb from #{data.inspect}")
186
+
187
+ File.open(File.join(sandbox_path, "client.rb"), "wb") do |file|
188
+ file.write(format_config_file(data))
189
+ end
190
+ end
191
+
192
+ end
193
+ end
194
+ end
@@ -1,125 +1,125 @@
1
- shared_examples_for "a file generator" do
2
-
3
- let(:stdout_io) { StringIO.new }
4
- let(:stderr_io) { StringIO.new }
5
-
6
- def stdout
7
- stdout_io.string
8
- end
9
-
10
- def stderr
11
- stderr_io.string
12
- end
13
-
14
- let(:expected_cookbook_root) { tempdir }
15
- let(:cookbook_name) { "example_cookbook" }
16
-
17
- let(:cookbook_path) { File.join(tempdir, cookbook_name) }
18
-
19
- subject(:recipe_generator) do
20
- generator = described_class.new(argv)
21
- allow(generator).to receive(:stdout).and_return(stdout_io)
22
- allow(generator).to receive(:stderr).and_return(stderr_io)
23
- generator
24
- end
25
-
26
- def generator_context
27
- ChefDK::Generator.context
28
- end
29
-
30
- before do
31
- ChefDK::Generator.reset
32
- reset_tempdir
33
- end
34
-
35
- after(:each) do
36
- ChefDK::Generator::Context.reset
37
- end
38
-
39
- context "when argv is empty" do
40
- let(:argv) { [] }
41
-
42
- it "emits an error message and exits" do
43
- expected_stdout = "Usage: chef generate #{generator_name} [path/to/cookbook] NAME [options]"
44
-
45
- expect(recipe_generator.run).to eq(1)
46
- expect(stdout).to include(expected_stdout)
47
- end
48
- end
49
-
50
- context "when CWD is a cookbook" do
51
-
52
- let(:argv) { [ new_file_name ] }
53
-
54
- before do
55
- FileUtils.cp_r(File.join(fixtures_path, "example_cookbook"), tempdir)
56
- end
57
-
58
- it "configures the generator context" do
59
- Dir.chdir(cookbook_path) do
60
- recipe_generator.read_and_validate_params
61
- recipe_generator.setup_context
62
-
63
- expect(generator_context.cookbook_root).to eq(expected_cookbook_root)
64
- expect(generator_context.cookbook_name).to eq(cookbook_name)
65
- expect(generator_context.new_file_basename).to eq(new_file_name)
66
- expect(generator_context.recipe_name).to eq(new_file_name)
67
- end
68
- end
69
-
70
- it "creates a new recipe" do
71
- Dir.chdir(cookbook_path) do
72
- allow(recipe_generator.chef_runner).to receive(:stdout).and_return(stdout_io)
73
- recipe_generator.run
74
- end
75
-
76
- generated_files.each do |expected_file|
77
- expect(File).to exist(File.join(cookbook_path, expected_file))
78
- end
79
- end
80
-
81
- end
82
-
83
- context "when CWD is not a cookbook" do
84
- context "and path to the cookbook is not given in the agv" do
85
- let(:argv) { [ new_file_name ] }
86
-
87
- it "emits an error message and exits" do
88
- expected_stdout = "Usage: chef generate #{generator_name} [path/to/cookbook] NAME [options]"
89
- expected_stderr = "Error: Directory #{Dir.pwd} is not a cookbook\n"
90
-
91
- expect(recipe_generator.run).to eq(1)
92
- expect(stdout).to include(expected_stdout)
93
- expect(stderr).to eq(expected_stderr)
94
- end
95
- end
96
-
97
- context "and path to the cookbook is given in the argv" do
98
- let(:argv) { [cookbook_path, new_file_name ] }
99
-
100
- before do
101
- FileUtils.cp_r(File.join(fixtures_path, "example_cookbook"), tempdir)
102
- end
103
-
104
- it "configures the generator context" do
105
- recipe_generator.read_and_validate_params
106
- recipe_generator.setup_context
107
-
108
- expect(generator_context.cookbook_root).to eq(File.dirname(cookbook_path))
109
- expect(generator_context.cookbook_name).to eq(cookbook_name)
110
- expect(generator_context.new_file_basename).to eq(new_file_name)
111
- end
112
-
113
- it "creates a new recipe" do
114
- allow(recipe_generator.chef_runner).to receive(:stdout).and_return(stdout_io)
115
- recipe_generator.run
116
-
117
- generated_files.each do |expected_file|
118
- expect(File).to exist(File.join(cookbook_path, expected_file))
119
- end
120
- end
121
-
122
- end
123
- end
124
-
125
- end
1
+ shared_examples_for "a file generator" do
2
+
3
+ let(:stdout_io) { StringIO.new }
4
+ let(:stderr_io) { StringIO.new }
5
+
6
+ def stdout
7
+ stdout_io.string
8
+ end
9
+
10
+ def stderr
11
+ stderr_io.string
12
+ end
13
+
14
+ let(:expected_cookbook_root) { tempdir }
15
+ let(:cookbook_name) { "example_cookbook" }
16
+
17
+ let(:cookbook_path) { File.join(tempdir, cookbook_name) }
18
+
19
+ subject(:recipe_generator) do
20
+ generator = described_class.new(argv)
21
+ allow(generator).to receive(:stdout).and_return(stdout_io)
22
+ allow(generator).to receive(:stderr).and_return(stderr_io)
23
+ generator
24
+ end
25
+
26
+ def generator_context
27
+ ChefDK::Generator.context
28
+ end
29
+
30
+ before do
31
+ ChefDK::Generator.reset
32
+ reset_tempdir
33
+ end
34
+
35
+ after(:each) do
36
+ ChefDK::Generator::Context.reset
37
+ end
38
+
39
+ context "when argv is empty" do
40
+ let(:argv) { [] }
41
+
42
+ it "emits an error message and exits" do
43
+ expected_stdout = "Usage: chef generate #{generator_name} [path/to/cookbook] NAME [options]"
44
+
45
+ expect(recipe_generator.run).to eq(1)
46
+ expect(stdout).to include(expected_stdout)
47
+ end
48
+ end
49
+
50
+ context "when CWD is a cookbook" do
51
+
52
+ let(:argv) { [ new_file_name ] }
53
+
54
+ before do
55
+ FileUtils.cp_r(File.join(fixtures_path, "example_cookbook"), tempdir)
56
+ end
57
+
58
+ it "configures the generator context" do
59
+ Dir.chdir(cookbook_path) do
60
+ recipe_generator.read_and_validate_params
61
+ recipe_generator.setup_context
62
+
63
+ expect(generator_context.cookbook_root).to eq(expected_cookbook_root)
64
+ expect(generator_context.cookbook_name).to eq(cookbook_name)
65
+ expect(generator_context.new_file_basename).to eq(new_file_name)
66
+ expect(generator_context.recipe_name).to eq(new_file_name)
67
+ end
68
+ end
69
+
70
+ it "creates a new recipe" do
71
+ Dir.chdir(cookbook_path) do
72
+ allow(recipe_generator.chef_runner).to receive(:stdout).and_return(stdout_io)
73
+ recipe_generator.run
74
+ end
75
+
76
+ generated_files.each do |expected_file|
77
+ expect(File).to exist(File.join(cookbook_path, expected_file))
78
+ end
79
+ end
80
+
81
+ end
82
+
83
+ context "when CWD is not a cookbook" do
84
+ context "and path to the cookbook is not given in the agv" do
85
+ let(:argv) { [ new_file_name ] }
86
+
87
+ it "emits an error message and exits" do
88
+ expected_stdout = "Usage: chef generate #{generator_name} [path/to/cookbook] NAME [options]"
89
+ expected_stderr = "Error: Directory #{Dir.pwd} is not a cookbook\n"
90
+
91
+ expect(recipe_generator.run).to eq(1)
92
+ expect(stdout).to include(expected_stdout)
93
+ expect(stderr).to eq(expected_stderr)
94
+ end
95
+ end
96
+
97
+ context "and path to the cookbook is given in the argv" do
98
+ let(:argv) { [cookbook_path, new_file_name ] }
99
+
100
+ before do
101
+ FileUtils.cp_r(File.join(fixtures_path, "example_cookbook"), tempdir)
102
+ end
103
+
104
+ it "configures the generator context" do
105
+ recipe_generator.read_and_validate_params
106
+ recipe_generator.setup_context
107
+
108
+ expect(generator_context.cookbook_root).to eq(File.dirname(cookbook_path))
109
+ expect(generator_context.cookbook_name).to eq(cookbook_name)
110
+ expect(generator_context.new_file_basename).to eq(new_file_name)
111
+ end
112
+
113
+ it "creates a new recipe" do
114
+ allow(recipe_generator.chef_runner).to receive(:stdout).and_return(stdout_io)
115
+ recipe_generator.run
116
+
117
+ generated_files.each do |expected_file|
118
+ expect(File).to exist(File.join(cookbook_path, expected_file))
119
+ end
120
+ end
121
+
122
+ end
123
+ end
124
+
125
+ end