chef 12.10.24 → 12.11.18

Sign up to get free protection for your applications and to get access to all the features.
Files changed (523) hide show
  1. checksums.yaml +4 -4
  2. data/CONTRIBUTING.md +3 -38
  3. data/Gemfile +6 -11
  4. data/LICENSE +201 -201
  5. data/README.md +11 -1
  6. data/VERSION +1 -1
  7. data/acceptance/.bundle/config +2 -0
  8. data/acceptance/Gemfile.lock +27 -26
  9. data/acceptance/basics/.kitchen/logs/chef-current-install-ubuntu-1404.log +2 -0
  10. data/acceptance/basics/.kitchen/logs/kitchen.log +3 -0
  11. data/acceptance/data-collector/.acceptance/acceptance-cookbook/.gitignore +2 -0
  12. data/acceptance/data-collector/.acceptance/acceptance-cookbook/metadata.rb +3 -0
  13. data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/destroy.rb +2 -0
  14. data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/provision.rb +2 -0
  15. data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/verify.rb +2 -0
  16. data/acceptance/data-collector/.acceptance/data-collector-test/.gitignore +16 -0
  17. data/acceptance/data-collector/.acceptance/data-collector-test/Berksfile +3 -0
  18. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/api.rb +85 -0
  19. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/apigemfile +3 -0
  20. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-both-mode.rb +4 -0
  21. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-client-mode.rb +4 -0
  22. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-no-endpoint.rb +2 -0
  23. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-solo-mode.rb +4 -0
  24. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/config.ru +2 -0
  25. data/acceptance/data-collector/.acceptance/data-collector-test/metadata.rb +7 -0
  26. data/acceptance/data-collector/.acceptance/data-collector-test/recipes/default.rb +38 -0
  27. data/acceptance/data-collector/.kitchen.yml +9 -0
  28. data/acceptance/data-collector/Berksfile +3 -0
  29. data/acceptance/data-collector/Berksfile.lock +6 -0
  30. data/acceptance/data-collector/test/integration/default/serverspec/default_spec.rb +251 -0
  31. data/acceptance/fips/.kitchen/logs/fips-integration-centos-6.log +3 -0
  32. data/acceptance/fips/.kitchen/logs/fips-integration-windows-2012r2.log +3 -0
  33. data/acceptance/fips/.kitchen/logs/fips-unit-functional-centos-6.log +3 -0
  34. data/acceptance/fips/.kitchen/logs/fips-unit-functional-windows-2012r2.log +3 -0
  35. data/acceptance/fips/.kitchen/logs/kitchen.log +6 -0
  36. data/acceptance/fips/test/integration/fips-integration/serverspec/fips-integration_spec.rb +2 -1
  37. data/acceptance/top-cookbooks/.kitchen.docker.yml +1 -4
  38. data/acceptance/trivial/.kitchen/logs/chef-current-install-windows-2012r2.log +2 -0
  39. data/acceptance/trivial/.kitchen/logs/kitchen.log +3 -0
  40. data/acceptance/windows-service/.kitchen/logs/chef-windows-service-windows-2012r2.log +2 -0
  41. data/acceptance/windows-service/.kitchen/logs/kitchen.log +3 -0
  42. data/bin/chef-apply +0 -0
  43. data/bin/chef-client +0 -0
  44. data/bin/chef-shell +0 -0
  45. data/bin/chef-solo +0 -0
  46. data/bin/knife +0 -0
  47. data/chef.gemspec +1 -0
  48. data/distro/common/html/_sources/ctl_chef_client.txt +35 -35
  49. data/distro/common/html/_sources/ctl_chef_server.txt +341 -341
  50. data/distro/common/html/_sources/ctl_chef_shell.txt +15 -15
  51. data/distro/common/html/_sources/ctl_chef_solo.txt +25 -25
  52. data/distro/common/html/_sources/index.txt +135 -135
  53. data/distro/common/html/_sources/knife.txt +74 -74
  54. data/distro/common/html/_sources/knife_bootstrap.txt +56 -56
  55. data/distro/common/html/_sources/knife_client.txt +150 -150
  56. data/distro/common/html/_sources/knife_common_options.txt +6 -6
  57. data/distro/common/html/_sources/knife_configure.txt +29 -29
  58. data/distro/common/html/_sources/knife_cookbook.txt +236 -236
  59. data/distro/common/html/_sources/knife_cookbook_site.txt +157 -157
  60. data/distro/common/html/_sources/knife_data_bag.txt +159 -159
  61. data/distro/common/html/_sources/knife_delete.txt +26 -26
  62. data/distro/common/html/_sources/knife_deps.txt +61 -61
  63. data/distro/common/html/_sources/knife_diff.txt +34 -34
  64. data/distro/common/html/_sources/knife_download.txt +44 -44
  65. data/distro/common/html/_sources/knife_edit.txt +26 -26
  66. data/distro/common/html/_sources/knife_environment.txt +158 -158
  67. data/distro/common/html/_sources/knife_exec.txt +47 -47
  68. data/distro/common/html/_sources/knife_index_rebuild.txt +20 -20
  69. data/distro/common/html/_sources/knife_list.txt +33 -33
  70. data/distro/common/html/_sources/knife_node.txt +250 -250
  71. data/distro/common/html/_sources/knife_raw.txt +35 -35
  72. data/distro/common/html/_sources/knife_recipe_list.txt +23 -23
  73. data/distro/common/html/_sources/knife_role.txt +157 -157
  74. data/distro/common/html/_sources/knife_search.txt +53 -53
  75. data/distro/common/html/_sources/knife_serve.txt +18 -18
  76. data/distro/common/html/_sources/knife_show.txt +26 -26
  77. data/distro/common/html/_sources/knife_ssh.txt +43 -43
  78. data/distro/common/html/_sources/knife_ssl_check.txt +41 -41
  79. data/distro/common/html/_sources/knife_ssl_fetch.txt +41 -41
  80. data/distro/common/html/_sources/knife_status.txt +37 -37
  81. data/distro/common/html/_sources/knife_tag.txt +69 -69
  82. data/distro/common/html/_sources/knife_upload.txt +49 -49
  83. data/distro/common/html/_sources/knife_user.txt +127 -127
  84. data/distro/common/html/_sources/knife_using.txt +43 -43
  85. data/distro/common/html/_sources/knife_xargs.txt +30 -30
  86. data/distro/common/html/_static/guide.css +504 -504
  87. data/distro/common/html/_static/pygments.css +61 -61
  88. data/distro/common/html/_static/underscore.js +31 -31
  89. data/distro/common/html/ctl_chef_client.html +269 -269
  90. data/distro/common/html/ctl_chef_server.html +727 -727
  91. data/distro/common/html/ctl_chef_shell.html +162 -162
  92. data/distro/common/html/ctl_chef_solo.html +193 -193
  93. data/distro/common/html/index.html +201 -201
  94. data/distro/common/html/knife.html +169 -169
  95. data/distro/common/html/knife_bootstrap.html +284 -284
  96. data/distro/common/html/knife_client.html +284 -284
  97. data/distro/common/html/knife_common_options.html +95 -95
  98. data/distro/common/html/knife_configure.html +104 -104
  99. data/distro/common/html/knife_cookbook.html +486 -486
  100. data/distro/common/html/knife_data_bag.html +373 -373
  101. data/distro/common/html/knife_delete.html +92 -92
  102. data/distro/common/html/knife_deps.html +142 -142
  103. data/distro/common/html/knife_diff.html +122 -122
  104. data/distro/common/html/knife_download.html +144 -144
  105. data/distro/common/html/knife_edit.html +88 -88
  106. data/distro/common/html/knife_environment.html +325 -325
  107. data/distro/common/html/knife_exec.html +219 -219
  108. data/distro/common/html/knife_index_rebuild.html +82 -82
  109. data/distro/common/html/knife_list.html +113 -113
  110. data/distro/common/html/knife_node.html +457 -457
  111. data/distro/common/html/knife_raw.html +109 -109
  112. data/distro/common/html/knife_recipe_list.html +90 -90
  113. data/distro/common/html/knife_role.html +294 -294
  114. data/distro/common/html/knife_search.html +202 -202
  115. data/distro/common/html/knife_serve.html +78 -78
  116. data/distro/common/html/knife_show.html +103 -103
  117. data/distro/common/html/knife_ssh.html +176 -176
  118. data/distro/common/html/knife_ssl_check.html +150 -150
  119. data/distro/common/html/knife_ssl_fetch.html +150 -150
  120. data/distro/common/html/knife_status.html +143 -143
  121. data/distro/common/html/knife_tag.html +137 -137
  122. data/distro/common/html/knife_upload.html +152 -152
  123. data/distro/common/html/knife_user.html +241 -241
  124. data/distro/common/html/knife_using.html +209 -209
  125. data/distro/common/html/knife_xargs.html +121 -121
  126. data/distro/common/html/search.html +81 -81
  127. data/distro/common/man/man1/README.md +58 -58
  128. data/distro/common/man/man1/chef-shell.1 +194 -194
  129. data/distro/common/man/man1/knife-bootstrap.1 +215 -215
  130. data/distro/common/man/man1/knife-client.1 +443 -443
  131. data/distro/common/man/man1/knife-configure.1 +161 -161
  132. data/distro/common/man/man1/knife-cookbook.1 +770 -770
  133. data/distro/common/man/man1/knife-data-bag.1 +617 -617
  134. data/distro/common/man/man1/knife-delete.1 +127 -127
  135. data/distro/common/man/man1/knife-deps.1 +246 -246
  136. data/distro/common/man/man1/knife-diff.1 +226 -226
  137. data/distro/common/man/man1/knife-download.1 +258 -258
  138. data/distro/common/man/man1/knife-edit.1 +121 -121
  139. data/distro/common/man/man1/knife-environment.1 +508 -508
  140. data/distro/common/man/man1/knife-exec.1 +362 -362
  141. data/distro/common/man/man1/knife-index-rebuild.1 +63 -63
  142. data/distro/common/man/man1/knife-list.1 +174 -174
  143. data/distro/common/man/man1/knife-node.1 +716 -716
  144. data/distro/common/man/man1/knife-raw.1 +172 -172
  145. data/distro/common/man/man1/knife-recipe-list.1 +85 -85
  146. data/distro/common/man/man1/knife-role.1 +426 -426
  147. data/distro/common/man/man1/knife-search.1 +359 -359
  148. data/distro/common/man/man1/knife-serve.1 +109 -109
  149. data/distro/common/man/man1/knife-show.1 +160 -160
  150. data/distro/common/man/man1/knife-ssh.1 +284 -284
  151. data/distro/common/man/man1/knife-ssl-check.1 +207 -207
  152. data/distro/common/man/man1/knife-ssl-fetch.1 +207 -207
  153. data/distro/common/man/man1/knife-status.1 +234 -234
  154. data/distro/common/man/man1/knife-tag.1 +189 -189
  155. data/distro/common/man/man1/knife-upload.1 +280 -280
  156. data/distro/common/man/man1/knife-user.1 +356 -356
  157. data/distro/common/man/man1/knife-xargs.1 +189 -189
  158. data/distro/common/man/man1/knife.1 +332 -332
  159. data/distro/common/man/man8/chef-apply.8 +86 -86
  160. data/distro/common/man/man8/chef-client.8 +398 -398
  161. data/distro/common/man/man8/chef-solo.8 +260 -260
  162. data/distro/common/markdown/README +3 -3
  163. data/lib/chef/application.rb +14 -9
  164. data/lib/chef/application/apply.rb +5 -5
  165. data/lib/chef/application/client.rb +3 -3
  166. data/lib/chef/application/exit_code.rb +226 -0
  167. data/lib/chef/application/solo.rb +37 -7
  168. data/lib/chef/application/windows_service.rb +3 -3
  169. data/lib/chef/chef_fs/command_line.rb +7 -0
  170. data/lib/chef/chef_fs/config.rb +1 -1
  171. data/lib/chef/chef_fs/data_handler/data_handler_base.rb +11 -10
  172. data/lib/chef/chef_fs/data_handler/environment_data_handler.rb +1 -1
  173. data/lib/chef/chef_fs/data_handler/role_data_handler.rb +1 -1
  174. data/lib/chef/chef_fs/file_system.rb +15 -13
  175. data/lib/chef/chef_fs/file_system/base_fs_object.rb +4 -0
  176. data/lib/chef/chef_fs/file_system/chef_server/acl_dir.rb +1 -1
  177. data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +9 -0
  178. data/lib/chef/chef_fs/file_system/chef_server/data_bag_dir.rb +6 -0
  179. data/lib/chef/chef_fs/file_system/chef_server/data_bag_entry.rb +19 -0
  180. data/lib/chef/chef_fs/file_system/chef_server/environments_dir.rb +1 -1
  181. data/lib/chef/chef_fs/file_system/chef_server/nodes_dir.rb +1 -1
  182. data/lib/chef/chef_fs/file_system/chef_server/org_entry.rb +4 -0
  183. data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +4 -0
  184. data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +4 -0
  185. data/lib/chef/chef_fs/file_system/chef_server/policy_revision_entry.rb +4 -0
  186. data/lib/chef/chef_fs/file_system/chef_server/rest_list_dir.rb +3 -3
  187. data/lib/chef/chef_fs/file_system/chef_server/rest_list_entry.rb +15 -4
  188. data/lib/chef/chef_fs/file_system/exceptions.rb +7 -0
  189. data/lib/chef/chef_fs/file_system/multiplexed_dir.rb +2 -2
  190. data/lib/chef/chef_fs/file_system/nonexistent_fs_object.rb +0 -4
  191. data/lib/chef/chef_fs/file_system/repository/acl.rb +7 -0
  192. data/lib/chef/chef_fs/file_system/repository/acls_sub_dir.rb +0 -4
  193. data/lib/chef/chef_fs/file_system/repository/base_file.rb +36 -4
  194. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +4 -0
  195. data/lib/chef/chef_fs/file_system/repository/client_keys_sub_dir.rb +0 -4
  196. data/lib/chef/chef_fs/file_system/repository/clients_dir.rb +0 -3
  197. data/lib/chef/chef_fs/file_system/repository/containers_dir.rb +0 -4
  198. data/lib/chef/chef_fs/file_system/repository/directory.rb +4 -0
  199. data/lib/chef/chef_fs/file_system/repository/environments_dir.rb +0 -4
  200. data/lib/chef/chef_fs/file_system/repository/groups_dir.rb +0 -4
  201. data/lib/chef/chef_fs/file_system/repository/nodes_dir.rb +0 -4
  202. data/lib/chef/chef_fs/file_system/repository/policy_groups_dir.rb +0 -4
  203. data/lib/chef/chef_fs/file_system/repository/roles_dir.rb +0 -4
  204. data/lib/chef/chef_fs/file_system/repository/users_dir.rb +0 -4
  205. data/lib/chef/client.rb +11 -3
  206. data/lib/chef/config_fetcher.rb +4 -4
  207. data/lib/chef/cookbook/gem_installer.rb +1 -0
  208. data/lib/chef/cookbook/synchronizer.rb +1 -1
  209. data/lib/chef/data_bag.rb +2 -2
  210. data/lib/chef/data_bag_item.rb +1 -1
  211. data/lib/chef/data_collector.rb +345 -0
  212. data/lib/chef/data_collector/messages.rb +125 -0
  213. data/lib/chef/data_collector/messages/helpers.rb +161 -0
  214. data/lib/chef/data_collector/resource_report.rb +84 -0
  215. data/lib/chef/decorator.rb +81 -0
  216. data/lib/chef/decorator/lazy.rb +60 -0
  217. data/lib/chef/decorator/lazy_array.rb +59 -0
  218. data/lib/chef/deprecation/provider/remote_file.rb +1 -1
  219. data/lib/chef/dsl/core.rb +19 -11
  220. data/lib/chef/dsl/platform_introspection.rb +16 -0
  221. data/lib/chef/dsl/recipe.rb +15 -9
  222. data/lib/chef/dsl/universal.rb +50 -0
  223. data/lib/chef/environment.rb +2 -2
  224. data/lib/chef/exceptions.rb +19 -4
  225. data/lib/chef/handler.rb +33 -0
  226. data/lib/chef/knife/cookbook_show.rb +6 -10
  227. data/lib/chef/knife/cookbook_site_install.rb +7 -2
  228. data/lib/chef/knife/help_topics.rb +4 -4
  229. data/lib/chef/knife/list.rb +1 -2
  230. data/lib/chef/knife/ssl_check.rb +2 -1
  231. data/lib/chef/monkey_patches/win32/registry.rb +11 -0
  232. data/lib/chef/nil_argument.rb +3 -3
  233. data/lib/chef/node.rb +2 -2
  234. data/lib/chef/platform/rebooter.rb +13 -2
  235. data/lib/chef/policy_builder/dynamic.rb +1 -1
  236. data/lib/chef/policy_builder/expand_node_object.rb +3 -3
  237. data/lib/chef/policy_builder/policyfile.rb +1 -1
  238. data/lib/chef/provider/git.rb +43 -41
  239. data/lib/chef/provider/lwrp_base.rb +0 -1
  240. data/lib/chef/provider/osx_profile.rb +2 -3
  241. data/lib/chef/provider/package.rb +51 -13
  242. data/lib/chef/provider/package/apt.rb +97 -103
  243. data/lib/chef/provider/package/chocolatey.rb +9 -10
  244. data/lib/chef/provider/package/dpkg.rb +2 -2
  245. data/lib/chef/provider/package/portage.rb +1 -1
  246. data/lib/chef/provider/package/rubygems.rb +8 -12
  247. data/lib/chef/provider/package/yum.rb +4 -959
  248. data/lib/chef/provider/package/yum/rpm_utils.rb +642 -0
  249. data/lib/chef/provider/package/{yum-dump.py → yum/yum-dump.py} +0 -0
  250. data/lib/chef/provider/package/yum/yum_cache.rb +376 -0
  251. data/lib/chef/provider/resource_update.rb +52 -52
  252. data/lib/chef/provider/systemd_unit.rb +238 -0
  253. data/lib/chef/providers.rb +1 -0
  254. data/lib/chef/reserved_names.rb +9 -9
  255. data/lib/chef/resource.rb +2 -7
  256. data/lib/chef/resource/file.rb +6 -1
  257. data/lib/chef/resource/systemd_unit.rb +63 -0
  258. data/lib/chef/resources.rb +1 -0
  259. data/lib/chef/sandbox.rb +20 -20
  260. data/lib/chef/shell/shell_session.rb +3 -3
  261. data/lib/chef/version.rb +1 -1
  262. data/lib/chef/win32/system.rb +0 -0
  263. data/spec/data/apt/chef-integration-test-1.0/debian/changelog +5 -5
  264. data/spec/data/apt/chef-integration-test-1.0/debian/compat +1 -1
  265. data/spec/data/apt/chef-integration-test-1.0/debian/control +13 -13
  266. data/spec/data/apt/chef-integration-test-1.0/debian/files +1 -1
  267. data/spec/data/apt/chef-integration-test-1.0/debian/rules +13 -13
  268. data/spec/data/apt/chef-integration-test-1.0/debian/source/format +1 -1
  269. data/spec/data/apt/chef-integration-test-1.1/debian/changelog +11 -11
  270. data/spec/data/apt/chef-integration-test-1.1/debian/compat +1 -1
  271. data/spec/data/apt/chef-integration-test-1.1/debian/control +13 -13
  272. data/spec/data/apt/chef-integration-test-1.1/debian/files +1 -1
  273. data/spec/data/apt/chef-integration-test-1.1/debian/rules +13 -13
  274. data/spec/data/apt/chef-integration-test-1.1/debian/source/format +1 -1
  275. data/spec/data/apt/chef-integration-test2-1.0/debian/rules +0 -0
  276. data/spec/data/apt/chef-integration-test_1.0-1_amd64.changes +22 -22
  277. data/spec/data/apt/chef-integration-test_1.1-1_amd64.changes +22 -22
  278. data/spec/data/apt/var/www/apt/conf/distributions +7 -7
  279. data/spec/data/apt/var/www/apt/conf/incoming +4 -4
  280. data/spec/data/apt/var/www/apt/conf/pulls +3 -3
  281. data/spec/data/apt/var/www/apt/db/version +4 -4
  282. data/spec/data/apt/var/www/apt/dists/sid/Release +19 -19
  283. data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Packages +16 -16
  284. data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Release +5 -5
  285. data/spec/data/bootstrap/encrypted_data_bag_secret +1 -1
  286. data/spec/data/bootstrap/no_proxy.erb +2 -2
  287. data/spec/data/bootstrap/secret.erb +9 -9
  288. data/spec/data/bootstrap/test-hints.erb +12 -12
  289. data/spec/data/bootstrap/test.erb +1 -1
  290. data/spec/data/cb_version_cookbooks/tatft/README.rdoc +2 -2
  291. data/spec/data/cb_version_cookbooks/tatft/attributes/default.rb +1 -1
  292. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-600hhz-0 +1 -1
  293. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ahd2gq-0 +1 -1
  294. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-api8ux-0 +1 -1
  295. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-b0r1m1-0 +1 -1
  296. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-bfygsi-0 +1 -1
  297. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-el14l6-0 +1 -1
  298. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ivrl3y-0 +1 -1
  299. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-kkbs85-0 +1 -1
  300. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ory1ux-0 +1 -1
  301. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-pgsq76-0 +1 -1
  302. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ra8uim-0 +1 -1
  303. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t7k1g-0 +1 -1
  304. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t8g0sv-0 +1 -1
  305. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ufy6g3-0 +1 -1
  306. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-x2d6j9-0 +1 -1
  307. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-xi0l6h-0 +1 -1
  308. data/spec/data/config.rb +6 -6
  309. data/spec/data/cookbooks/angrybash/metadata.rb +2 -2
  310. data/spec/data/cookbooks/angrybash/recipes/default.rb +8 -8
  311. data/spec/data/cookbooks/apache2/files/default/apache2_module_conf_generate.pl +2 -2
  312. data/spec/data/cookbooks/apache2/metadata.rb +2 -2
  313. data/spec/data/cookbooks/apache2/recipes/default.rb +2 -2
  314. data/spec/data/cookbooks/borken/metadata.rb +2 -2
  315. data/spec/data/cookbooks/borken/recipes/default.rb +1 -1
  316. data/spec/data/cookbooks/borken/templates/default/borken.erb +1 -1
  317. data/spec/data/cookbooks/chefignore +8 -8
  318. data/spec/data/cookbooks/ignorken/files/default/not_me.rb +2 -2
  319. data/spec/data/cookbooks/ignorken/metadata.rb +2 -2
  320. data/spec/data/cookbooks/ignorken/recipes/ignoreme.rb +1 -1
  321. data/spec/data/cookbooks/ignorken/templates/ubuntu-12.10/not_me.rb +2 -2
  322. data/spec/data/cookbooks/java/files/default/java.response +1 -1
  323. data/spec/data/cookbooks/java/metadata.rb +2 -2
  324. data/spec/data/cookbooks/name-mismatch-versionnumber/README.md +4 -4
  325. data/spec/data/cookbooks/name-mismatch-versionnumber/metadata.rb +8 -8
  326. data/spec/data/cookbooks/openldap/attributes/default.rb +16 -16
  327. data/spec/data/cookbooks/openldap/attributes/smokey.rb +1 -1
  328. data/spec/data/cookbooks/openldap/definitions/client.rb +5 -5
  329. data/spec/data/cookbooks/openldap/definitions/server.rb +5 -5
  330. data/spec/data/cookbooks/openldap/files/default/.dotfile +1 -1
  331. data/spec/data/cookbooks/openldap/files/default/remotedir/.a_dotdir/.a_dotfile_in_a_dotdir +1 -1
  332. data/spec/data/cookbooks/openldap/files/default/remotedir/not_a_template.erb +2 -2
  333. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file1.txt +2 -2
  334. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file2.txt +2 -2
  335. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/.a_dotfile +1 -1
  336. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file1.txt +2 -2
  337. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file2.txt +2 -2
  338. data/spec/data/cookbooks/openldap/files/default/remotedir/subdir_with_no_file_just_a_subsubdir/the_subsubdir/some_file.txt +3 -3
  339. data/spec/data/cookbooks/openldap/libraries/openldap.rb +4 -4
  340. data/spec/data/cookbooks/openldap/libraries/openldap/version.rb +3 -3
  341. data/spec/data/cookbooks/openldap/metadata.rb +8 -8
  342. data/spec/data/cookbooks/openldap/recipes/default.rb +4 -4
  343. data/spec/data/cookbooks/openldap/recipes/gigantor.rb +3 -3
  344. data/spec/data/cookbooks/openldap/recipes/one.rb +15 -15
  345. data/spec/data/cookbooks/openldap/recipes/return.rb +2 -2
  346. data/spec/data/cookbooks/openldap/templates/default/helper_test.erb +1 -1
  347. data/spec/data/cookbooks/openldap/templates/default/helpers_via_partial_test.erb +1 -1
  348. data/spec/data/cookbooks/openldap/templates/default/no_windows_line_endings.erb +4 -4
  349. data/spec/data/cookbooks/openldap/templates/default/openldap_variable_stuff.conf.erb +1 -1
  350. data/spec/data/cookbooks/openldap/templates/default/test.erb +1 -1
  351. data/spec/data/cookbooks/preseed/files/default/preseed-file.seed +1 -1
  352. data/spec/data/cookbooks/preseed/files/default/preseed-template.seed +4 -4
  353. data/spec/data/cookbooks/preseed/metadata.rb +2 -2
  354. data/spec/data/cookbooks/preseed/templates/default/preseed-template-variables.seed +1 -1
  355. data/spec/data/cookbooks/preseed/templates/default/preseed-template.seed +1 -1
  356. data/spec/data/definitions/test.rb +4 -4
  357. data/spec/data/environment-config.rb +4 -4
  358. data/spec/data/file-providers-method-snapshot-chef-11-4.json +127 -127
  359. data/spec/data/fileedit/hosts +4 -4
  360. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/README.md +4 -4
  361. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/metadata.rb +13 -13
  362. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/README.md +4 -4
  363. data/spec/data/kitchen/chefignore +6 -6
  364. data/spec/data/kitchen/openldap/attributes/default.rb +3 -3
  365. data/spec/data/kitchen/openldap/attributes/robinson.rb +2 -2
  366. data/spec/data/kitchen/openldap/definitions/client.rb +3 -3
  367. data/spec/data/kitchen/openldap/definitions/drewbarrymore.rb +2 -2
  368. data/spec/data/kitchen/openldap/recipes/gigantor.rb +2 -2
  369. data/spec/data/kitchen/openldap/recipes/ignoreme.rb +2 -2
  370. data/spec/data/kitchen/openldap/recipes/woot.rb +3 -3
  371. data/spec/data/knife_subcommand/test_explicit_category.rb +6 -6
  372. data/spec/data/knife_subcommand/test_name_mapping.rb +4 -4
  373. data/spec/data/knife_subcommand/test_yourself.rb +21 -21
  374. data/spec/data/lwrp/providers/inline_compiler.rb +26 -26
  375. data/spec/data/lwrp/providers/monkey_name_printer.rb +5 -5
  376. data/spec/data/lwrp/providers/paint_drying_watcher.rb +7 -7
  377. data/spec/data/lwrp/providers/thumb_twiddler.rb +7 -7
  378. data/spec/data/lwrp/resources/foo.rb +4 -4
  379. data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +1 -1
  380. data/spec/data/lwrp_override/providers/buck_passer.rb +5 -5
  381. data/spec/data/mac_users/10.7-8.plist.xml +559 -559
  382. data/spec/data/mac_users/10.7-8.shadow.xml +11 -11
  383. data/spec/data/mac_users/10.7.plist.xml +559 -559
  384. data/spec/data/mac_users/10.7.shadow.xml +11 -11
  385. data/spec/data/mac_users/10.8.plist.xml +559 -559
  386. data/spec/data/mac_users/10.8.shadow.xml +21 -21
  387. data/spec/data/mac_users/10.9.plist.xml +560 -560
  388. data/spec/data/mac_users/10.9.shadow.xml +21 -21
  389. data/spec/data/metadata/quick_start/metadata.rb +19 -19
  390. data/spec/data/nodes/default.rb +15 -15
  391. data/spec/data/nodes/test.example.com.rb +17 -17
  392. data/spec/data/nodes/test.rb +15 -15
  393. data/spec/data/null_config.rb +1 -1
  394. data/spec/data/object_loader/environments/test.json +7 -7
  395. data/spec/data/object_loader/environments/test.rb +2 -2
  396. data/spec/data/object_loader/environments/test_json_class.json +8 -8
  397. data/spec/data/object_loader/nodes/test.json +7 -7
  398. data/spec/data/object_loader/nodes/test.rb +2 -2
  399. data/spec/data/object_loader/nodes/test_json_class.json +8 -8
  400. data/spec/data/object_loader/roles/test.json +7 -7
  401. data/spec/data/object_loader/roles/test.rb +2 -2
  402. data/spec/data/object_loader/roles/test_json_class.json +8 -8
  403. data/spec/data/partial_one.erb +1 -1
  404. data/spec/data/recipes/test.rb +7 -7
  405. data/spec/data/run_context/cookbooks/circular-dep1/attributes/default.rb +4 -4
  406. data/spec/data/run_context/cookbooks/circular-dep1/definitions/circular_dep1_res.rb +1 -1
  407. data/spec/data/run_context/cookbooks/circular-dep1/libraries/lib.rb +2 -2
  408. data/spec/data/run_context/cookbooks/circular-dep1/metadata.rb +2 -2
  409. data/spec/data/run_context/cookbooks/circular-dep1/providers/provider.rb +1 -1
  410. data/spec/data/run_context/cookbooks/circular-dep1/resources/resource.rb +1 -1
  411. data/spec/data/run_context/cookbooks/circular-dep2/attributes/default.rb +3 -3
  412. data/spec/data/run_context/cookbooks/circular-dep2/definitions/circular_dep2_res.rb +1 -1
  413. data/spec/data/run_context/cookbooks/circular-dep2/libraries/lib.rb +2 -2
  414. data/spec/data/run_context/cookbooks/circular-dep2/metadata.rb +2 -2
  415. data/spec/data/run_context/cookbooks/circular-dep2/providers/provider.rb +1 -1
  416. data/spec/data/run_context/cookbooks/circular-dep2/resources/resource.rb +1 -1
  417. data/spec/data/run_context/cookbooks/dependency1/attributes/aa_first.rb +2 -2
  418. data/spec/data/run_context/cookbooks/dependency1/attributes/default.rb +2 -2
  419. data/spec/data/run_context/cookbooks/dependency1/attributes/zz_last.rb +3 -3
  420. data/spec/data/run_context/cookbooks/dependency1/definitions/dependency1_res.rb +1 -1
  421. data/spec/data/run_context/cookbooks/dependency1/libraries/lib.rb +2 -2
  422. data/spec/data/run_context/cookbooks/dependency1/providers/provider.rb +1 -1
  423. data/spec/data/run_context/cookbooks/dependency1/resources/resource.rb +1 -1
  424. data/spec/data/run_context/cookbooks/dependency2/attributes/default.rb +3 -3
  425. data/spec/data/run_context/cookbooks/dependency2/definitions/dependency2_res.rb +1 -1
  426. data/spec/data/run_context/cookbooks/dependency2/libraries/lib.rb +2 -2
  427. data/spec/data/run_context/cookbooks/dependency2/providers/provider.rb +1 -1
  428. data/spec/data/run_context/cookbooks/dependency2/resources/resource.rb +1 -1
  429. data/spec/data/run_context/cookbooks/no-default-attr/attributes/server.rb +3 -3
  430. data/spec/data/run_context/cookbooks/no-default-attr/definitions/no_default-attr_res.rb +1 -1
  431. data/spec/data/run_context/cookbooks/no-default-attr/providers/provider.rb +1 -1
  432. data/spec/data/run_context/cookbooks/no-default-attr/resources/resource.rb +1 -1
  433. data/spec/data/run_context/cookbooks/test-with-circular-deps/attributes/default.rb +3 -3
  434. data/spec/data/run_context/cookbooks/test-with-circular-deps/definitions/test_with-circular-deps_res.rb +1 -1
  435. data/spec/data/run_context/cookbooks/test-with-circular-deps/libraries/lib.rb +2 -2
  436. data/spec/data/run_context/cookbooks/test-with-circular-deps/metadata.rb +2 -2
  437. data/spec/data/run_context/cookbooks/test-with-circular-deps/providers/provider.rb +1 -1
  438. data/spec/data/run_context/cookbooks/test-with-circular-deps/resources/resource.rb +1 -1
  439. data/spec/data/run_context/cookbooks/test-with-deps/attributes/default.rb +3 -3
  440. data/spec/data/run_context/cookbooks/test-with-deps/definitions/test_with-deps_res.rb +1 -1
  441. data/spec/data/run_context/cookbooks/test-with-deps/libraries/lib.rb +1 -1
  442. data/spec/data/run_context/cookbooks/test-with-deps/metadata.rb +3 -3
  443. data/spec/data/run_context/cookbooks/test-with-deps/providers/provider.rb +1 -1
  444. data/spec/data/run_context/cookbooks/test-with-deps/resources/resource.rb +1 -1
  445. data/spec/data/run_context/cookbooks/test/attributes/george.rb +1 -1
  446. data/spec/data/run_context/cookbooks/test/definitions/new_animals.rb +9 -9
  447. data/spec/data/run_context/cookbooks/test/definitions/new_cat.rb +5 -5
  448. data/spec/data/run_context/cookbooks/test/definitions/test_res.rb +1 -1
  449. data/spec/data/run_context/cookbooks/test/providers/provider.rb +1 -1
  450. data/spec/data/run_context/cookbooks/test/recipes/default.rb +5 -5
  451. data/spec/data/run_context/cookbooks/test/recipes/one.rb +7 -7
  452. data/spec/data/run_context/cookbooks/test/recipes/two.rb +7 -7
  453. data/spec/data/run_context/cookbooks/test/resources/resource.rb +1 -1
  454. data/spec/data/run_context/nodes/run_context.rb +5 -5
  455. data/spec/data/search_queries_to_transform.txt +98 -98
  456. data/spec/data/shef-config.rb +10 -10
  457. data/spec/data/ssl/5e707473.0 +18 -18
  458. data/spec/data/ssl/chef-rspec.cert +27 -27
  459. data/spec/data/ssl/chef-rspec.key +27 -27
  460. data/spec/data/ssl/key.pem +15 -15
  461. data/spec/data/ssl/private_key.pem +27 -27
  462. data/spec/data/ssl/private_key_with_whitespace.pem +32 -32
  463. data/spec/data/standalone_cookbook/chefignore +9 -9
  464. data/spec/data/standalone_cookbook/recipes/default.rb +2 -2
  465. data/spec/data/trusted_certs/example.crt +22 -22
  466. data/spec/data/trusted_certs/intermediate.pem +27 -27
  467. data/spec/data/trusted_certs/root.pem +22 -22
  468. data/spec/functional/assets/chefinittest +34 -34
  469. data/spec/functional/assets/testchefsubsys +10 -10
  470. data/spec/functional/provider/remote_file/cache_control_data_spec.rb +0 -0
  471. data/spec/functional/resource/aix_service_spec.rb +0 -0
  472. data/spec/functional/resource/aixinit_service_spec.rb +0 -0
  473. data/spec/functional/resource/chocolatey_package_spec.rb +0 -5
  474. data/spec/functional/resource/env_spec.rb +0 -0
  475. data/spec/functional/win32/registry_spec.rb +1 -0
  476. data/spec/integration/client/exit_code_spec.rb +245 -0
  477. data/spec/integration/knife/deps_spec.rb +7 -7
  478. data/spec/integration/knife/download_spec.rb +19 -0
  479. data/spec/integration/knife/list_spec.rb +0 -8
  480. data/spec/integration/knife/upload_spec.rb +21 -2
  481. data/spec/integration/solo/solo_spec.rb +1 -1
  482. data/spec/rcov.opts +2 -2
  483. data/spec/unit/application/apply_spec.rb +6 -4
  484. data/spec/unit/application/exit_code_spec.rb +231 -0
  485. data/spec/unit/application/solo_spec.rb +143 -88
  486. data/spec/unit/chef_fs/config_spec.rb +129 -0
  487. data/spec/unit/chef_fs/file_system/repository/base_file_spec.rb +8 -10
  488. data/spec/unit/client_spec.rb +1 -1
  489. data/spec/unit/config_fetcher_spec.rb +2 -2
  490. data/spec/unit/cookbook/synchronizer_spec.rb +1 -1
  491. data/spec/unit/data_bag_item_spec.rb +2 -2
  492. data/spec/unit/data_bag_spec.rb +2 -2
  493. data/spec/unit/data_collector/messages/helpers_spec.rb +190 -0
  494. data/spec/unit/data_collector/messages_spec.rb +207 -0
  495. data/spec/unit/data_collector_spec.rb +525 -0
  496. data/spec/unit/decorator/lazy_array_spec.rb +58 -0
  497. data/spec/unit/decorator/lazy_spec.rb +39 -0
  498. data/spec/unit/decorator_spec.rb +142 -0
  499. data/spec/unit/environment_spec.rb +4 -4
  500. data/spec/unit/handler_spec.rb +87 -0
  501. data/spec/unit/knife/cookbook_show_spec.rb +89 -90
  502. data/spec/unit/knife/ssl_check_spec.rb +16 -0
  503. data/spec/unit/policy_builder/dynamic_spec.rb +1 -1
  504. data/spec/unit/policy_builder/policyfile_spec.rb +1 -1
  505. data/spec/unit/provider/git_spec.rb +77 -18
  506. data/spec/unit/provider/package/apt_spec.rb +97 -34
  507. data/spec/unit/provider/package/chocolatey_spec.rb +3 -15
  508. data/spec/unit/provider/package/portage_spec.rb +6 -0
  509. data/spec/unit/provider/package/rubygems_spec.rb +38 -4
  510. data/spec/unit/provider/package/yum/yum_cache_spec.rb +27 -0
  511. data/spec/unit/provider/package_spec.rb +20 -7
  512. data/spec/unit/provider/systemd_unit_spec.rb +885 -0
  513. data/spec/unit/resource/systemd_unit_spec.rb +133 -0
  514. data/spec/unit/resource_builder_spec.rb +1 -1
  515. data/tasks/bin/bundle-platform +6 -2
  516. data/tasks/bin/bundle-platform.bat +0 -0
  517. data/tasks/bin/create-override-gemfile +0 -0
  518. data/tasks/bin/run_external_test +0 -0
  519. data/tasks/bundle_util.rb +18 -2
  520. data/tasks/changelog.rb +1 -0
  521. data/tasks/dependencies.rb +47 -57
  522. metadata +847 -7
  523. data/tasks/bin/run_chef_tests +0 -17
@@ -26,10 +26,6 @@ class Chef
26
26
  module Repository
27
27
  class AclsSubDir < Repository::Directory
28
28
 
29
- def can_have_child?(name, is_dir)
30
- !is_dir && File.extname(name) == ".json"
31
- end
32
-
33
29
  protected
34
30
 
35
31
  def make_child_entry(child_name)
@@ -29,23 +29,48 @@ class Chef
29
29
  attr_reader :file_path
30
30
  attr_reader :data_handler
31
31
 
32
+ alias_method :display_path, :path
33
+ alias_method :display_name, :name
34
+
32
35
  def initialize(name, parent)
33
36
  @parent = parent
37
+
38
+ if %w{ .rb .json }.include? File.extname(name)
39
+ name = File.basename(name, ".*")
40
+ end
41
+
42
+ file_path = "#{parent.file_path}/#{name}"
43
+
44
+ Chef::Log.debug "BaseFile: Detecting file extension for #{name}"
45
+ ext = File.exist?(file_path + ".rb") ? ".rb" : ".json"
46
+ name += ext
47
+ file_path += ext
48
+
49
+ Chef::Log.debug "BaseFile: got a file path of #{file_path} for #{name}"
34
50
  @name = name
35
51
  @path = Chef::ChefFS::PathUtils.join(parent.path, name)
36
- @file_path = "#{parent.file_path}/#{name}"
52
+ @file_path = file_path
37
53
  end
38
54
 
39
55
  def dir?
40
56
  false
41
57
  end
42
58
 
59
+ # Used to compare names on disk to the API, for diffing.
60
+ def bare_name
61
+ File.basename(name, ".*")
62
+ end
63
+
43
64
  def is_json_file?
44
- File.extname(name) == ".json"
65
+ File.extname(file_path) == ".json"
66
+ end
67
+
68
+ def is_ruby_file?
69
+ File.extname(file_path) == ".rb"
45
70
  end
46
71
 
47
72
  def name_valid?
48
- !name.start_with?(".") && is_json_file?
73
+ !name.start_with?(".") && (is_json_file? || is_ruby_file?)
49
74
  end
50
75
 
51
76
  def fs_entry_valid?
@@ -91,12 +116,19 @@ class Chef
91
116
  end
92
117
 
93
118
  def read
94
- File.open(file_path, "rb") { |f| f.read }
119
+ if is_ruby_file?
120
+ data_handler.from_ruby(file_path).to_json
121
+ else
122
+ File.open(file_path, "rb") { |f| f.read }
123
+ end
95
124
  rescue Errno::ENOENT
96
125
  raise Chef::ChefFS::FileSystem::NotFoundError.new(self, $!)
97
126
  end
98
127
 
99
128
  def write(content)
129
+ if is_ruby_file?
130
+ raise Chef::ChefFS::FileSystem::RubyFileError.new(:write, self)
131
+ end
100
132
  if content && write_pretty_json && is_json_file?
101
133
  content = minimize(content, self)
102
134
  end
@@ -37,6 +37,10 @@ class Chef
37
37
  attr_reader :recursive
38
38
  attr_reader :file_path
39
39
 
40
+ alias_method :display_path, :path
41
+ alias_method :display_name, :name
42
+ alias_method :bare_name, :name
43
+
40
44
  def initialize(name, parent, file_path = nil, ruby_only = false, recursive = false)
41
45
  @parent = parent
42
46
  @name = name
@@ -26,10 +26,6 @@ class Chef
26
26
  module Repository
27
27
  class ClientKeysSubDir < Repository::Directory
28
28
 
29
- def can_have_child?(name, is_dir)
30
- !is_dir && File.extname(name) == ".json"
31
- end
32
-
33
29
  protected
34
30
 
35
31
  def make_child_entry(child_name)
@@ -26,9 +26,6 @@ class Chef
26
26
  module FileSystem
27
27
  module Repository
28
28
  class ClientsDir < Repository::Directory
29
- def can_have_child?(name, is_dir)
30
- !is_dir && File.extname(name) == ".json"
31
- end
32
29
 
33
30
  def make_child_entry(child_name)
34
31
  Client.new(child_name, self)
@@ -27,10 +27,6 @@ class Chef
27
27
  module Repository
28
28
  class ContainersDir < Repository::Directory
29
29
 
30
- def can_have_child?(name, is_dir)
31
- !is_dir && File.extname(name) == ".json"
32
- end
33
-
34
30
  def make_child_entry(child_name)
35
31
  Container.new(child_name, self)
36
32
  end
@@ -28,6 +28,10 @@ class Chef
28
28
  attr_reader :path
29
29
  attr_reader :file_path
30
30
 
31
+ alias_method :display_path, :path
32
+ alias_method :display_name, :name
33
+ alias_method :bare_name, :name
34
+
31
35
  def initialize(name, parent, file_path = nil)
32
36
  @parent = parent
33
37
  @name = name
@@ -27,10 +27,6 @@ class Chef
27
27
  module Repository
28
28
  class EnvironmentsDir < Repository::Directory
29
29
 
30
- def can_have_child?(name, is_dir)
31
- !is_dir && File.extname(name) == ".json"
32
- end
33
-
34
30
  def make_child_entry(child_name)
35
31
  Environment.new(child_name, self)
36
32
  end
@@ -27,10 +27,6 @@ class Chef
27
27
  module Repository
28
28
  class GroupsDir < Repository::Directory
29
29
 
30
- def can_have_child?(name, is_dir)
31
- !is_dir && File.extname(name) == ".json"
32
- end
33
-
34
30
  def make_child_entry(child_name)
35
31
  Group.new(child_name, self)
36
32
  end
@@ -27,10 +27,6 @@ class Chef
27
27
  module Repository
28
28
  class NodesDir < Repository::Directory
29
29
 
30
- def can_have_child?(name, is_dir)
31
- !is_dir && File.extname(name) == ".json"
32
- end
33
-
34
30
  def make_child_entry(child_name)
35
31
  Node.new(child_name, self)
36
32
  end
@@ -27,10 +27,6 @@ class Chef
27
27
  module Repository
28
28
  class PolicyGroupsDir < Repository::Directory
29
29
 
30
- def can_have_child?(name, is_dir)
31
- !is_dir && File.extname(name) == ".json"
32
- end
33
-
34
30
  def make_child_entry(child_name)
35
31
  PolicyGroup.new(child_name, self)
36
32
  end
@@ -27,10 +27,6 @@ class Chef
27
27
  module Repository
28
28
  class RolesDir < Repository::Directory
29
29
 
30
- def can_have_child?(name, is_dir)
31
- !is_dir && File.extname(name) == ".json"
32
- end
33
-
34
30
  def make_child_entry(child_name)
35
31
  Role.new(child_name, self)
36
32
  end
@@ -27,10 +27,6 @@ class Chef
27
27
  module Repository
28
28
  class UsersDir < Repository::Directory
29
29
 
30
- def can_have_child?(name, is_dir)
31
- !is_dir && File.extname(name) == ".json"
32
- end
33
-
34
30
  def make_child_entry(child_name)
35
31
  User.new(child_name, self)
36
32
  end
@@ -45,6 +45,7 @@ require "chef/formatters/doc"
45
45
  require "chef/formatters/minimal"
46
46
  require "chef/version"
47
47
  require "chef/resource_reporter"
48
+ require "chef/data_collector"
48
49
  require "chef/audit/audit_reporter"
49
50
  require "chef/run_lock"
50
51
  require "chef/policy_builder"
@@ -262,7 +263,8 @@ class Chef
262
263
  enforce_path_sanity
263
264
  run_ohai
264
265
 
265
- register unless Chef::Config[:solo]
266
+ register unless Chef::Config[:solo_legacy_mode]
267
+ register_data_collector_reporter
266
268
 
267
269
  load_node
268
270
 
@@ -533,7 +535,7 @@ class Chef
533
535
  # @api private
534
536
  #
535
537
  def save_updated_node
536
- if Chef::Config[:solo]
538
+ if Chef::Config[:solo_legacy_mode]
537
539
  # nothing to do
538
540
  elsif policy_builder.temporary_policy?
539
541
  Chef::Log.warn("Skipping final node save because override_runlist was given")
@@ -936,7 +938,7 @@ class Chef
936
938
  end
937
939
 
938
940
  def assert_cookbook_path_not_empty(run_context)
939
- if Chef::Config[:solo]
941
+ if Chef::Config[:solo_legacy_mode]
940
942
  # Check for cookbooks in the path given
941
943
  # Chef::Config[:cookbook_path] can be a string or an array
942
944
  # if it's an array, go through it and check each one, raise error at the last one if no files are found
@@ -957,6 +959,12 @@ class Chef
957
959
 
958
960
  Chef::ReservedNames::Win32::Security.has_admin_privileges?
959
961
  end
962
+
963
+ # Register the data collector reporter to send event information to the
964
+ # data collector server
965
+ def register_data_collector_reporter
966
+ events.register(Chef::DataCollector::Reporter.new) if Chef::DataCollector.register_reporter?
967
+ end
960
968
  end
961
969
  end
962
970
 
@@ -25,7 +25,7 @@ class Chef
25
25
  begin
26
26
  Chef::JSONCompat.from_json(config_data)
27
27
  rescue Chef::Exceptions::JSON::ParseError => error
28
- Chef::Application.fatal!("Could not parse the provided JSON file (#{config_location}): " + error.message, 2)
28
+ Chef::Application.fatal!("Could not parse the provided JSON file (#{config_location}): " + error.message, Chef::Exceptions::DeprecatedExitCode.new)
29
29
  end
30
30
  end
31
31
 
@@ -40,15 +40,15 @@ class Chef
40
40
  def fetch_remote_config
41
41
  http.get("")
42
42
  rescue SocketError, SystemCallError, Net::HTTPServerException => error
43
- Chef::Application.fatal!("Cannot fetch config '#{config_location}': '#{error.class}: #{error.message}", 2)
43
+ Chef::Application.fatal!("Cannot fetch config '#{config_location}': '#{error.class}: #{error.message}", Chef::Exceptions::DeprecatedExitCode.new)
44
44
  end
45
45
 
46
46
  def read_local_config
47
47
  ::File.read(config_location)
48
48
  rescue Errno::ENOENT
49
- Chef::Application.fatal!("Cannot load configuration from #{config_location}", 2)
49
+ Chef::Application.fatal!("Cannot load configuration from #{config_location}", Chef::Exceptions::DeprecatedExitCode.new)
50
50
  rescue Errno::EACCES
51
- Chef::Application.fatal!("Permissions are incorrect on #{config_location}. Please chmod a+r #{config_location}", 2)
51
+ Chef::Application.fatal!("Permissions are incorrect on #{config_location}. Please chmod a+r #{config_location}", Chef::Exceptions::DeprecatedExitCode.new)
52
52
  end
53
53
 
54
54
  def config_missing?
@@ -59,6 +59,7 @@ class Chef
59
59
  Chef::Log.info(so.stdout)
60
60
  end
61
61
  end
62
+ Gem.clear_paths
62
63
  rescue Exception => e
63
64
  events.cookbook_gem_failed(e)
64
65
  raise
@@ -43,7 +43,7 @@ class Chef
43
43
  end
44
44
 
45
45
  def cleanup_file_cache
46
- unless Chef::Config[:solo] || skip_removal
46
+ unless Chef::Config[:solo_legacy_mode] || skip_removal
47
47
  # Delete each file in the cache that we didn't encounter in the
48
48
  # manifest.
49
49
  cache.find(File.join(%w{cookbooks ** {*,.*}})).each do |cache_filename|
@@ -91,7 +91,7 @@ class Chef
91
91
  end
92
92
 
93
93
  def self.list(inflate = false)
94
- if Chef::Config[:solo]
94
+ if Chef::Config[:solo_legacy_mode]
95
95
  paths = Array(Chef::Config[:data_bag_path])
96
96
  names = []
97
97
  paths.each do |path|
@@ -118,7 +118,7 @@ class Chef
118
118
 
119
119
  # Load a Data Bag by name via either the RESTful API or local data_bag_path if run in solo mode
120
120
  def self.load(name)
121
- if Chef::Config[:solo]
121
+ if Chef::Config[:solo_legacy_mode]
122
122
  paths = Array(Chef::Config[:data_bag_path])
123
123
  data_bag = {}
124
124
  paths.each do |path|
@@ -147,7 +147,7 @@ class Chef
147
147
 
148
148
  # Load a Data Bag Item by name via either the RESTful API or local data_bag_path if run in solo mode
149
149
  def self.load(data_bag, name)
150
- if Chef::Config[:solo]
150
+ if Chef::Config[:solo_legacy_mode]
151
151
  bag = Chef::DataBag.load(data_bag)
152
152
  raise Exceptions::InvalidDataBagItemID, "Item #{name} not found in data bag #{data_bag}. Other items found: #{bag.keys.join(", ")}" unless bag.include?(name)
153
153
  item = bag[name]
@@ -0,0 +1,345 @@
1
+ #
2
+ # Author:: Adam Leff (<adamleff@chef.io>)
3
+ # Author:: Ryan Cragun (<ryan@chef.io>)
4
+ #
5
+ # Copyright:: Copyright 2012-2016, Chef Software Inc.
6
+ # License:: Apache License, Version 2.0
7
+ #
8
+ # Licensed under the Apache License, Version 2.0 (the "License");
9
+ # you may not use this file except in compliance with the License.
10
+ # You may obtain a copy of the License at
11
+ #
12
+ # http://www.apache.org/licenses/LICENSE-2.0
13
+ #
14
+ # Unless required by applicable law or agreed to in writing, software
15
+ # distributed under the License is distributed on an "AS IS" BASIS,
16
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
+ # See the License for the specific language governing permissions and
18
+ # limitations under the License.
19
+ #
20
+
21
+ require "uri"
22
+ require "chef/event_dispatch/base"
23
+ require "chef/data_collector/messages"
24
+ require "chef/data_collector/resource_report"
25
+
26
+ class Chef
27
+
28
+ # == Chef::DataCollector
29
+ # Provides methods for determinine whether a reporter should be registered.
30
+ class DataCollector
31
+ def self.register_reporter?
32
+ Chef::Config[:data_collector][:server_url] &&
33
+ !Chef::Config[:why_run] &&
34
+ self.reporter_enabled_for_current_mode?
35
+ end
36
+
37
+ def self.reporter_enabled_for_current_mode?
38
+ if Chef::Config[:solo] || Chef::Config[:local_mode]
39
+ acceptable_modes = [:solo, :both]
40
+ else
41
+ acceptable_modes = [:client, :both]
42
+ end
43
+
44
+ acceptable_modes.include?(Chef::Config[:data_collector][:mode])
45
+ end
46
+
47
+ # == Chef::DataCollector::Reporter
48
+ # Provides an event handler that can be registered to report on Chef
49
+ # run data. Unlike the existing Chef::ResourceReporter event handler,
50
+ # the DataCollector handler is not tied to a Chef Server / Chef Reporting
51
+ # and exports its data through a webhook-like mechanism to a configured
52
+ # endpoint.
53
+ class Reporter < EventDispatch::Base
54
+ attr_reader :updated_resources, :status, :exception, :error_descriptions,
55
+ :expanded_run_list, :run_status, :http, :resource_count,
56
+ :current_resource_report, :enabled
57
+
58
+ def initialize
59
+ @updated_resources = []
60
+ @resource_count = 0
61
+ @current_resource_loaded = nil
62
+ @error_descriptions = {}
63
+ @expanded_run_list = {}
64
+ @http = Chef::HTTP.new(data_collector_server_url)
65
+ @enabled = true
66
+ end
67
+
68
+ # see EventDispatch::Base#run_started
69
+ # Upon receipt, we will send our run start message to the
70
+ # configured DataCollector endpoint. Depending on whether
71
+ # the user has configured raise_on_failure, if we cannot
72
+ # send the message, we will either disable the DataCollector
73
+ # Reporter for the duration of this run, or we'll raise an
74
+ # exception.
75
+ def run_started(current_run_status)
76
+ update_run_status(current_run_status)
77
+
78
+ disable_reporter_on_error do
79
+ send_to_data_collector(
80
+ Chef::DataCollector::Messages.run_start_message(current_run_status).to_json
81
+ )
82
+ end
83
+ end
84
+
85
+ # see EventDispatch::Base#run_completed
86
+ # Upon receipt, we will send our run completion message to the
87
+ # configured DataCollector endpoint.
88
+ def run_completed(node)
89
+ send_run_completion(status: "success")
90
+ end
91
+
92
+ # see EventDispatch::Base#run_failed
93
+ def run_failed(exception)
94
+ send_run_completion(status: "failure")
95
+ end
96
+
97
+ # see EventDispatch::Base#resource_current_state_loaded
98
+ # Create a new ResourceReport instance that we'll use to track
99
+ # the state of this resource during the run. Nested resources are
100
+ # ignored as they are assumed to be an inline resource of a custom
101
+ # resource, and we only care about tracking top-level resources.
102
+ def resource_current_state_loaded(new_resource, action, current_resource)
103
+ return if nested_resource?(new_resource)
104
+ update_current_resource_report(
105
+ Chef::DataCollector::ResourceReport.new(
106
+ new_resource,
107
+ action,
108
+ current_resource
109
+ )
110
+ )
111
+ end
112
+
113
+ # see EventDispatch::Base#resource_up_to_date
114
+ # Mark our ResourceReport status accordingly, and increment the total
115
+ # resource count.
116
+ def resource_up_to_date(new_resource, action)
117
+ current_resource_report.up_to_date unless nested_resource?(new_resource)
118
+ increment_resource_count
119
+ end
120
+
121
+ # see EventDispatch::Base#resource_skipped
122
+ # Increment the total resource count. If this is a top-level resource,
123
+ # we also create a ResourceReport instance (because a skipped resource
124
+ # does not trigger the resource_current_state_loaded event), and flag
125
+ # it as skipped.
126
+ def resource_skipped(new_resource, action, conditional)
127
+ increment_resource_count
128
+ return if nested_resource?(new_resource)
129
+
130
+ update_current_resource_report(
131
+ Chef::DataCollector::ResourceReport.new(
132
+ new_resource,
133
+ action
134
+ )
135
+ )
136
+ current_resource_report.skipped(conditional)
137
+ end
138
+
139
+ # see EventDispatch::Base#resource_updated
140
+ # Flag the current ResourceReport instance as updated (as long as it's
141
+ # a top-level resource) and increment the total resource count.
142
+ def resource_updated(new_resource, action)
143
+ current_resource_report.updated unless nested_resource?(new_resource)
144
+ increment_resource_count
145
+ end
146
+
147
+ # see EventDispatch::Base#resource_failed
148
+ # Flag the current ResourceReport as failed and supply the exception as
149
+ # long as it's a top-level resource, increment the total resource count,
150
+ # and update the run error text with the proper Formatter.
151
+ def resource_failed(new_resource, action, exception)
152
+ current_resource_report.failed(exception) unless nested_resource?(new_resource)
153
+ increment_resource_count
154
+ update_error_description(
155
+ Formatters::ErrorMapper.resource_failed(
156
+ new_resource,
157
+ action,
158
+ exception
159
+ ).for_json
160
+ )
161
+ end
162
+
163
+ # see EventDispatch::Base#resource_completed
164
+ # Mark the ResourceReport instance as finished (for timing details)
165
+ # and add it to the list of resources encountered during this run.
166
+ # This marks the end of this resource during this run.
167
+ def resource_completed(new_resource)
168
+ if current_resource_report && !nested_resource?(new_resource)
169
+ current_resource_report.finish
170
+ add_updated_resource(current_resource_report)
171
+ update_current_resource_report(nil)
172
+ end
173
+ end
174
+
175
+ # see EventDispatch::Base#run_list_expanded
176
+ # The expanded run list is stored for later use by the run_completed
177
+ # event and message.
178
+ def run_list_expanded(run_list_expansion)
179
+ @expanded_run_list = run_list_expansion
180
+ end
181
+
182
+ # see EventDispatch::Base#run_list_expand_failed
183
+ # The run error text is updated with the output of the appropriate
184
+ # formatter.
185
+ def run_list_expand_failed(node, exception)
186
+ update_error_description(
187
+ Formatters::ErrorMapper.run_list_expand_failed(
188
+ node,
189
+ exception
190
+ ).for_json
191
+ )
192
+ end
193
+
194
+ # see EventDispatch::Base#cookbook_resolution_failed
195
+ # The run error text is updated with the output of the appropriate
196
+ # formatter.
197
+ def cookbook_resolution_failed(expanded_run_list, exception)
198
+ update_error_description(
199
+ Formatters::ErrorMapper.cookbook_resolution_failed(
200
+ expanded_run_list,
201
+ exception
202
+ ).for_json
203
+ )
204
+ end
205
+
206
+ # see EventDispatch::Base#cookbook_sync_failed
207
+ # The run error text is updated with the output of the appropriate
208
+ # formatter.
209
+ def cookbook_sync_failed(cookbooks, exception)
210
+ update_error_description(
211
+ Formatters::ErrorMapper.cookbook_sync_failed(
212
+ cookbooks,
213
+ exception
214
+ ).for_json
215
+ )
216
+ end
217
+
218
+ private
219
+
220
+ #
221
+ # Yields to the passed-in block (which is expected to be some interaction
222
+ # with the DataCollector endpoint). If some communication failure occurs,
223
+ # either disable any future communications to the DataCollector endpoint, or
224
+ # raise an exception (if the user has set
225
+ # Chef::Config.data_collector.raise_on_failure to true.)
226
+ #
227
+ # @param block [Proc] A ruby block to run. Ignored if a command is given.
228
+ #
229
+ def disable_reporter_on_error
230
+ yield
231
+ rescue Timeout::Error, Errno::EINVAL, Errno::ECONNRESET,
232
+ Errno::ECONNREFUSED, EOFError, Net::HTTPBadResponse,
233
+ Net::HTTPHeaderSyntaxError, Net::ProtocolError, OpenSSL::SSL::SSLError => e
234
+ disable_data_collector_reporter
235
+ code = if e.respond_to?(:response) && e.response.code
236
+ e.response.code.to_s
237
+ else
238
+ "Exception Code Empty"
239
+ end
240
+
241
+ msg = "Error while reporting run start to Data Collector. " \
242
+ "URL: #{data_collector_server_url} " \
243
+ "Exception: #{code} -- #{e.message} "
244
+
245
+ if Chef::Config[:data_collector][:raise_on_failure]
246
+ Chef::Log.error(msg)
247
+ raise
248
+ else
249
+ Chef::Log.warn(msg)
250
+ end
251
+ end
252
+
253
+ def send_to_data_collector(message)
254
+ return unless data_collector_accessible?
255
+
256
+ Chef::Log.debug("data_collector_reporter: POSTing the following message to #{data_collector_server_url}: #{message}")
257
+ http.post(nil, message, headers)
258
+ end
259
+
260
+ #
261
+ # Send any messages to the DataCollector endpoint that are necessary to
262
+ # indicate the run has completed. Currently, two messages are sent:
263
+ #
264
+ # - An "action" message with the node object indicating it's been updated
265
+ # - An "run_converge" (i.e. RunEnd) message with details about the run,
266
+ # what resources were modified/up-to-date/skipped, etc.
267
+ #
268
+ # @param opts [Hash] Additional details about the run, such as its success/failure.
269
+ #
270
+ def send_run_completion(opts)
271
+ # If run_status is nil we probably failed before the client triggered
272
+ # the run_started callback. In this case we'll skip updating because
273
+ # we have nothing to report.
274
+ return unless run_status
275
+
276
+ send_to_data_collector(Chef::DataCollector::Messages.node_update_message(run_status).to_json)
277
+ send_to_data_collector(
278
+ Chef::DataCollector::Messages.run_end_message(
279
+ run_status: run_status,
280
+ expanded_run_list: expanded_run_list,
281
+ total_resource_count: resource_count,
282
+ updated_resources: updated_resources,
283
+ status: opts[:status],
284
+ error_descriptions: error_descriptions
285
+ ).to_json
286
+ )
287
+ end
288
+
289
+ def headers
290
+ headers = { "Content-Type" => "application/json" }
291
+
292
+ unless data_collector_token.nil?
293
+ headers["x-data-collector-token"] = data_collector_token
294
+ headers["x-data-collector-auth"] = "version=1.0"
295
+ end
296
+
297
+ headers
298
+ end
299
+
300
+ def data_collector_server_url
301
+ Chef::Config[:data_collector][:server_url]
302
+ end
303
+
304
+ def data_collector_token
305
+ Chef::Config[:data_collector][:token]
306
+ end
307
+
308
+ def increment_resource_count
309
+ @resource_count += 1
310
+ end
311
+
312
+ def add_updated_resource(resource_report)
313
+ @updated_resources << resource_report
314
+ end
315
+
316
+ def disable_data_collector_reporter
317
+ @enabled = false
318
+ end
319
+
320
+ def data_collector_accessible?
321
+ @enabled
322
+ end
323
+
324
+ def update_run_status(run_status)
325
+ @run_status = run_status
326
+ end
327
+
328
+ def update_current_resource_report(resource_report)
329
+ @current_resource_report = resource_report
330
+ end
331
+
332
+ def update_error_description(discription_hash)
333
+ @error_descriptions = discription_hash
334
+ end
335
+
336
+ # If we are getting messages about a resource while we are in the middle of
337
+ # another resource's update, we assume that the nested resource is just the
338
+ # implementation of a provider, and we want to hide it from the reporting
339
+ # output.
340
+ def nested_resource?(new_resource)
341
+ @current_resource_report && @current_resource_report.new_resource != new_resource
342
+ end
343
+ end
344
+ end
345
+ end