chef 12.7.2 → 12.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1836) hide show
  1. checksums.yaml +4 -4
  2. data/CONTRIBUTING.md +208 -208
  3. data/Gemfile +49 -58
  4. data/LICENSE +201 -201
  5. data/README.md +139 -139
  6. data/Rakefile +86 -73
  7. data/VERSION +1 -1
  8. data/acceptance/.gitignore +2 -1
  9. data/acceptance/.shared/kitchen_acceptance/.kitchen.digitalocean.yml +33 -27
  10. data/acceptance/.shared/kitchen_acceptance/.kitchen.ec2.yml +290 -281
  11. data/acceptance/.shared/kitchen_acceptance/.kitchen.vagrant.yml +59 -49
  12. data/acceptance/.shared/kitchen_acceptance/libraries/kitchen.rb +51 -46
  13. data/acceptance/.shared/kitchen_acceptance/metadata.rb +1 -1
  14. data/acceptance/Gemfile +14 -11
  15. data/acceptance/README.md +132 -86
  16. data/acceptance/basics/.acceptance/acceptance-cookbook/.gitignore +2 -2
  17. data/acceptance/basics/.acceptance/acceptance-cookbook/metadata.rb +3 -3
  18. data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  19. data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  20. data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  21. data/acceptance/basics/.kitchen.yml +4 -4
  22. data/acceptance/basics/test/integration/chef-current-install/serverspec/chef_client_spec.rb +19 -19
  23. data/acceptance/basics/test/integration/chef-current-install/serverspec/spec_helper.rb +6 -6
  24. data/acceptance/fips/.acceptance/acceptance-cookbook/.gitignore +2 -0
  25. data/acceptance/fips/.acceptance/acceptance-cookbook/metadata.rb +2 -0
  26. data/acceptance/fips/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -0
  27. data/acceptance/fips/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -0
  28. data/acceptance/fips/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -0
  29. data/acceptance/fips/.kitchen.yml +4 -0
  30. data/acceptance/fips/test/integration/fips/serverspec/Gemfile +3 -0
  31. data/acceptance/fips/test/integration/fips/serverspec/fips_spec.rb +39 -0
  32. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/.gitignore +2 -2
  33. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/libraries/cookbook_kitchen.rb +43 -43
  34. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/libraries/top_cookbooks.rb +23 -21
  35. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/metadata.rb +3 -3
  36. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  37. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  38. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  39. data/acceptance/top-cookbooks/.gitignore +1 -1
  40. data/acceptance/top-cookbooks/.kitchen.docker.yml +12 -0
  41. data/acceptance/top-cookbooks/.kitchen.git.yml +11 -10
  42. data/acceptance/top-cookbooks/.kitchen.learn-the-basics-rhel.yml +7 -4
  43. data/acceptance/top-cookbooks/.kitchen.learn-the-basics-ubuntu.yml +7 -4
  44. data/acceptance/top-cookbooks/.kitchen.learn-the-basics-windows.yml +7 -4
  45. data/acceptance/trivial/.acceptance/acceptance-cookbook/.gitignore +2 -2
  46. data/acceptance/trivial/.acceptance/acceptance-cookbook/metadata.rb +2 -2
  47. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  48. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  49. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  50. data/acceptance/trivial/.kitchen.yml +7 -7
  51. data/acceptance/trivial/test/integration/chef-current-install/inspec/chef_client_spec.rb +5 -5
  52. data/acceptance/windows-service/.acceptance/acceptance-cookbook/.gitignore +2 -2
  53. data/acceptance/windows-service/.acceptance/acceptance-cookbook/metadata.rb +2 -2
  54. data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  55. data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  56. data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  57. data/acceptance/windows-service/.kitchen.yml +7 -7
  58. data/acceptance/windows-service/test/integration/chef-windows-service/inspec/chef_windows_service_spec.rb +58 -58
  59. data/bin/chef-apply +25 -25
  60. data/bin/chef-client +26 -26
  61. data/bin/chef-shell +34 -37
  62. data/bin/chef-solo +25 -25
  63. data/bin/knife +25 -25
  64. data/chef-windows.gemspec +24 -24
  65. data/chef.gemspec +63 -58
  66. data/distro/common/html/_sources/ctl_chef_client.txt +35 -35
  67. data/distro/common/html/_sources/ctl_chef_server.txt +341 -341
  68. data/distro/common/html/_sources/ctl_chef_shell.txt +15 -15
  69. data/distro/common/html/_sources/ctl_chef_solo.txt +25 -25
  70. data/distro/common/html/_sources/index.txt +135 -135
  71. data/distro/common/html/_sources/knife.txt +74 -74
  72. data/distro/common/html/_sources/knife_bootstrap.txt +56 -56
  73. data/distro/common/html/_sources/knife_client.txt +150 -150
  74. data/distro/common/html/_sources/knife_common_options.txt +6 -6
  75. data/distro/common/html/_sources/knife_configure.txt +29 -29
  76. data/distro/common/html/_sources/knife_cookbook.txt +236 -236
  77. data/distro/common/html/_sources/knife_cookbook_site.txt +157 -157
  78. data/distro/common/html/_sources/knife_data_bag.txt +159 -159
  79. data/distro/common/html/_sources/knife_delete.txt +26 -26
  80. data/distro/common/html/_sources/knife_deps.txt +61 -61
  81. data/distro/common/html/_sources/knife_diff.txt +34 -34
  82. data/distro/common/html/_sources/knife_download.txt +44 -44
  83. data/distro/common/html/_sources/knife_edit.txt +26 -26
  84. data/distro/common/html/_sources/knife_environment.txt +158 -158
  85. data/distro/common/html/_sources/knife_exec.txt +47 -47
  86. data/distro/common/html/_sources/knife_index_rebuild.txt +20 -20
  87. data/distro/common/html/_sources/knife_list.txt +33 -33
  88. data/distro/common/html/_sources/knife_node.txt +250 -250
  89. data/distro/common/html/_sources/knife_raw.txt +35 -35
  90. data/distro/common/html/_sources/knife_recipe_list.txt +23 -23
  91. data/distro/common/html/_sources/knife_role.txt +157 -157
  92. data/distro/common/html/_sources/knife_search.txt +53 -53
  93. data/distro/common/html/_sources/knife_serve.txt +18 -18
  94. data/distro/common/html/_sources/knife_show.txt +26 -26
  95. data/distro/common/html/_sources/knife_ssh.txt +43 -43
  96. data/distro/common/html/_sources/knife_ssl_check.txt +41 -41
  97. data/distro/common/html/_sources/knife_ssl_fetch.txt +41 -41
  98. data/distro/common/html/_sources/knife_status.txt +37 -37
  99. data/distro/common/html/_sources/knife_tag.txt +69 -69
  100. data/distro/common/html/_sources/knife_upload.txt +49 -49
  101. data/distro/common/html/_sources/knife_user.txt +127 -127
  102. data/distro/common/html/_sources/knife_using.txt +43 -43
  103. data/distro/common/html/_sources/knife_xargs.txt +30 -30
  104. data/distro/common/html/_static/basic.css +536 -536
  105. data/distro/common/html/_static/doctools.js +238 -238
  106. data/distro/common/html/_static/guide.css +504 -504
  107. data/distro/common/html/_static/pygments.css +61 -61
  108. data/distro/common/html/_static/searchtools.js +621 -621
  109. data/distro/common/html/_static/underscore.js +31 -31
  110. data/distro/common/html/_static/websupport.js +808 -808
  111. data/distro/common/html/ctl_chef_client.html +269 -269
  112. data/distro/common/html/ctl_chef_server.html +727 -727
  113. data/distro/common/html/ctl_chef_shell.html +162 -162
  114. data/distro/common/html/ctl_chef_solo.html +193 -193
  115. data/distro/common/html/index.html +201 -201
  116. data/distro/common/html/knife.html +169 -169
  117. data/distro/common/html/knife_bootstrap.html +284 -284
  118. data/distro/common/html/knife_client.html +284 -284
  119. data/distro/common/html/knife_common_options.html +95 -95
  120. data/distro/common/html/knife_configure.html +104 -104
  121. data/distro/common/html/knife_cookbook.html +486 -486
  122. data/distro/common/html/knife_cookbook_site.html +375 -375
  123. data/distro/common/html/knife_data_bag.html +373 -373
  124. data/distro/common/html/knife_delete.html +92 -92
  125. data/distro/common/html/knife_deps.html +142 -142
  126. data/distro/common/html/knife_diff.html +122 -122
  127. data/distro/common/html/knife_download.html +144 -144
  128. data/distro/common/html/knife_edit.html +88 -88
  129. data/distro/common/html/knife_environment.html +325 -325
  130. data/distro/common/html/knife_exec.html +219 -219
  131. data/distro/common/html/knife_index_rebuild.html +82 -82
  132. data/distro/common/html/knife_list.html +113 -113
  133. data/distro/common/html/knife_node.html +457 -457
  134. data/distro/common/html/knife_raw.html +109 -109
  135. data/distro/common/html/knife_recipe_list.html +90 -90
  136. data/distro/common/html/knife_role.html +294 -294
  137. data/distro/common/html/knife_search.html +202 -202
  138. data/distro/common/html/knife_serve.html +78 -78
  139. data/distro/common/html/knife_show.html +103 -103
  140. data/distro/common/html/knife_ssh.html +176 -176
  141. data/distro/common/html/knife_ssl_check.html +150 -150
  142. data/distro/common/html/knife_ssl_fetch.html +150 -150
  143. data/distro/common/html/knife_status.html +143 -143
  144. data/distro/common/html/knife_tag.html +137 -137
  145. data/distro/common/html/knife_upload.html +152 -152
  146. data/distro/common/html/knife_user.html +241 -241
  147. data/distro/common/html/knife_using.html +209 -209
  148. data/distro/common/html/knife_xargs.html +121 -121
  149. data/distro/common/html/search.html +81 -81
  150. data/distro/common/man/man1/README.md +58 -58
  151. data/distro/common/man/man1/chef-shell.1 +194 -194
  152. data/distro/common/man/man1/knife-bootstrap.1 +215 -215
  153. data/distro/common/man/man1/knife-client.1 +443 -443
  154. data/distro/common/man/man1/knife-configure.1 +161 -161
  155. data/distro/common/man/man1/knife-cookbook-site.1 +552 -552
  156. data/distro/common/man/man1/knife-cookbook.1 +770 -770
  157. data/distro/common/man/man1/knife-data-bag.1 +617 -617
  158. data/distro/common/man/man1/knife-delete.1 +127 -127
  159. data/distro/common/man/man1/knife-deps.1 +246 -246
  160. data/distro/common/man/man1/knife-diff.1 +226 -226
  161. data/distro/common/man/man1/knife-download.1 +258 -258
  162. data/distro/common/man/man1/knife-edit.1 +121 -121
  163. data/distro/common/man/man1/knife-environment.1 +508 -508
  164. data/distro/common/man/man1/knife-exec.1 +362 -362
  165. data/distro/common/man/man1/knife-index-rebuild.1 +63 -63
  166. data/distro/common/man/man1/knife-list.1 +174 -174
  167. data/distro/common/man/man1/knife-node.1 +716 -716
  168. data/distro/common/man/man1/knife-raw.1 +172 -172
  169. data/distro/common/man/man1/knife-recipe-list.1 +85 -85
  170. data/distro/common/man/man1/knife-role.1 +426 -426
  171. data/distro/common/man/man1/knife-search.1 +359 -359
  172. data/distro/common/man/man1/knife-serve.1 +109 -109
  173. data/distro/common/man/man1/knife-show.1 +160 -160
  174. data/distro/common/man/man1/knife-ssh.1 +284 -284
  175. data/distro/common/man/man1/knife-ssl-check.1 +207 -207
  176. data/distro/common/man/man1/knife-ssl-fetch.1 +207 -207
  177. data/distro/common/man/man1/knife-status.1 +234 -234
  178. data/distro/common/man/man1/knife-tag.1 +189 -189
  179. data/distro/common/man/man1/knife-upload.1 +280 -280
  180. data/distro/common/man/man1/knife-user.1 +356 -356
  181. data/distro/common/man/man1/knife-xargs.1 +189 -189
  182. data/distro/common/man/man1/knife.1 +332 -332
  183. data/distro/common/man/man8/chef-apply.8 +86 -86
  184. data/distro/common/man/man8/chef-client.8 +398 -398
  185. data/distro/common/man/man8/chef-solo.8 +260 -260
  186. data/distro/common/markdown/README +3 -3
  187. data/distro/common/markdown/man1/chef-shell.mkd +195 -195
  188. data/distro/common/markdown/man1/knife-bootstrap.mkd +141 -141
  189. data/distro/common/markdown/man1/knife-client.mkd +103 -103
  190. data/distro/common/markdown/man1/knife-configure.mkd +70 -70
  191. data/distro/common/markdown/man1/knife-cookbook-site.mkd +123 -123
  192. data/distro/common/markdown/man1/knife-cookbook.mkd +263 -263
  193. data/distro/common/markdown/man1/knife-data-bag.mkd +121 -121
  194. data/distro/common/markdown/man1/knife-environment.mkd +151 -151
  195. data/distro/common/markdown/man1/knife-exec.mkd +42 -42
  196. data/distro/common/markdown/man1/knife-index.mkd +30 -30
  197. data/distro/common/markdown/man1/knife-node.mkd +130 -130
  198. data/distro/common/markdown/man1/knife-role.mkd +85 -85
  199. data/distro/common/markdown/man1/knife-search.mkd +180 -180
  200. data/distro/common/markdown/man1/knife-ssh.mkd +69 -69
  201. data/distro/common/markdown/man1/knife-status.mkd +36 -36
  202. data/distro/common/markdown/man1/knife-tag.mkd +39 -39
  203. data/distro/common/markdown/man1/knife.mkd +213 -213
  204. data/distro/common/markdown/man8/chef-client.mkd +75 -73
  205. data/distro/common/markdown/man8/chef-expander.mkd +81 -81
  206. data/distro/common/markdown/man8/chef-expanderctl.mkd +57 -57
  207. data/distro/common/markdown/man8/chef-server-webui.mkd +121 -121
  208. data/distro/common/markdown/man8/chef-server.mkd +120 -120
  209. data/distro/common/markdown/man8/chef-solo.mkd +107 -107
  210. data/distro/common/markdown/man8/chef-solr.mkd +89 -89
  211. data/distro/powershell/chef/chef.psm1 +327 -327
  212. data/lib-backcompat/chef/chef_fs/file_system/acl_entry.rb +5 -5
  213. data/lib-backcompat/chef/chef_fs/file_system/chef_repository_file_system_root_dir.rb +5 -5
  214. data/lib-backcompat/chef/chef_fs/file_system/chef_server_root_dir.rb +5 -5
  215. data/lib/chef.rb +35 -35
  216. data/lib/chef/api_client.rb +233 -233
  217. data/lib/chef/api_client/registration.rb +192 -192
  218. data/lib/chef/api_client_v1.rb +325 -325
  219. data/lib/chef/application.rb +342 -342
  220. data/lib/chef/application/apply.rb +221 -221
  221. data/lib/chef/application/client.rb +513 -501
  222. data/lib/chef/application/knife.rb +208 -208
  223. data/lib/chef/application/solo.rb +334 -330
  224. data/lib/chef/application/windows_service.rb +338 -338
  225. data/lib/chef/application/windows_service_manager.rb +202 -202
  226. data/lib/chef/applications.rb +4 -4
  227. data/lib/chef/audit/audit_event_proxy.rb +93 -93
  228. data/lib/chef/audit/audit_reporter.rb +172 -172
  229. data/lib/chef/audit/control_group_data.rb +139 -139
  230. data/lib/chef/audit/logger.rb +36 -36
  231. data/lib/chef/audit/rspec_formatter.rb +37 -37
  232. data/lib/chef/audit/runner.rb +196 -196
  233. data/lib/chef/chef_class.rb +228 -228
  234. data/lib/chef/chef_fs.rb +59 -59
  235. data/lib/chef/chef_fs/chef_fs_data_store.rb +871 -856
  236. data/lib/chef/chef_fs/command_line.rb +285 -285
  237. data/lib/chef/chef_fs/config.rb +283 -282
  238. data/lib/chef/chef_fs/data_handler/acl_data_handler.rb +26 -26
  239. data/lib/chef/chef_fs/data_handler/client_data_handler.rb +39 -39
  240. data/lib/chef/chef_fs/data_handler/client_key_data_handler.rb +11 -0
  241. data/lib/chef/chef_fs/data_handler/container_data_handler.rb +35 -29
  242. data/lib/chef/chef_fs/data_handler/cookbook_data_handler.rb +38 -38
  243. data/lib/chef/chef_fs/data_handler/data_bag_item_data_handler.rb +62 -56
  244. data/lib/chef/chef_fs/data_handler/data_handler_base.rb +204 -202
  245. data/lib/chef/chef_fs/data_handler/environment_data_handler.rb +40 -40
  246. data/lib/chef/chef_fs/data_handler/group_data_handler.rb +55 -55
  247. data/lib/chef/chef_fs/data_handler/node_data_handler.rb +36 -36
  248. data/lib/chef/chef_fs/data_handler/organization_data_handler.rb +36 -30
  249. data/lib/chef/chef_fs/data_handler/organization_invites_data_handler.rb +17 -17
  250. data/lib/chef/chef_fs/data_handler/organization_members_data_handler.rb +17 -17
  251. data/lib/chef/chef_fs/data_handler/policy_data_handler.rb +48 -42
  252. data/lib/chef/chef_fs/data_handler/policy_group_data_handler.rb +33 -27
  253. data/lib/chef/chef_fs/data_handler/role_data_handler.rb +40 -40
  254. data/lib/chef/chef_fs/data_handler/user_data_handler.rb +29 -29
  255. data/lib/chef/chef_fs/file_pattern.rb +301 -301
  256. data/lib/chef/chef_fs/file_system.rb +429 -429
  257. data/lib/chef/chef_fs/file_system/already_exists_error.rb +28 -28
  258. data/lib/chef/chef_fs/file_system/base_fs_dir.rb +47 -47
  259. data/lib/chef/chef_fs/file_system/base_fs_object.rb +183 -183
  260. data/lib/chef/chef_fs/file_system/chef_server/acl_dir.rb +65 -65
  261. data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +60 -60
  262. data/lib/chef/chef_fs/file_system/chef_server/acls_dir.rb +75 -75
  263. data/lib/chef/chef_fs/file_system/chef_server/chef_server_root_dir.rb +196 -196
  264. data/lib/chef/chef_fs/file_system/chef_server/cookbook_artifact_dir.rb +38 -38
  265. data/lib/chef/chef_fs/file_system/chef_server/cookbook_artifacts_dir.rb +102 -102
  266. data/lib/chef/chef_fs/file_system/chef_server/cookbook_dir.rb +222 -222
  267. data/lib/chef/chef_fs/file_system/chef_server/cookbook_file.rb +84 -84
  268. data/lib/chef/chef_fs/file_system/chef_server/cookbook_subdir.rb +61 -61
  269. data/lib/chef/chef_fs/file_system/chef_server/cookbooks_acl_dir.rb +42 -42
  270. data/lib/chef/chef_fs/file_system/chef_server/cookbooks_dir.rb +102 -102
  271. data/lib/chef/chef_fs/file_system/chef_server/data_bag_dir.rb +71 -71
  272. data/lib/chef/chef_fs/file_system/chef_server/data_bags_dir.rb +69 -69
  273. data/lib/chef/chef_fs/file_system/chef_server/environments_dir.rb +57 -57
  274. data/lib/chef/chef_fs/file_system/chef_server/nodes_dir.rb +53 -53
  275. data/lib/chef/chef_fs/file_system/chef_server/org_entry.rb +31 -31
  276. data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +61 -61
  277. data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +60 -60
  278. data/lib/chef/chef_fs/file_system/chef_server/policies_acl_dir.rb +41 -41
  279. data/lib/chef/chef_fs/file_system/chef_server/policies_dir.rb +160 -160
  280. data/lib/chef/chef_fs/file_system/chef_server/policy_group_entry.rb +137 -137
  281. data/lib/chef/chef_fs/file_system/chef_server/policy_groups_dir.rb +43 -43
  282. data/lib/chef/chef_fs/file_system/chef_server/policy_revision_entry.rb +34 -34
  283. data/lib/chef/chef_fs/file_system/chef_server/rest_list_dir.rb +178 -178
  284. data/lib/chef/chef_fs/file_system/chef_server/rest_list_entry.rb +187 -187
  285. data/lib/chef/chef_fs/file_system/chef_server/versioned_cookbook_dir.rb +45 -45
  286. data/lib/chef/chef_fs/file_system/chef_server/versioned_cookbooks_dir.rb +107 -107
  287. data/lib/chef/chef_fs/file_system/cookbook_frozen_error.rb +28 -28
  288. data/lib/chef/chef_fs/file_system/default_environment_cannot_be_modified_error.rb +32 -32
  289. data/lib/chef/chef_fs/file_system/file_system_error.rb +44 -44
  290. data/lib/chef/chef_fs/file_system/memory/memory_dir.rb +53 -53
  291. data/lib/chef/chef_fs/file_system/memory/memory_file.rb +20 -20
  292. data/lib/chef/chef_fs/file_system/memory/memory_root.rb +23 -23
  293. data/lib/chef/chef_fs/file_system/multiplexed_dir.rb +64 -64
  294. data/lib/chef/chef_fs/file_system/must_delete_recursively_error.rb +28 -28
  295. data/lib/chef/chef_fs/file_system/nonexistent_fs_object.rb +36 -36
  296. data/lib/chef/chef_fs/file_system/not_found_error.rb +28 -28
  297. data/lib/chef/chef_fs/file_system/operation_failed_error.rb +42 -42
  298. data/lib/chef/chef_fs/file_system/operation_not_allowed_error.rb +46 -46
  299. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_acls_dir.rb +39 -39
  300. data/lib/chef/chef_fs/file_system/repository/{chef_repository_file_system_data_bags_dir.rb → chef_repository_file_system_client_keys_dir.rb} +38 -38
  301. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_artifact_dir.rb +41 -41
  302. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +146 -95
  303. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +176 -82
  304. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_entry.rb +83 -83
  305. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_policies_dir.rb +38 -38
  306. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +214 -210
  307. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_versioned_cookbook_dir.rb +42 -42
  308. data/lib/chef/chef_fs/file_system/repository/{chef_repository_file_system_cookbook_artifacts_dir.rb → cookbook_artifacts_dir.rb} +36 -34
  309. data/lib/chef/chef_fs/file_system/repository/cookbooks_dir.rb +52 -0
  310. data/lib/chef/chef_fs/file_system/repository/data_bag.rb +39 -0
  311. data/lib/chef/chef_fs/file_system/repository/data_bag_item.rb +114 -0
  312. data/lib/chef/chef_fs/file_system/repository/data_bags_dir.rb +39 -0
  313. data/lib/chef/chef_fs/file_system/repository/directory.rb +139 -0
  314. data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +117 -117
  315. data/lib/chef/chef_fs/file_system/repository/file_system_root_dir.rb +33 -33
  316. data/lib/chef/chef_fs/file_system/repository/{chef_repository_file_system_versioned_cookbooks_dir.rb → versioned_cookbooks_dir.rb} +34 -34
  317. data/lib/chef/chef_fs/knife.rb +161 -161
  318. data/lib/chef/chef_fs/parallelizer.rb +105 -105
  319. data/lib/chef/chef_fs/parallelizer/flatten_enumerable.rb +35 -35
  320. data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +281 -281
  321. data/lib/chef/chef_fs/path_utils.rb +127 -127
  322. data/lib/chef/client.rb +967 -967
  323. data/lib/chef/config.rb +85 -85
  324. data/lib/chef/config_fetcher.rb +72 -72
  325. data/lib/chef/constants.rb +28 -28
  326. data/lib/chef/cookbook/chefignore.rb +74 -74
  327. data/lib/chef/cookbook/cookbook_collection.rb +63 -58
  328. data/lib/chef/cookbook/cookbook_version_loader.rb +352 -301
  329. data/lib/chef/cookbook/file_system_file_vendor.rb +59 -59
  330. data/lib/chef/cookbook/file_vendor.rb +71 -71
  331. data/lib/chef/cookbook/gem_installer.rb +118 -0
  332. data/lib/chef/cookbook/metadata.rb +904 -886
  333. data/lib/chef/cookbook/remote_file_vendor.rb +87 -87
  334. data/lib/chef/cookbook/synchronizer.rb +298 -294
  335. data/lib/chef/cookbook/syntax_check.rb +260 -260
  336. data/lib/chef/cookbook_loader.rb +200 -182
  337. data/lib/chef/cookbook_manifest.rb +290 -290
  338. data/lib/chef/cookbook_site_streaming_uploader.rb +244 -244
  339. data/lib/chef/cookbook_uploader.rb +157 -157
  340. data/lib/chef/cookbook_version.rb +631 -627
  341. data/lib/chef/daemon.rb +131 -131
  342. data/lib/chef/data_bag.rb +176 -175
  343. data/lib/chef/data_bag_item.rb +218 -218
  344. data/lib/chef/delayed_evaluator.rb +21 -21
  345. data/lib/chef/deprecation/mixin/template.rb +48 -48
  346. data/lib/chef/deprecation/provider/cookbook_file.rb +54 -54
  347. data/lib/chef/deprecation/provider/file.rb +198 -198
  348. data/lib/chef/deprecation/provider/remote_directory.rb +52 -52
  349. data/lib/chef/deprecation/provider/remote_file.rb +85 -85
  350. data/lib/chef/deprecation/provider/template.rb +63 -63
  351. data/lib/chef/deprecation/warnings.rb +38 -38
  352. data/lib/chef/digester.rb +74 -74
  353. data/lib/chef/dsl.rb +6 -6
  354. data/lib/chef/dsl/audit.rb +51 -51
  355. data/lib/chef/dsl/chef_provisioning.rb +57 -57
  356. data/lib/chef/dsl/cheffish.rb +64 -64
  357. data/lib/chef/dsl/data_query.rb +89 -89
  358. data/lib/chef/dsl/declare_resource.rb +108 -108
  359. data/lib/chef/dsl/definitions.rb +43 -43
  360. data/lib/chef/dsl/include_attribute.rb +61 -61
  361. data/lib/chef/dsl/include_recipe.rb +44 -44
  362. data/lib/chef/dsl/platform_introspection.rb +254 -254
  363. data/lib/chef/dsl/powershell.rb +29 -29
  364. data/lib/chef/dsl/reboot_pending.rb +64 -64
  365. data/lib/chef/dsl/recipe.rb +134 -134
  366. data/lib/chef/dsl/registry_helper.rb +63 -63
  367. data/lib/chef/dsl/resources.rb +58 -58
  368. data/lib/chef/encrypted_data_bag_item.rb +155 -155
  369. data/lib/chef/encrypted_data_bag_item/assertions.rb +54 -54
  370. data/lib/chef/encrypted_data_bag_item/check_encrypted.rb +56 -56
  371. data/lib/chef/encrypted_data_bag_item/decryption_failure.rb +22 -22
  372. data/lib/chef/encrypted_data_bag_item/decryptor.rb +227 -227
  373. data/lib/chef/encrypted_data_bag_item/encrypted_data_bag_item_assertions.rb +37 -37
  374. data/lib/chef/encrypted_data_bag_item/encryption_failure.rb +22 -22
  375. data/lib/chef/encrypted_data_bag_item/encryptor.rb +225 -225
  376. data/lib/chef/encrypted_data_bag_item/unacceptable_encrypted_data_bag_item_format.rb +22 -22
  377. data/lib/chef/encrypted_data_bag_item/unsupported_cipher.rb +22 -22
  378. data/lib/chef/encrypted_data_bag_item/unsupported_encrypted_data_bag_item_format.rb +22 -22
  379. data/lib/chef/environment.rb +326 -326
  380. data/lib/chef/event_dispatch/base.rb +420 -400
  381. data/lib/chef/event_dispatch/dispatcher.rb +62 -62
  382. data/lib/chef/event_dispatch/dsl.rb +65 -65
  383. data/lib/chef/event_dispatch/events_output_stream.rb +37 -37
  384. data/lib/chef/event_loggers/base.rb +62 -62
  385. data/lib/chef/event_loggers/windows_eventlog.rb +101 -101
  386. data/lib/chef/exceptions.rb +504 -504
  387. data/lib/chef/file_access_control.rb +75 -75
  388. data/lib/chef/file_access_control/unix.rb +290 -290
  389. data/lib/chef/file_access_control/windows.rb +335 -335
  390. data/lib/chef/file_cache.rb +221 -221
  391. data/lib/chef/file_content_management/content_base.rb +56 -56
  392. data/lib/chef/file_content_management/deploy.rb +37 -37
  393. data/lib/chef/file_content_management/deploy/cp.rb +48 -48
  394. data/lib/chef/file_content_management/deploy/mv_unix.rb +76 -76
  395. data/lib/chef/file_content_management/deploy/mv_windows.rb +103 -103
  396. data/lib/chef/file_content_management/tempfile.rb +97 -96
  397. data/lib/chef/formatters/base.rb +237 -237
  398. data/lib/chef/formatters/doc.rb +422 -396
  399. data/lib/chef/formatters/error_descriptor.rb +67 -67
  400. data/lib/chef/formatters/error_inspectors.rb +19 -19
  401. data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +184 -184
  402. data/lib/chef/formatters/error_inspectors/compile_error_inspector.rb +154 -154
  403. data/lib/chef/formatters/error_inspectors/cookbook_resolve_error_inspector.rb +168 -168
  404. data/lib/chef/formatters/error_inspectors/cookbook_sync_error_inspector.rb +82 -82
  405. data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +128 -128
  406. data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +147 -147
  407. data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +124 -124
  408. data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +121 -121
  409. data/lib/chef/formatters/error_mapper.rb +85 -85
  410. data/lib/chef/formatters/indentable_output_stream.rb +170 -170
  411. data/lib/chef/formatters/minimal.rb +233 -233
  412. data/lib/chef/guard_interpreter.rb +32 -32
  413. data/lib/chef/guard_interpreter/default_guard_interpreter.rb +43 -43
  414. data/lib/chef/guard_interpreter/resource_guard_interpreter.rb +138 -138
  415. data/lib/chef/handler.rb +235 -235
  416. data/lib/chef/handler/error_report.rb +33 -33
  417. data/lib/chef/handler/json_file.rb +63 -63
  418. data/lib/chef/http.rb +430 -427
  419. data/lib/chef/http/auth_credentials.rb +57 -57
  420. data/lib/chef/http/authenticator.rb +106 -106
  421. data/lib/chef/http/basic_client.rb +169 -169
  422. data/lib/chef/http/cookie_jar.rb +31 -31
  423. data/lib/chef/http/cookie_manager.rb +59 -59
  424. data/lib/chef/http/decompressor.rb +142 -142
  425. data/lib/chef/http/http_request.rb +186 -186
  426. data/lib/chef/http/json_input.rb +73 -73
  427. data/lib/chef/http/json_output.rb +78 -78
  428. data/lib/chef/http/json_to_model_output.rb +34 -34
  429. data/lib/chef/http/remote_request_id.rb +46 -46
  430. data/lib/chef/http/simple.rb +40 -40
  431. data/lib/chef/http/simple_json.rb +43 -43
  432. data/lib/chef/http/socketless_chef_zero_client.rb +207 -206
  433. data/lib/chef/http/ssl_policies.rb +130 -130
  434. data/lib/chef/http/validate_content_length.rb +115 -110
  435. data/lib/chef/json_compat.rb +164 -164
  436. data/lib/chef/key.rb +273 -273
  437. data/lib/chef/knife.rb +587 -580
  438. data/lib/chef/knife/bootstrap.rb +480 -480
  439. data/lib/chef/knife/bootstrap/chef_vault_handler.rb +159 -159
  440. data/lib/chef/knife/bootstrap/client_builder.rb +208 -208
  441. data/lib/chef/knife/bootstrap/templates/README.md +11 -11
  442. data/lib/chef/knife/bootstrap/templates/chef-full.erb +236 -231
  443. data/lib/chef/knife/client_bulk_delete.rb +104 -104
  444. data/lib/chef/knife/client_create.rb +111 -111
  445. data/lib/chef/knife/client_delete.rb +60 -60
  446. data/lib/chef/knife/client_edit.rb +53 -53
  447. data/lib/chef/knife/client_key_create.rb +67 -67
  448. data/lib/chef/knife/client_key_delete.rb +76 -76
  449. data/lib/chef/knife/client_key_edit.rb +79 -79
  450. data/lib/chef/knife/client_key_list.rb +69 -69
  451. data/lib/chef/knife/client_key_show.rb +76 -76
  452. data/lib/chef/knife/client_list.rb +42 -42
  453. data/lib/chef/knife/client_reregister.rb +59 -59
  454. data/lib/chef/knife/client_show.rb +49 -49
  455. data/lib/chef/knife/configure.rb +171 -171
  456. data/lib/chef/knife/configure_client.rb +50 -50
  457. data/lib/chef/knife/cookbook_bulk_delete.rb +71 -71
  458. data/lib/chef/knife/cookbook_create.rb +448 -448
  459. data/lib/chef/knife/cookbook_delete.rb +151 -151
  460. data/lib/chef/knife/cookbook_download.rb +143 -143
  461. data/lib/chef/knife/cookbook_list.rb +47 -47
  462. data/lib/chef/knife/cookbook_metadata.rb +108 -108
  463. data/lib/chef/knife/cookbook_metadata_from_file.rb +44 -44
  464. data/lib/chef/knife/cookbook_show.rb +98 -98
  465. data/lib/chef/knife/cookbook_site_download.rb +109 -109
  466. data/lib/chef/knife/cookbook_site_install.rb +192 -192
  467. data/lib/chef/knife/cookbook_site_list.rb +58 -58
  468. data/lib/chef/knife/cookbook_site_search.rb +46 -46
  469. data/lib/chef/knife/cookbook_site_share.rb +169 -169
  470. data/lib/chef/knife/cookbook_site_show.rb +55 -55
  471. data/lib/chef/knife/cookbook_site_unshare.rb +56 -56
  472. data/lib/chef/knife/cookbook_site_vendor.rb +46 -46
  473. data/lib/chef/knife/cookbook_test.rb +95 -95
  474. data/lib/chef/knife/cookbook_upload.rb +308 -310
  475. data/lib/chef/knife/core/bootstrap_context.rb +233 -200
  476. data/lib/chef/knife/core/cookbook_scm_repo.rb +159 -159
  477. data/lib/chef/knife/core/custom_manifest_loader.rb +69 -69
  478. data/lib/chef/knife/core/gem_glob_loader.rb +138 -138
  479. data/lib/chef/knife/core/generic_presenter.rb +222 -222
  480. data/lib/chef/knife/core/hashed_command_loader.rb +99 -80
  481. data/lib/chef/knife/core/node_editor.rb +130 -130
  482. data/lib/chef/knife/core/node_presenter.rb +159 -159
  483. data/lib/chef/knife/core/object_loader.rb +115 -115
  484. data/lib/chef/knife/core/status_presenter.rb +157 -157
  485. data/lib/chef/knife/core/subcommand_loader.rb +212 -206
  486. data/lib/chef/knife/core/text_formatter.rb +85 -85
  487. data/lib/chef/knife/core/ui.rb +284 -275
  488. data/lib/chef/knife/data_bag_create.rb +78 -78
  489. data/lib/chef/knife/data_bag_delete.rb +49 -49
  490. data/lib/chef/knife/data_bag_edit.rb +74 -74
  491. data/lib/chef/knife/data_bag_from_file.rb +114 -114
  492. data/lib/chef/knife/data_bag_list.rb +42 -42
  493. data/lib/chef/knife/data_bag_secret_options.rb +142 -142
  494. data/lib/chef/knife/data_bag_show.rb +69 -69
  495. data/lib/chef/knife/delete.rb +107 -107
  496. data/lib/chef/knife/deps.rb +140 -140
  497. data/lib/chef/knife/diff.rb +68 -68
  498. data/lib/chef/knife/download.rb +68 -68
  499. data/lib/chef/knife/edit.rb +72 -72
  500. data/lib/chef/knife/environment_compare.rb +127 -127
  501. data/lib/chef/knife/environment_create.rb +53 -53
  502. data/lib/chef/knife/environment_delete.rb +45 -45
  503. data/lib/chef/knife/environment_edit.rb +45 -45
  504. data/lib/chef/knife/environment_from_file.rb +82 -82
  505. data/lib/chef/knife/environment_list.rb +42 -42
  506. data/lib/chef/knife/environment_show.rb +48 -48
  507. data/lib/chef/knife/exec.rb +87 -87
  508. data/lib/chef/knife/help.rb +101 -101
  509. data/lib/chef/knife/help_topics.rb +4 -4
  510. data/lib/chef/knife/index_rebuild.rb +133 -133
  511. data/lib/chef/knife/key_create.rb +112 -108
  512. data/lib/chef/knife/key_create_base.rb +50 -50
  513. data/lib/chef/knife/key_delete.rb +55 -55
  514. data/lib/chef/knife/key_edit.rb +118 -114
  515. data/lib/chef/knife/key_edit_base.rb +55 -55
  516. data/lib/chef/knife/key_list.rb +88 -88
  517. data/lib/chef/knife/key_list_base.rb +45 -45
  518. data/lib/chef/knife/key_show.rb +53 -53
  519. data/lib/chef/knife/list.rb +157 -157
  520. data/lib/chef/knife/node_bulk_delete.rb +74 -74
  521. data/lib/chef/knife/node_create.rb +47 -47
  522. data/lib/chef/knife/node_delete.rb +46 -46
  523. data/lib/chef/knife/node_edit.rb +70 -70
  524. data/lib/chef/knife/node_environment_set.rb +54 -54
  525. data/lib/chef/knife/node_from_file.rb +51 -51
  526. data/lib/chef/knife/node_list.rb +44 -44
  527. data/lib/chef/knife/node_run_list_add.rb +104 -104
  528. data/lib/chef/knife/node_run_list_remove.rb +67 -67
  529. data/lib/chef/knife/node_run_list_set.rb +66 -66
  530. data/lib/chef/knife/node_show.rb +66 -66
  531. data/lib/chef/knife/null.rb +10 -10
  532. data/lib/chef/knife/osc_user_create.rb +97 -97
  533. data/lib/chef/knife/osc_user_delete.rb +51 -51
  534. data/lib/chef/knife/osc_user_edit.rb +58 -58
  535. data/lib/chef/knife/osc_user_list.rb +47 -47
  536. data/lib/chef/knife/osc_user_reregister.rb +64 -64
  537. data/lib/chef/knife/osc_user_show.rb +54 -54
  538. data/lib/chef/knife/raw.rb +103 -103
  539. data/lib/chef/knife/recipe_list.rb +32 -32
  540. data/lib/chef/knife/rehash.rb +65 -62
  541. data/lib/chef/knife/role_bulk_delete.rb +65 -65
  542. data/lib/chef/knife/role_create.rb +53 -53
  543. data/lib/chef/knife/role_delete.rb +46 -46
  544. data/lib/chef/knife/role_edit.rb +45 -45
  545. data/lib/chef/knife/role_env_run_list_add.rb +86 -86
  546. data/lib/chef/knife/role_env_run_list_clear.rb +55 -55
  547. data/lib/chef/knife/role_env_run_list_remove.rb +57 -57
  548. data/lib/chef/knife/role_env_run_list_replace.rb +59 -59
  549. data/lib/chef/knife/role_env_run_list_set.rb +70 -70
  550. data/lib/chef/knife/role_from_file.rb +51 -51
  551. data/lib/chef/knife/role_list.rb +42 -42
  552. data/lib/chef/knife/role_run_list_add.rb +86 -86
  553. data/lib/chef/knife/role_run_list_clear.rb +55 -55
  554. data/lib/chef/knife/role_run_list_remove.rb +57 -57
  555. data/lib/chef/knife/role_run_list_replace.rb +59 -59
  556. data/lib/chef/knife/role_run_list_set.rb +70 -70
  557. data/lib/chef/knife/role_show.rb +49 -49
  558. data/lib/chef/knife/search.rb +201 -201
  559. data/lib/chef/knife/serve.rb +48 -48
  560. data/lib/chef/knife/show.rb +56 -56
  561. data/lib/chef/knife/ssh.rb +572 -575
  562. data/lib/chef/knife/ssl_check.rb +281 -281
  563. data/lib/chef/knife/ssl_fetch.rb +157 -157
  564. data/lib/chef/knife/status.rb +110 -110
  565. data/lib/chef/knife/tag_create.rb +52 -52
  566. data/lib/chef/knife/tag_delete.rb +60 -60
  567. data/lib/chef/knife/tag_list.rb +47 -47
  568. data/lib/chef/knife/upload.rb +70 -70
  569. data/lib/chef/knife/user_create.rb +150 -150
  570. data/lib/chef/knife/user_delete.rb +95 -95
  571. data/lib/chef/knife/user_edit.rb +81 -81
  572. data/lib/chef/knife/user_key_create.rb +69 -69
  573. data/lib/chef/knife/user_key_delete.rb +76 -76
  574. data/lib/chef/knife/user_key_edit.rb +79 -79
  575. data/lib/chef/knife/user_key_list.rb +69 -69
  576. data/lib/chef/knife/user_key_show.rb +76 -76
  577. data/lib/chef/knife/user_list.rb +45 -45
  578. data/lib/chef/knife/user_reregister.rb +89 -89
  579. data/lib/chef/knife/user_show.rb +78 -78
  580. data/lib/chef/knife/xargs.rb +266 -266
  581. data/lib/chef/local_mode.rb +128 -128
  582. data/lib/chef/log.rb +68 -68
  583. data/lib/chef/log/syslog.rb +45 -45
  584. data/lib/chef/log/winevt.rb +99 -99
  585. data/lib/chef/mash.rb +226 -226
  586. data/lib/chef/mixin/api_version_request_handling.rb +66 -66
  587. data/lib/chef/mixin/checksum.rb +32 -32
  588. data/lib/chef/mixin/command.rb +193 -192
  589. data/lib/chef/mixin/command/unix.rb +220 -220
  590. data/lib/chef/mixin/command/windows.rb +71 -71
  591. data/lib/chef/mixin/convert_to_class_name.rb +126 -126
  592. data/lib/chef/mixin/create_path.rb +73 -73
  593. data/lib/chef/mixin/deep_merge.rb +140 -140
  594. data/lib/chef/mixin/deprecation.rb +123 -123
  595. data/lib/chef/mixin/descendants_tracker.rb +81 -81
  596. data/lib/chef/mixin/enforce_ownership_and_permissions.rb +39 -39
  597. data/lib/chef/mixin/file_class.rb +35 -35
  598. data/lib/chef/mixin/from_file.rb +50 -50
  599. data/lib/chef/mixin/get_source_from_package.rb +47 -47
  600. data/lib/chef/mixin/homebrew_user.rb +68 -68
  601. data/lib/chef/mixin/language.rb +48 -48
  602. data/lib/chef/mixin/language_include_attribute.rb +34 -34
  603. data/lib/chef/mixin/language_include_recipe.rb +31 -31
  604. data/lib/chef/mixin/params_validate.rb +489 -489
  605. data/lib/chef/mixin/path_sanity.rb +68 -68
  606. data/lib/chef/mixin/powershell_out.rb +98 -98
  607. data/lib/chef/mixin/powershell_type_coercions.rb +84 -84
  608. data/lib/chef/mixin/properties.rb +303 -302
  609. data/lib/chef/mixin/provides.rb +28 -27
  610. data/lib/chef/mixin/proxified_socket.rb +38 -38
  611. data/lib/chef/mixin/recipe_definition_dsl_core.rb +35 -35
  612. data/lib/chef/mixin/securable.rb +196 -196
  613. data/lib/chef/mixin/shell_out.rb +117 -117
  614. data/lib/chef/mixin/subclass_directive.rb +37 -37
  615. data/lib/chef/mixin/template.rb +262 -262
  616. data/lib/chef/mixin/unformatter.rb +32 -32
  617. data/lib/chef/mixin/uris.rb +43 -43
  618. data/lib/chef/mixin/which.rb +37 -37
  619. data/lib/chef/mixin/why_run.rb +331 -331
  620. data/lib/chef/mixin/wide_string.rb +72 -72
  621. data/lib/chef/mixin/windows_architecture_helper.rb +114 -114
  622. data/lib/chef/mixin/windows_env_helper.rb +67 -67
  623. data/lib/chef/mixin/xml_escape.rb +140 -140
  624. data/lib/chef/mixins.rb +13 -13
  625. data/lib/chef/monkey_patches/net-ssh-multi.rb +140 -140
  626. data/lib/chef/monkey_patches/net_http.rb +60 -60
  627. data/lib/chef/monkey_patches/webrick-utils.rb +51 -51
  628. data/lib/chef/monkey_patches/win32/registry.rb +72 -72
  629. data/lib/chef/monologger.rb +88 -88
  630. data/lib/chef/nil_argument.rb +3 -3
  631. data/lib/chef/node.rb +700 -700
  632. data/lib/chef/node/attribute.rb +586 -586
  633. data/lib/chef/node/attribute_collections.rb +323 -323
  634. data/lib/chef/node/immutable_collections.rb +219 -219
  635. data/lib/chef/node_map.rb +222 -222
  636. data/lib/chef/null_logger.rb +72 -72
  637. data/lib/chef/org.rb +149 -149
  638. data/lib/chef/platform.rb +30 -30
  639. data/lib/chef/platform/handler_map.rb +40 -40
  640. data/lib/chef/platform/priority_map.rb +41 -41
  641. data/lib/chef/platform/provider_handler_map.rb +29 -29
  642. data/lib/chef/platform/provider_mapping.rb +214 -214
  643. data/lib/chef/platform/provider_priority_map.rb +11 -11
  644. data/lib/chef/platform/query_helpers.rb +112 -112
  645. data/lib/chef/platform/rebooter.rb +54 -54
  646. data/lib/chef/platform/resource_handler_map.rb +29 -29
  647. data/lib/chef/platform/resource_priority_map.rb +11 -11
  648. data/lib/chef/platform/service_helpers.rb +122 -122
  649. data/lib/chef/policy_builder.rb +42 -42
  650. data/lib/chef/policy_builder/dynamic.rb +185 -185
  651. data/lib/chef/policy_builder/expand_node_object.rb +278 -274
  652. data/lib/chef/policy_builder/policyfile.rb +527 -525
  653. data/lib/chef/property.rb +673 -673
  654. data/lib/chef/provider.rb +461 -461
  655. data/lib/chef/provider/apt_update.rb +79 -79
  656. data/lib/chef/provider/batch.rb +45 -45
  657. data/lib/chef/provider/breakpoint.rb +38 -38
  658. data/lib/chef/provider/cookbook_file.rb +53 -53
  659. data/lib/chef/provider/cookbook_file/content.rb +49 -49
  660. data/lib/chef/provider/cron.rb +263 -263
  661. data/lib/chef/provider/cron/aix.rb +50 -50
  662. data/lib/chef/provider/cron/solaris.rb +22 -22
  663. data/lib/chef/provider/cron/unix.rb +83 -83
  664. data/lib/chef/provider/deploy.rb +476 -476
  665. data/lib/chef/provider/deploy/revision.rb +109 -109
  666. data/lib/chef/provider/deploy/timestamped.rb +34 -34
  667. data/lib/chef/provider/directory.rb +152 -152
  668. data/lib/chef/provider/dsc_resource.rb +197 -200
  669. data/lib/chef/provider/dsc_script.rb +185 -185
  670. data/lib/chef/provider/env.rb +169 -169
  671. data/lib/chef/provider/env/windows.rb +72 -72
  672. data/lib/chef/provider/erl_call.rb +108 -108
  673. data/lib/chef/provider/execute.rb +125 -125
  674. data/lib/chef/provider/file.rb +495 -495
  675. data/lib/chef/provider/file/content.rb +39 -39
  676. data/lib/chef/provider/git.rb +332 -332
  677. data/lib/chef/provider/group.rb +183 -183
  678. data/lib/chef/provider/group/aix.rb +86 -86
  679. data/lib/chef/provider/group/dscl.rb +170 -170
  680. data/lib/chef/provider/group/gpasswd.rb +58 -58
  681. data/lib/chef/provider/group/groupadd.rb +137 -137
  682. data/lib/chef/provider/group/groupmod.rb +128 -128
  683. data/lib/chef/provider/group/pw.rb +140 -140
  684. data/lib/chef/provider/group/suse.rb +62 -62
  685. data/lib/chef/provider/group/usermod.rb +91 -91
  686. data/lib/chef/provider/group/windows.rb +98 -98
  687. data/lib/chef/provider/http_request.rb +122 -122
  688. data/lib/chef/provider/ifconfig.rb +226 -226
  689. data/lib/chef/provider/ifconfig/aix.rb +99 -99
  690. data/lib/chef/provider/ifconfig/debian.rb +84 -84
  691. data/lib/chef/provider/ifconfig/redhat.rb +48 -48
  692. data/lib/chef/provider/launchd.rb +208 -0
  693. data/lib/chef/provider/link.rb +159 -159
  694. data/lib/chef/provider/log.rb +57 -57
  695. data/lib/chef/provider/lwrp_base.rb +99 -99
  696. data/lib/chef/provider/mdadm.rb +92 -92
  697. data/lib/chef/provider/mount.rb +173 -173
  698. data/lib/chef/provider/mount/aix.rb +180 -180
  699. data/lib/chef/provider/mount/mount.rb +270 -270
  700. data/lib/chef/provider/mount/solaris.rb +271 -271
  701. data/lib/chef/provider/mount/windows.rb +86 -86
  702. data/lib/chef/provider/ohai.rb +49 -49
  703. data/lib/chef/provider/osx_profile.rb +256 -256
  704. data/lib/chef/provider/package.rb +565 -565
  705. data/lib/chef/provider/package/aix.rb +136 -136
  706. data/lib/chef/provider/package/apt.rb +185 -185
  707. data/lib/chef/provider/package/chocolatey.rb +275 -277
  708. data/lib/chef/provider/package/dpkg.rb +226 -226
  709. data/lib/chef/provider/package/easy_install.rb +133 -133
  710. data/lib/chef/provider/package/freebsd/base.rb +89 -89
  711. data/lib/chef/provider/package/freebsd/pkg.rb +114 -114
  712. data/lib/chef/provider/package/freebsd/pkgng.rb +78 -78
  713. data/lib/chef/provider/package/freebsd/port.rb +60 -60
  714. data/lib/chef/provider/package/homebrew.rb +137 -137
  715. data/lib/chef/provider/package/ips.rb +91 -91
  716. data/lib/chef/provider/package/macports.rb +101 -101
  717. data/lib/chef/provider/package/openbsd.rb +136 -136
  718. data/lib/chef/provider/package/pacman.rb +104 -104
  719. data/lib/chef/provider/package/paludis.rb +86 -86
  720. data/lib/chef/provider/package/portage.rb +140 -140
  721. data/lib/chef/provider/package/rpm.rb +123 -123
  722. data/lib/chef/provider/package/rubygems.rb +586 -586
  723. data/lib/chef/provider/package/smartos.rb +92 -92
  724. data/lib/chef/provider/package/solaris.rb +138 -138
  725. data/lib/chef/provider/package/windows.rb +269 -260
  726. data/lib/chef/provider/package/windows/exe.rb +117 -117
  727. data/lib/chef/provider/package/windows/msi.rb +93 -93
  728. data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +89 -89
  729. data/lib/chef/provider/package/yum-dump.py +307 -307
  730. data/lib/chef/provider/package/yum.rb +1421 -1421
  731. data/lib/chef/provider/package/zypper.rb +143 -143
  732. data/lib/chef/provider/powershell_script.rb +215 -215
  733. data/lib/chef/provider/reboot.rb +70 -70
  734. data/lib/chef/provider/registry_key.rb +155 -155
  735. data/lib/chef/provider/remote_directory.rb +281 -281
  736. data/lib/chef/provider/remote_file.rb +53 -53
  737. data/lib/chef/provider/remote_file/cache_control_data.rb +195 -195
  738. data/lib/chef/provider/remote_file/content.rb +81 -81
  739. data/lib/chef/provider/remote_file/fetcher.rb +55 -55
  740. data/lib/chef/provider/remote_file/ftp.rb +183 -183
  741. data/lib/chef/provider/remote_file/http.rb +117 -117
  742. data/lib/chef/provider/remote_file/local_file.rb +60 -60
  743. data/lib/chef/provider/remote_file/network_file.rb +48 -48
  744. data/lib/chef/provider/resource_update.rb +52 -52
  745. data/lib/chef/provider/route.rb +229 -229
  746. data/lib/chef/provider/ruby_block.rb +44 -44
  747. data/lib/chef/provider/script.rb +85 -85
  748. data/lib/chef/provider/service.rb +250 -212
  749. data/lib/chef/provider/service/aix.rb +129 -129
  750. data/lib/chef/provider/service/aixinit.rb +117 -117
  751. data/lib/chef/provider/service/arch.rb +118 -118
  752. data/lib/chef/provider/service/debian.rb +182 -182
  753. data/lib/chef/provider/service/freebsd.rb +195 -195
  754. data/lib/chef/provider/service/gentoo.rb +71 -71
  755. data/lib/chef/provider/service/init.rb +94 -94
  756. data/lib/chef/provider/service/insserv.rb +59 -59
  757. data/lib/chef/provider/service/invokercd.rb +41 -41
  758. data/lib/chef/provider/service/macosx.rb +250 -250
  759. data/lib/chef/provider/service/openbsd.rb +217 -217
  760. data/lib/chef/provider/service/redhat.rb +120 -120
  761. data/lib/chef/provider/service/simple.rb +175 -175
  762. data/lib/chef/provider/service/solaris.rb +117 -117
  763. data/lib/chef/provider/service/systemd.rb +155 -139
  764. data/lib/chef/provider/service/upstart.rb +242 -242
  765. data/lib/chef/provider/service/windows.rb +313 -313
  766. data/lib/chef/provider/subversion.rb +221 -221
  767. data/lib/chef/provider/template.rb +65 -65
  768. data/lib/chef/provider/template/content.rb +70 -70
  769. data/lib/chef/provider/template_finder.rb +62 -62
  770. data/lib/chef/provider/user.rb +211 -211
  771. data/lib/chef/provider/user/aix.rb +97 -97
  772. data/lib/chef/provider/user/dscl.rb +710 -710
  773. data/lib/chef/provider/user/pw.rb +114 -114
  774. data/lib/chef/provider/user/solaris.rb +121 -121
  775. data/lib/chef/provider/user/useradd.rb +163 -163
  776. data/lib/chef/provider/user/windows.rb +128 -128
  777. data/lib/chef/provider/whyrun_safe_ruby_block.rb +32 -32
  778. data/lib/chef/provider/windows_script.rb +72 -72
  779. data/lib/chef/provider_resolver.rb +170 -170
  780. data/lib/chef/providers.rb +142 -141
  781. data/lib/chef/recipe.rb +119 -119
  782. data/lib/chef/request_id.rb +37 -37
  783. data/lib/chef/reserved_names.rb +9 -9
  784. data/lib/chef/resource.rb +1581 -1581
  785. data/lib/chef/resource/action_class.rb +87 -87
  786. data/lib/chef/resource/apt_package.rb +32 -32
  787. data/lib/chef/resource/apt_update.rb +33 -33
  788. data/lib/chef/resource/bash.rb +33 -33
  789. data/lib/chef/resource/batch.rb +33 -33
  790. data/lib/chef/resource/bff_package.rb +27 -27
  791. data/lib/chef/resource/breakpoint.rb +32 -32
  792. data/lib/chef/resource/chef_gem.rb +51 -51
  793. data/lib/chef/resource/chocolatey_package.rb +39 -39
  794. data/lib/chef/resource/conditional.rb +127 -127
  795. data/lib/chef/resource/conditional_action_not_nothing.rb +48 -48
  796. data/lib/chef/resource/cookbook_file.rb +49 -49
  797. data/lib/chef/resource/cron.rb +216 -216
  798. data/lib/chef/resource/csh.rb +33 -33
  799. data/lib/chef/resource/deploy.rb +443 -443
  800. data/lib/chef/resource/deploy_revision.rb +31 -31
  801. data/lib/chef/resource/directory.rb +62 -62
  802. data/lib/chef/resource/dpkg_package.rb +30 -30
  803. data/lib/chef/resource/dsc_resource.rb +121 -121
  804. data/lib/chef/resource/dsc_script.rb +140 -140
  805. data/lib/chef/resource/easy_install_package.rb +32 -32
  806. data/lib/chef/resource/env.rb +65 -65
  807. data/lib/chef/resource/erl_call.rb +85 -85
  808. data/lib/chef/resource/execute.rb +172 -172
  809. data/lib/chef/resource/file.rb +83 -83
  810. data/lib/chef/resource/file/verification.rb +128 -128
  811. data/lib/chef/resource/freebsd_package.rb +62 -62
  812. data/lib/chef/resource/gem_package.rb +41 -41
  813. data/lib/chef/resource/git.rb +44 -44
  814. data/lib/chef/resource/group.rb +102 -102
  815. data/lib/chef/resource/homebrew_package.rb +34 -34
  816. data/lib/chef/resource/http_request.rb +66 -66
  817. data/lib/chef/resource/ifconfig.rb +147 -147
  818. data/lib/chef/resource/ips_package.rb +34 -34
  819. data/lib/chef/resource/ksh.rb +32 -32
  820. data/lib/chef/resource/launchd.rb +104 -0
  821. data/lib/chef/resource/link.rb +107 -107
  822. data/lib/chef/resource/log.rb +76 -76
  823. data/lib/chef/resource/lwrp_base.rb +124 -124
  824. data/lib/chef/resource/macosx_service.rb +58 -58
  825. data/lib/chef/resource/macports_package.rb +27 -27
  826. data/lib/chef/resource/mdadm.rb +103 -103
  827. data/lib/chef/resource/mount.rb +187 -187
  828. data/lib/chef/resource/ohai.rb +53 -53
  829. data/lib/chef/resource/openbsd_package.rb +35 -35
  830. data/lib/chef/resource/osx_profile.rb +74 -74
  831. data/lib/chef/resource/package.rb +47 -47
  832. data/lib/chef/resource/pacman_package.rb +28 -28
  833. data/lib/chef/resource/paludis_package.rb +33 -33
  834. data/lib/chef/resource/perl.rb +32 -32
  835. data/lib/chef/resource/portage_package.rb +32 -32
  836. data/lib/chef/resource/powershell_script.rb +50 -50
  837. data/lib/chef/resource/python.rb +31 -31
  838. data/lib/chef/resource/reboot.rb +48 -48
  839. data/lib/chef/resource/registry_key.rb +144 -144
  840. data/lib/chef/resource/remote_directory.rb +122 -122
  841. data/lib/chef/resource/remote_file.rb +149 -149
  842. data/lib/chef/resource/resource_notification.rb +122 -122
  843. data/lib/chef/resource/route.rb +137 -137
  844. data/lib/chef/resource/rpm_package.rb +32 -32
  845. data/lib/chef/resource/ruby.rb +31 -31
  846. data/lib/chef/resource/ruby_block.rb +53 -53
  847. data/lib/chef/resource/scm.rb +185 -185
  848. data/lib/chef/resource/script.rb +74 -74
  849. data/lib/chef/resource/service.rb +208 -197
  850. data/lib/chef/resource/smartos_package.rb +29 -29
  851. data/lib/chef/resource/solaris_package.rb +31 -31
  852. data/lib/chef/resource/subversion.rb +44 -44
  853. data/lib/chef/resource/template.rb +215 -215
  854. data/lib/chef/resource/timestamped_deploy.rb +26 -26
  855. data/lib/chef/resource/user.rb +160 -160
  856. data/lib/chef/resource/whyrun_safe_ruby_block.rb +24 -24
  857. data/lib/chef/resource/windows_package.rb +55 -55
  858. data/lib/chef/resource/windows_script.rb +65 -65
  859. data/lib/chef/resource/windows_service.rb +71 -71
  860. data/lib/chef/resource/yum_package.rb +47 -47
  861. data/lib/chef/resource/zypper_package.rb +28 -28
  862. data/lib/chef/resource_builder.rb +151 -151
  863. data/lib/chef/resource_collection.rb +89 -89
  864. data/lib/chef/resource_collection/resource_collection_serialization.rb +59 -59
  865. data/lib/chef/resource_collection/resource_list.rb +90 -89
  866. data/lib/chef/resource_collection/resource_set.rb +170 -170
  867. data/lib/chef/resource_collection/stepable_iterator.rb +124 -124
  868. data/lib/chef/resource_definition.rb +68 -68
  869. data/lib/chef/resource_definition_list.rb +38 -38
  870. data/lib/chef/resource_reporter.rb +327 -327
  871. data/lib/chef/resource_resolver.rb +185 -185
  872. data/lib/chef/resources.rb +88 -87
  873. data/lib/chef/rest.rb +209 -209
  874. data/lib/chef/role.rb +280 -280
  875. data/lib/chef/run_context.rb +670 -670
  876. data/lib/chef/run_context/cookbook_compiler.rb +289 -289
  877. data/lib/chef/run_list.rb +168 -166
  878. data/lib/chef/run_list/run_list_expansion.rb +234 -234
  879. data/lib/chef/run_list/run_list_item.rb +98 -98
  880. data/lib/chef/run_list/versioned_recipe_list.rb +102 -102
  881. data/lib/chef/run_lock.rb +197 -197
  882. data/lib/chef/run_status.rb +125 -125
  883. data/lib/chef/runner.rb +141 -141
  884. data/lib/chef/sandbox.rb +20 -20
  885. data/lib/chef/scan_access_control.rb +138 -138
  886. data/lib/chef/search/query.rb +180 -180
  887. data/lib/chef/server_api.rb +78 -78
  888. data/lib/chef/shell.rb +327 -322
  889. data/lib/chef/shell/ext.rb +593 -593
  890. data/lib/chef/shell/model_wrapper.rb +120 -119
  891. data/lib/chef/shell/shell_session.rb +299 -299
  892. data/lib/chef/shell_out.rb +13 -13
  893. data/lib/chef/tasks/chef_repo.rake +200 -200
  894. data/lib/chef/user.rb +199 -199
  895. data/lib/chef/user_v1.rb +330 -330
  896. data/lib/chef/util/backup.rb +94 -94
  897. data/lib/chef/util/diff.rb +184 -184
  898. data/lib/chef/util/dsc/configuration_generator.rb +139 -139
  899. data/lib/chef/util/dsc/lcm_output_parser.rb +137 -137
  900. data/lib/chef/util/dsc/local_configuration_manager.rb +141 -141
  901. data/lib/chef/util/dsc/resource_info.rb +26 -26
  902. data/lib/chef/util/dsc/resource_store.rb +109 -109
  903. data/lib/chef/util/editor.rb +91 -91
  904. data/lib/chef/util/file_edit.rb +100 -100
  905. data/lib/chef/util/path_helper.rb +25 -25
  906. data/lib/chef/util/powershell/cmdlet.rb +170 -170
  907. data/lib/chef/util/powershell/cmdlet_result.rb +61 -61
  908. data/lib/chef/util/powershell/ps_credential.rb +41 -41
  909. data/lib/chef/util/selinux.rb +92 -92
  910. data/lib/chef/util/threaded_job_queue.rb +61 -61
  911. data/lib/chef/util/windows.rb +24 -24
  912. data/lib/chef/util/windows/net_group.rb +84 -84
  913. data/lib/chef/util/windows/net_use.rb +85 -85
  914. data/lib/chef/util/windows/net_user.rb +170 -169
  915. data/lib/chef/util/windows/volume.rb +59 -59
  916. data/lib/chef/version.rb +34 -34
  917. data/lib/chef/version/platform.rb +44 -44
  918. data/lib/chef/version_class.rb +70 -70
  919. data/lib/chef/version_constraint.rb +118 -118
  920. data/lib/chef/version_constraint/platform.rb +26 -26
  921. data/lib/chef/whitelist.rb +86 -86
  922. data/lib/chef/win32/api.rb +374 -374
  923. data/lib/chef/win32/api/crypto.rb +63 -63
  924. data/lib/chef/win32/api/error.rb +953 -922
  925. data/lib/chef/win32/api/file.rb +625 -622
  926. data/lib/chef/win32/api/installer.rb +165 -165
  927. data/lib/chef/win32/api/memory.rb +105 -105
  928. data/lib/chef/win32/api/net.rb +312 -312
  929. data/lib/chef/win32/api/process.rb +42 -42
  930. data/lib/chef/win32/api/psapi.rb +51 -51
  931. data/lib/chef/win32/api/registry.rb +51 -51
  932. data/lib/chef/win32/api/security.rb +460 -460
  933. data/lib/chef/win32/api/synchronization.rb +89 -89
  934. data/lib/chef/win32/api/system.rb +238 -238
  935. data/lib/chef/win32/api/unicode.rb +135 -135
  936. data/lib/chef/win32/crypto.rb +50 -50
  937. data/lib/chef/win32/error.rb +86 -76
  938. data/lib/chef/win32/eventlog.rb +31 -31
  939. data/lib/chef/win32/file.rb +218 -218
  940. data/lib/chef/win32/file/info.rb +99 -99
  941. data/lib/chef/win32/file/version_info.rb +93 -93
  942. data/lib/chef/win32/handle.rb +55 -55
  943. data/lib/chef/win32/memory.rb +101 -101
  944. data/lib/chef/win32/mutex.rb +116 -116
  945. data/lib/chef/win32/net.rb +311 -311
  946. data/lib/chef/win32/process.rb +97 -97
  947. data/lib/chef/win32/registry.rb +372 -372
  948. data/lib/chef/win32/security.rb +665 -665
  949. data/lib/chef/win32/security/ace.rb +123 -123
  950. data/lib/chef/win32/security/acl.rb +103 -103
  951. data/lib/chef/win32/security/securable_object.rb +109 -109
  952. data/lib/chef/win32/security/security_descriptor.rb +93 -93
  953. data/lib/chef/win32/security/sid.rb +304 -304
  954. data/lib/chef/win32/security/token.rb +72 -72
  955. data/lib/chef/win32/system.rb +62 -62
  956. data/lib/chef/win32/unicode.rb +60 -60
  957. data/lib/chef/win32/version.rb +158 -158
  958. data/lib/chef/workstation_config_loader.rb +23 -23
  959. data/spec/data/apt/chef-integration-test-1.0/debian/changelog +5 -5
  960. data/spec/data/apt/chef-integration-test-1.0/debian/compat +1 -1
  961. data/spec/data/apt/chef-integration-test-1.0/debian/control +13 -13
  962. data/spec/data/apt/chef-integration-test-1.0/debian/copyright +34 -34
  963. data/spec/data/apt/chef-integration-test-1.0/debian/files +1 -1
  964. data/spec/data/apt/chef-integration-test-1.0/debian/rules +13 -13
  965. data/spec/data/apt/chef-integration-test-1.0/debian/source/format +1 -1
  966. data/spec/data/apt/chef-integration-test-1.1/debian/changelog +11 -11
  967. data/spec/data/apt/chef-integration-test-1.1/debian/compat +1 -1
  968. data/spec/data/apt/chef-integration-test-1.1/debian/control +13 -13
  969. data/spec/data/apt/chef-integration-test-1.1/debian/copyright +34 -34
  970. data/spec/data/apt/chef-integration-test-1.1/debian/files +1 -1
  971. data/spec/data/apt/chef-integration-test-1.1/debian/rules +13 -13
  972. data/spec/data/apt/chef-integration-test-1.1/debian/source/format +1 -1
  973. data/spec/data/apt/chef-integration-test2-1.0/debian/changelog +5 -5
  974. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2.debhelper.log +45 -45
  975. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2.substvars +1 -1
  976. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/conffiles +1 -1
  977. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/control +10 -10
  978. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/md5sums +1 -1
  979. data/spec/data/apt/chef-integration-test2-1.0/debian/compat +1 -1
  980. data/spec/data/apt/chef-integration-test2-1.0/debian/conffiles +1 -1
  981. data/spec/data/apt/chef-integration-test2-1.0/debian/control +13 -13
  982. data/spec/data/apt/chef-integration-test2-1.0/debian/copyright +34 -34
  983. data/spec/data/apt/chef-integration-test2-1.0/debian/files +1 -1
  984. data/spec/data/apt/chef-integration-test2-1.0/debian/rules +13 -13
  985. data/spec/data/apt/chef-integration-test2-1.0/debian/source/format +1 -1
  986. data/spec/data/apt/chef-integration-test2_1.0-1.dsc +18 -18
  987. data/spec/data/apt/chef-integration-test2_1.0-1_amd64.build +91 -91
  988. data/spec/data/apt/chef-integration-test2_1.0-1_amd64.changes +31 -31
  989. data/spec/data/apt/chef-integration-test_1.0-1_amd64.changes +22 -22
  990. data/spec/data/apt/chef-integration-test_1.1-1_amd64.changes +22 -22
  991. data/spec/data/apt/var/www/apt/conf/distributions +7 -7
  992. data/spec/data/apt/var/www/apt/conf/incoming +4 -4
  993. data/spec/data/apt/var/www/apt/conf/pulls +3 -3
  994. data/spec/data/apt/var/www/apt/db/version +4 -4
  995. data/spec/data/apt/var/www/apt/dists/sid/Release +19 -19
  996. data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Packages +16 -16
  997. data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Release +5 -5
  998. data/spec/data/bootstrap/encrypted_data_bag_secret +1 -1
  999. data/spec/data/bootstrap/no_proxy.erb +2 -2
  1000. data/spec/data/bootstrap/secret.erb +9 -9
  1001. data/spec/data/bootstrap/test-hints.erb +12 -12
  1002. data/spec/data/bootstrap/test.erb +1 -1
  1003. data/spec/data/cb_version_cookbooks/tatft/README.rdoc +2 -2
  1004. data/spec/data/cb_version_cookbooks/tatft/attributes/default.rb +1 -1
  1005. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-600hhz-0 +1 -1
  1006. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ahd2gq-0 +1 -1
  1007. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-api8ux-0 +1 -1
  1008. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-b0r1m1-0 +1 -1
  1009. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-bfygsi-0 +1 -1
  1010. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-el14l6-0 +1 -1
  1011. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ivrl3y-0 +1 -1
  1012. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-kkbs85-0 +1 -1
  1013. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ory1ux-0 +1 -1
  1014. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-pgsq76-0 +1 -1
  1015. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ra8uim-0 +1 -1
  1016. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t7k1g-0 +1 -1
  1017. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t8g0sv-0 +1 -1
  1018. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ufy6g3-0 +1 -1
  1019. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-x2d6j9-0 +1 -1
  1020. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-xi0l6h-0 +1 -1
  1021. data/spec/data/client.d_00/00-foo.rb +2 -0
  1022. data/spec/data/client.d_00/01-bar.rb +1 -0
  1023. data/spec/data/client.d_00/bar +1 -0
  1024. data/spec/data/client.d_01/foo/bar.rb +1 -0
  1025. data/spec/data/client.d_02/foo.rb/foo.txt +1 -0
  1026. data/spec/data/config.rb +6 -6
  1027. data/spec/data/cookbooks/angrybash/metadata.rb +2 -2
  1028. data/spec/data/cookbooks/angrybash/recipes/default.rb +8 -8
  1029. data/spec/data/cookbooks/apache2/files/default/apache2_module_conf_generate.pl +2 -2
  1030. data/spec/data/cookbooks/apache2/metadata.rb +2 -2
  1031. data/spec/data/cookbooks/apache2/recipes/default.rb +2 -2
  1032. data/spec/data/cookbooks/borken/metadata.rb +2 -2
  1033. data/spec/data/cookbooks/borken/recipes/default.rb +1 -1
  1034. data/spec/data/cookbooks/borken/templates/default/borken.erb +1 -1
  1035. data/spec/data/cookbooks/chefignore +8 -8
  1036. data/spec/data/cookbooks/ignorken/files/default/not_me.rb +2 -2
  1037. data/spec/data/cookbooks/ignorken/metadata.rb +2 -2
  1038. data/spec/data/cookbooks/ignorken/recipes/ignoreme.rb +1 -1
  1039. data/spec/data/cookbooks/ignorken/templates/ubuntu-12.10/not_me.rb +2 -2
  1040. data/spec/data/cookbooks/java/files/default/java.response +1 -1
  1041. data/spec/data/cookbooks/java/metadata.rb +2 -2
  1042. data/spec/data/cookbooks/name-mismatch-versionnumber/README.md +4 -4
  1043. data/spec/data/cookbooks/name-mismatch-versionnumber/metadata.rb +8 -8
  1044. data/spec/data/cookbooks/name-mismatch-versionnumber/recipes/default.rb +8 -8
  1045. data/spec/data/cookbooks/openldap/.root_dotfile +0 -0
  1046. data/spec/data/cookbooks/openldap/attributes/default.rb +16 -16
  1047. data/spec/data/cookbooks/openldap/attributes/smokey.rb +1 -1
  1048. data/spec/data/cookbooks/openldap/definitions/client.rb +5 -5
  1049. data/spec/data/cookbooks/openldap/definitions/server.rb +5 -5
  1050. data/spec/data/cookbooks/openldap/files/default/.dotfile +1 -1
  1051. data/spec/data/cookbooks/openldap/files/default/remotedir/.a_dotdir/.a_dotfile_in_a_dotdir +1 -1
  1052. data/spec/data/cookbooks/openldap/files/default/remotedir/not_a_template.erb +2 -2
  1053. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file1.txt +2 -2
  1054. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file2.txt +2 -2
  1055. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/.a_dotfile +1 -1
  1056. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file1.txt +2 -2
  1057. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file2.txt +2 -2
  1058. data/spec/data/cookbooks/openldap/files/default/remotedir/subdir_with_no_file_just_a_subsubdir/the_subsubdir/some_file.txt +3 -3
  1059. data/spec/data/cookbooks/openldap/libraries/openldap.rb +4 -4
  1060. data/spec/data/cookbooks/openldap/libraries/openldap/version.rb +3 -3
  1061. data/spec/data/cookbooks/openldap/metadata.rb +8 -8
  1062. data/spec/data/cookbooks/openldap/recipes/default.rb +4 -4
  1063. data/spec/data/cookbooks/openldap/recipes/gigantor.rb +3 -3
  1064. data/spec/data/cookbooks/openldap/recipes/one.rb +15 -15
  1065. data/spec/data/cookbooks/openldap/recipes/return.rb +2 -2
  1066. data/spec/data/cookbooks/openldap/spec/spec_helper.rb +0 -0
  1067. data/spec/data/cookbooks/openldap/templates/default/helper_test.erb +1 -1
  1068. data/spec/data/cookbooks/openldap/templates/default/helpers.erb +14 -14
  1069. data/spec/data/cookbooks/openldap/templates/default/helpers_via_partial_test.erb +1 -1
  1070. data/spec/data/cookbooks/openldap/templates/default/nested_openldap_partials.erb +1 -1
  1071. data/spec/data/cookbooks/openldap/templates/default/nested_partial.erb +1 -1
  1072. data/spec/data/cookbooks/openldap/templates/default/no_windows_line_endings.erb +4 -4
  1073. data/spec/data/cookbooks/openldap/templates/default/openldap_variable_stuff.conf.erb +1 -1
  1074. data/spec/data/cookbooks/openldap/templates/default/test.erb +1 -1
  1075. data/spec/data/cookbooks/preseed/files/default/preseed-file.seed +1 -1
  1076. data/spec/data/cookbooks/preseed/files/default/preseed-template.seed +4 -4
  1077. data/spec/data/cookbooks/preseed/metadata.rb +2 -2
  1078. data/spec/data/cookbooks/preseed/templates/default/preseed-template-variables.seed +1 -1
  1079. data/spec/data/cookbooks/preseed/templates/default/preseed-template.seed +1 -1
  1080. data/spec/data/cookbooks/supports-platform-constraints/metadata.rb +5 -5
  1081. data/spec/data/definitions/test.rb +4 -4
  1082. data/spec/data/environment-config.rb +4 -4
  1083. data/spec/data/file-providers-method-snapshot-chef-11-4.json +127 -127
  1084. data/spec/data/fileedit/hosts +4 -4
  1085. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/README.md +4 -4
  1086. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/metadata.rb +13 -13
  1087. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/recipes/default.rb +8 -8
  1088. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/README.md +4 -4
  1089. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/metadata.rb +9 -9
  1090. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/recipes/default.rb +8 -8
  1091. data/spec/data/kitchen/chefignore +6 -6
  1092. data/spec/data/kitchen/openldap/attributes/default.rb +3 -3
  1093. data/spec/data/kitchen/openldap/attributes/robinson.rb +2 -2
  1094. data/spec/data/kitchen/openldap/definitions/client.rb +3 -3
  1095. data/spec/data/kitchen/openldap/definitions/drewbarrymore.rb +2 -2
  1096. data/spec/data/kitchen/openldap/recipes/gigantor.rb +2 -2
  1097. data/spec/data/kitchen/openldap/recipes/ignoreme.rb +2 -2
  1098. data/spec/data/kitchen/openldap/recipes/woot.rb +3 -3
  1099. data/spec/data/knife_subcommand/test_explicit_category.rb +6 -6
  1100. data/spec/data/knife_subcommand/test_name_mapping.rb +4 -4
  1101. data/spec/data/knife_subcommand/test_yourself.rb +21 -21
  1102. data/spec/data/lwrp/providers/buck_passer.rb +28 -28
  1103. data/spec/data/lwrp/providers/buck_passer_2.rb +26 -26
  1104. data/spec/data/lwrp/providers/embedded_resource_accesses_providers_scope.rb +28 -28
  1105. data/spec/data/lwrp/providers/inline_compiler.rb +26 -26
  1106. data/spec/data/lwrp/providers/monkey_name_printer.rb +5 -5
  1107. data/spec/data/lwrp/providers/paint_drying_watcher.rb +7 -7
  1108. data/spec/data/lwrp/providers/thumb_twiddler.rb +7 -7
  1109. data/spec/data/lwrp/resources/bar.rb +2 -2
  1110. data/spec/data/lwrp/resources/foo.rb +4 -4
  1111. data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +1 -1
  1112. data/spec/data/lwrp_override/providers/buck_passer.rb +5 -5
  1113. data/spec/data/lwrp_override/resources/foo.rb +10 -10
  1114. data/spec/data/mac_users/10.7-8.plist.xml +559 -559
  1115. data/spec/data/mac_users/10.7-8.shadow.xml +11 -11
  1116. data/spec/data/mac_users/10.7.plist.xml +559 -559
  1117. data/spec/data/mac_users/10.7.shadow.xml +11 -11
  1118. data/spec/data/mac_users/10.8.plist.xml +559 -559
  1119. data/spec/data/mac_users/10.8.shadow.xml +21 -21
  1120. data/spec/data/mac_users/10.9.plist.xml +560 -560
  1121. data/spec/data/mac_users/10.9.shadow.xml +21 -21
  1122. data/spec/data/metadata/quick_start/metadata.rb +19 -19
  1123. data/spec/data/nested.json +2 -2
  1124. data/spec/data/nodes/default.rb +15 -15
  1125. data/spec/data/nodes/test.example.com.rb +17 -17
  1126. data/spec/data/nodes/test.rb +15 -15
  1127. data/spec/data/null_config.rb +1 -1
  1128. data/spec/data/object_loader/environments/test.json +7 -7
  1129. data/spec/data/object_loader/environments/test.rb +2 -2
  1130. data/spec/data/object_loader/environments/test_json_class.json +8 -8
  1131. data/spec/data/object_loader/nodes/test.json +7 -7
  1132. data/spec/data/object_loader/nodes/test.rb +2 -2
  1133. data/spec/data/object_loader/nodes/test_json_class.json +8 -8
  1134. data/spec/data/object_loader/roles/test.json +7 -7
  1135. data/spec/data/object_loader/roles/test.rb +2 -2
  1136. data/spec/data/object_loader/roles/test_json_class.json +8 -8
  1137. data/spec/data/partial_one.erb +1 -1
  1138. data/spec/data/recipes/test.rb +7 -7
  1139. data/spec/data/run_context/cookbooks/circular-dep1/attributes/default.rb +4 -4
  1140. data/spec/data/run_context/cookbooks/circular-dep1/definitions/circular_dep1_res.rb +1 -1
  1141. data/spec/data/run_context/cookbooks/circular-dep1/libraries/lib.rb +2 -2
  1142. data/spec/data/run_context/cookbooks/circular-dep1/metadata.rb +2 -2
  1143. data/spec/data/run_context/cookbooks/circular-dep1/providers/provider.rb +1 -1
  1144. data/spec/data/run_context/cookbooks/circular-dep1/resources/resource.rb +1 -1
  1145. data/spec/data/run_context/cookbooks/circular-dep2/attributes/default.rb +3 -3
  1146. data/spec/data/run_context/cookbooks/circular-dep2/definitions/circular_dep2_res.rb +1 -1
  1147. data/spec/data/run_context/cookbooks/circular-dep2/libraries/lib.rb +2 -2
  1148. data/spec/data/run_context/cookbooks/circular-dep2/metadata.rb +2 -2
  1149. data/spec/data/run_context/cookbooks/circular-dep2/providers/provider.rb +1 -1
  1150. data/spec/data/run_context/cookbooks/circular-dep2/resources/resource.rb +1 -1
  1151. data/spec/data/run_context/cookbooks/dependency1/attributes/aa_first.rb +2 -2
  1152. data/spec/data/run_context/cookbooks/dependency1/attributes/default.rb +2 -2
  1153. data/spec/data/run_context/cookbooks/dependency1/attributes/zz_last.rb +3 -3
  1154. data/spec/data/run_context/cookbooks/dependency1/definitions/dependency1_res.rb +1 -1
  1155. data/spec/data/run_context/cookbooks/dependency1/libraries/lib.rb +2 -2
  1156. data/spec/data/run_context/cookbooks/dependency1/providers/provider.rb +1 -1
  1157. data/spec/data/run_context/cookbooks/dependency1/resources/resource.rb +1 -1
  1158. data/spec/data/run_context/cookbooks/dependency2/attributes/default.rb +3 -3
  1159. data/spec/data/run_context/cookbooks/dependency2/definitions/dependency2_res.rb +1 -1
  1160. data/spec/data/run_context/cookbooks/dependency2/libraries/lib.rb +2 -2
  1161. data/spec/data/run_context/cookbooks/dependency2/providers/provider.rb +1 -1
  1162. data/spec/data/run_context/cookbooks/dependency2/resources/resource.rb +1 -1
  1163. data/spec/data/run_context/cookbooks/include/recipes/default.rb +24 -24
  1164. data/spec/data/run_context/cookbooks/include/recipes/includee.rb +3 -3
  1165. data/spec/data/run_context/cookbooks/no-default-attr/attributes/server.rb +3 -3
  1166. data/spec/data/run_context/cookbooks/no-default-attr/definitions/no_default-attr_res.rb +1 -1
  1167. data/spec/data/run_context/cookbooks/no-default-attr/providers/provider.rb +1 -1
  1168. data/spec/data/run_context/cookbooks/no-default-attr/resources/resource.rb +1 -1
  1169. data/spec/data/run_context/cookbooks/test-with-circular-deps/attributes/default.rb +3 -3
  1170. data/spec/data/run_context/cookbooks/test-with-circular-deps/definitions/test_with-circular-deps_res.rb +1 -1
  1171. data/spec/data/run_context/cookbooks/test-with-circular-deps/libraries/lib.rb +2 -2
  1172. data/spec/data/run_context/cookbooks/test-with-circular-deps/metadata.rb +2 -2
  1173. data/spec/data/run_context/cookbooks/test-with-circular-deps/providers/provider.rb +1 -1
  1174. data/spec/data/run_context/cookbooks/test-with-circular-deps/resources/resource.rb +1 -1
  1175. data/spec/data/run_context/cookbooks/test-with-deps/attributes/default.rb +3 -3
  1176. data/spec/data/run_context/cookbooks/test-with-deps/definitions/test_with-deps_res.rb +1 -1
  1177. data/spec/data/run_context/cookbooks/test-with-deps/libraries/lib.rb +1 -1
  1178. data/spec/data/run_context/cookbooks/test-with-deps/metadata.rb +3 -3
  1179. data/spec/data/run_context/cookbooks/test-with-deps/providers/provider.rb +1 -1
  1180. data/spec/data/run_context/cookbooks/test-with-deps/resources/resource.rb +1 -1
  1181. data/spec/data/run_context/cookbooks/test/attributes/george.rb +1 -1
  1182. data/spec/data/run_context/cookbooks/test/definitions/new_animals.rb +9 -9
  1183. data/spec/data/run_context/cookbooks/test/definitions/new_cat.rb +5 -5
  1184. data/spec/data/run_context/cookbooks/test/definitions/test_res.rb +1 -1
  1185. data/spec/data/run_context/cookbooks/test/providers/provider.rb +1 -1
  1186. data/spec/data/run_context/cookbooks/test/recipes/default.rb +5 -5
  1187. data/spec/data/run_context/cookbooks/test/recipes/one.rb +7 -7
  1188. data/spec/data/run_context/cookbooks/test/recipes/two.rb +7 -7
  1189. data/spec/data/run_context/cookbooks/test/resources/resource.rb +1 -1
  1190. data/spec/data/run_context/nodes/run_context.rb +5 -5
  1191. data/spec/data/search_queries_to_transform.txt +98 -98
  1192. data/spec/data/shef-config.rb +10 -10
  1193. data/spec/data/ssl/5e707473.0 +18 -18
  1194. data/spec/data/ssl/chef-rspec.cert +27 -27
  1195. data/spec/data/ssl/chef-rspec.key +27 -27
  1196. data/spec/data/ssl/key.pem +15 -15
  1197. data/spec/data/ssl/private_key.pem +27 -27
  1198. data/spec/data/ssl/private_key_with_whitespace.pem +32 -32
  1199. data/spec/data/standalone_cookbook/chefignore +9 -9
  1200. data/spec/data/standalone_cookbook/recipes/default.rb +2 -2
  1201. data/spec/data/trusted_certs/example.crt +22 -22
  1202. data/spec/data/trusted_certs/intermediate.pem +27 -27
  1203. data/spec/data/trusted_certs/opscode.pem +57 -57
  1204. data/spec/data/trusted_certs/root.pem +22 -22
  1205. data/spec/functional/application_spec.rb +58 -58
  1206. data/spec/functional/assets/chefinittest +34 -34
  1207. data/spec/functional/assets/testchefsubsys +10 -10
  1208. data/spec/functional/audit/rspec_formatter_spec.rb +54 -54
  1209. data/spec/functional/audit/runner_spec.rb +121 -121
  1210. data/spec/functional/dsl/reboot_pending_spec.rb +106 -106
  1211. data/spec/functional/dsl/registry_helper_spec.rb +61 -61
  1212. data/spec/functional/event_loggers/windows_eventlog_spec.rb +101 -101
  1213. data/spec/functional/file_content_management/deploy_strategies_spec.rb +229 -229
  1214. data/spec/functional/http/simple_spec.rb +140 -140
  1215. data/spec/functional/knife/configure_spec.rb +33 -33
  1216. data/spec/functional/knife/cookbook_delete_spec.rb +167 -167
  1217. data/spec/functional/knife/exec_spec.rb +55 -55
  1218. data/spec/functional/knife/rehash_spec.rb +39 -0
  1219. data/spec/functional/knife/smoke_test.rb +42 -42
  1220. data/spec/functional/knife/ssh_spec.rb +284 -284
  1221. data/spec/functional/mixin/powershell_out_spec.rb +43 -43
  1222. data/spec/functional/mixin/shell_out_spec.rb +48 -48
  1223. data/spec/functional/notifications_spec.rb +238 -238
  1224. data/spec/functional/provider/remote_file/cache_control_data_spec.rb +100 -100
  1225. data/spec/functional/provider/whyrun_safe_ruby_block_spec.rb +51 -51
  1226. data/spec/functional/rebooter_spec.rb +105 -105
  1227. data/spec/functional/resource/aix_service_spec.rb +138 -138
  1228. data/spec/functional/resource/aixinit_service_spec.rb +211 -211
  1229. data/spec/functional/resource/base.rb +28 -28
  1230. data/spec/functional/resource/bash_spec.rb +88 -88
  1231. data/spec/functional/resource/batch_spec.rb +30 -30
  1232. data/spec/functional/resource/bff_spec.rb +120 -120
  1233. data/spec/functional/resource/chocolatey_package_spec.rb +130 -124
  1234. data/spec/functional/resource/cookbook_file_spec.rb +81 -81
  1235. data/spec/functional/resource/cron_spec.rb +172 -172
  1236. data/spec/functional/resource/deploy_revision_spec.rb +881 -881
  1237. data/spec/functional/resource/directory_spec.rb +43 -43
  1238. data/spec/functional/resource/dpkg_package_spec.rb +339 -339
  1239. data/spec/functional/resource/dsc_resource_spec.rb +90 -90
  1240. data/spec/functional/resource/dsc_script_spec.rb +479 -469
  1241. data/spec/functional/resource/env_spec.rb +192 -192
  1242. data/spec/functional/resource/execute_spec.rb +154 -154
  1243. data/spec/functional/resource/file_spec.rb +167 -167
  1244. data/spec/functional/resource/git_spec.rb +259 -259
  1245. data/spec/functional/resource/group_spec.rb +461 -461
  1246. data/spec/functional/resource/ifconfig_spec.rb +165 -165
  1247. data/spec/functional/resource/link_spec.rb +613 -613
  1248. data/spec/functional/resource/mount_spec.rb +203 -203
  1249. data/spec/functional/resource/ohai_spec.rb +62 -62
  1250. data/spec/functional/resource/package_spec.rb +386 -386
  1251. data/spec/functional/resource/powershell_script_spec.rb +601 -601
  1252. data/spec/functional/resource/reboot_spec.rb +103 -103
  1253. data/spec/functional/resource/registry_spec.rb +560 -560
  1254. data/spec/functional/resource/remote_directory_spec.rb +220 -220
  1255. data/spec/functional/resource/remote_file_spec.rb +240 -240
  1256. data/spec/functional/resource/rpm_spec.rb +123 -123
  1257. data/spec/functional/resource/template_spec.rb +212 -212
  1258. data/spec/functional/resource/user/dscl_spec.rb +198 -198
  1259. data/spec/functional/resource/user/useradd_spec.rb +692 -699
  1260. data/spec/functional/resource/user/windows_spec.rb +133 -133
  1261. data/spec/functional/resource/windows_package_spec.rb +168 -168
  1262. data/spec/functional/resource/windows_service_spec.rb +102 -102
  1263. data/spec/functional/rest_spec.rb +95 -95
  1264. data/spec/functional/run_lock_spec.rb +466 -466
  1265. data/spec/functional/shell_spec.rb +148 -148
  1266. data/spec/functional/tiny_server_spec.rb +78 -78
  1267. data/spec/functional/util/path_helper_spec.rb +37 -37
  1268. data/spec/functional/util/powershell/cmdlet_spec.rb +111 -111
  1269. data/spec/functional/version_spec.rb +35 -35
  1270. data/spec/functional/win32/crypto_spec.rb +54 -54
  1271. data/spec/functional/win32/registry_spec.rb +623 -623
  1272. data/spec/functional/win32/security_spec.rb +100 -100
  1273. data/spec/functional/win32/service_manager_spec.rb +220 -220
  1274. data/spec/functional/win32/sid_spec.rb +55 -55
  1275. data/spec/functional/win32/version_info_spec.rb +50 -50
  1276. data/spec/functional/win32/versions_spec.rb +117 -117
  1277. data/spec/integration/client/client_spec.rb +500 -500
  1278. data/spec/integration/client/ipv6_spec.rb +134 -134
  1279. data/spec/integration/knife/chef_fs_data_store_spec.rb +556 -556
  1280. data/spec/integration/knife/chef_repo_path_spec.rb +890 -890
  1281. data/spec/integration/knife/chef_repository_file_system_spec.rb +292 -292
  1282. data/spec/integration/knife/chefignore_spec.rb +300 -300
  1283. data/spec/integration/knife/common_options_spec.rb +155 -155
  1284. data/spec/integration/knife/cookbook_api_ipv6_spec.rb +112 -112
  1285. data/spec/integration/knife/delete_spec.rb +1017 -1017
  1286. data/spec/integration/knife/deps_spec.rb +706 -706
  1287. data/spec/integration/knife/diff_spec.rb +602 -602
  1288. data/spec/integration/knife/download_spec.rb +1314 -1314
  1289. data/spec/integration/knife/list_spec.rb +1067 -1067
  1290. data/spec/integration/knife/raw_spec.rb +242 -242
  1291. data/spec/integration/knife/redirection_spec.rb +52 -52
  1292. data/spec/integration/knife/serve_spec.rb +57 -57
  1293. data/spec/integration/knife/show_spec.rb +167 -167
  1294. data/spec/integration/knife/upload_spec.rb +1529 -1529
  1295. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +148 -148
  1296. data/spec/integration/recipes/lwrp_spec.rb +53 -53
  1297. data/spec/integration/recipes/provider_choice.rb +37 -37
  1298. data/spec/integration/recipes/recipe_dsl_spec.rb +1519 -1519
  1299. data/spec/integration/recipes/remote_directory.rb +74 -74
  1300. data/spec/integration/recipes/resource_action_spec.rb +569 -569
  1301. data/spec/integration/recipes/resource_converge_if_changed_spec.rb +496 -496
  1302. data/spec/integration/recipes/resource_load_spec.rb +208 -208
  1303. data/spec/integration/solo/solo_spec.rb +176 -176
  1304. data/spec/rcov.opts +2 -2
  1305. data/spec/scripts/ssl-serve.rb +47 -47
  1306. data/spec/spec_helper.rb +248 -249
  1307. data/spec/stress/win32/file_spec.rb +37 -37
  1308. data/spec/stress/win32/memory_spec.rb +22 -22
  1309. data/spec/stress/win32/security_spec.rb +69 -69
  1310. data/spec/support/chef_helpers.rb +95 -95
  1311. data/spec/support/key_helpers.rb +104 -104
  1312. data/spec/support/lib/chef/provider/easy.rb +35 -35
  1313. data/spec/support/lib/chef/provider/openldap_includer.rb +29 -29
  1314. data/spec/support/lib/chef/provider/snakeoil.rb +41 -41
  1315. data/spec/support/lib/chef/resource/cat.rb +38 -38
  1316. data/spec/support/lib/chef/resource/one_two_three_four.rb +37 -37
  1317. data/spec/support/lib/chef/resource/openldap_includer.rb +26 -26
  1318. data/spec/support/lib/chef/resource/with_state.rb +28 -28
  1319. data/spec/support/lib/chef/resource/zen_follower.rb +35 -35
  1320. data/spec/support/lib/chef/resource/zen_master.rb +41 -41
  1321. data/spec/support/lib/library_load_order.rb +20 -20
  1322. data/spec/support/matchers/leak.rb +98 -98
  1323. data/spec/support/mock/constant.rb +52 -52
  1324. data/spec/support/mock/platform.rb +25 -25
  1325. data/spec/support/platform_helpers.rb +214 -218
  1326. data/spec/support/platforms/prof/gc.rb +53 -53
  1327. data/spec/support/platforms/prof/win32.rb +45 -45
  1328. data/spec/support/platforms/win32/spec_service.rb +59 -59
  1329. data/spec/support/shared/context/client.rb +285 -285
  1330. data/spec/support/shared/context/config.rb +21 -21
  1331. data/spec/support/shared/context/win32.rb +34 -34
  1332. data/spec/support/shared/examples/client.rb +53 -53
  1333. data/spec/support/shared/functional/diff_disabled.rb +10 -10
  1334. data/spec/support/shared/functional/directory_resource.rb +176 -176
  1335. data/spec/support/shared/functional/file_resource.rb +1049 -1049
  1336. data/spec/support/shared/functional/http.rb +248 -248
  1337. data/spec/support/shared/functional/knife.rb +37 -37
  1338. data/spec/support/shared/functional/securable_resource.rb +547 -547
  1339. data/spec/support/shared/functional/securable_resource_with_reporting.rb +394 -394
  1340. data/spec/support/shared/functional/win32_service.rb +59 -59
  1341. data/spec/support/shared/functional/windows_script.rb +202 -202
  1342. data/spec/support/shared/integration/app_server_support.rb +42 -42
  1343. data/spec/support/shared/integration/integration_helper.rb +154 -154
  1344. data/spec/support/shared/integration/knife_support.rb +173 -173
  1345. data/spec/support/shared/matchers/exit_with_code.rb +32 -32
  1346. data/spec/support/shared/matchers/match_environment_variable.rb +17 -17
  1347. data/spec/support/shared/shared_examples.rb +14 -14
  1348. data/spec/support/shared/unit/api_error_inspector.rb +190 -190
  1349. data/spec/support/shared/unit/api_versioning.rb +77 -77
  1350. data/spec/support/shared/unit/application_dot_d.rb +70 -0
  1351. data/spec/support/shared/unit/execute_resource.rb +133 -133
  1352. data/spec/support/shared/unit/file_system_support.rb +69 -69
  1353. data/spec/support/shared/unit/knife_shared.rb +39 -39
  1354. data/spec/support/shared/unit/mock_shellout.rb +49 -49
  1355. data/spec/support/shared/unit/platform_introspector.rb +189 -189
  1356. data/spec/support/shared/unit/provider/file.rb +835 -835
  1357. data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +433 -433
  1358. data/spec/support/shared/unit/resource/static_provider_resolution.rb +63 -63
  1359. data/spec/support/shared/unit/script_resource.rb +98 -98
  1360. data/spec/support/shared/unit/user_and_client_shared.rb +114 -114
  1361. data/spec/support/shared/unit/windows_script_resource.rb +80 -80
  1362. data/spec/tiny_server.rb +207 -207
  1363. data/spec/unit/api_client/registration_spec.rb +278 -278
  1364. data/spec/unit/api_client_spec.rb +341 -341
  1365. data/spec/unit/api_client_v1_spec.rb +455 -455
  1366. data/spec/unit/application/apply_spec.rb +110 -110
  1367. data/spec/unit/application/client_spec.rb +435 -431
  1368. data/spec/unit/application/knife_spec.rb +229 -229
  1369. data/spec/unit/application/solo_spec.rb +170 -167
  1370. data/spec/unit/application_spec.rb +384 -384
  1371. data/spec/unit/audit/audit_event_proxy_spec.rb +311 -311
  1372. data/spec/unit/audit/audit_reporter_spec.rb +430 -430
  1373. data/spec/unit/audit/control_group_data_spec.rb +477 -477
  1374. data/spec/unit/audit/logger_spec.rb +42 -42
  1375. data/spec/unit/audit/rspec_formatter_spec.rb +29 -29
  1376. data/spec/unit/audit/runner_spec.rb +144 -144
  1377. data/spec/unit/chef_class_spec.rb +110 -110
  1378. data/spec/unit/chef_fs/config_spec.rb +106 -106
  1379. data/spec/unit/chef_fs/data_handler/group_handler_spec.rb +63 -63
  1380. data/spec/unit/chef_fs/diff_spec.rb +328 -328
  1381. data/spec/unit/chef_fs/file_pattern_spec.rb +512 -512
  1382. data/spec/unit/chef_fs/file_system/cookbook_subdir_spec.rb +34 -34
  1383. data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +47 -47
  1384. data/spec/unit/chef_fs/file_system_spec.rb +148 -148
  1385. data/spec/unit/chef_fs/parallelizer.rb +479 -479
  1386. data/spec/unit/chef_fs/path_util_spec.rb +108 -108
  1387. data/spec/unit/chef_spec.rb +25 -25
  1388. data/spec/unit/client_spec.rb +544 -544
  1389. data/spec/unit/config_fetcher_spec.rb +125 -125
  1390. data/spec/unit/config_spec.rb +31 -31
  1391. data/spec/unit/cookbook/chefignore_spec.rb +49 -49
  1392. data/spec/unit/cookbook/cookbook_version_loader_spec.rb +198 -186
  1393. data/spec/unit/cookbook/file_vendor_spec.rb +97 -97
  1394. data/spec/unit/cookbook/metadata_spec.rb +952 -924
  1395. data/spec/unit/cookbook/synchronizer_spec.rb +520 -520
  1396. data/spec/unit/cookbook/syntax_check_spec.rb +219 -217
  1397. data/spec/unit/cookbook_loader_spec.rb +299 -290
  1398. data/spec/unit/cookbook_manifest_spec.rb +243 -243
  1399. data/spec/unit/cookbook_site_streaming_uploader_spec.rb +203 -199
  1400. data/spec/unit/cookbook_spec.rb +66 -66
  1401. data/spec/unit/cookbook_uploader_spec.rb +199 -199
  1402. data/spec/unit/cookbook_version_file_specificity_spec.rb +553 -553
  1403. data/spec/unit/cookbook_version_spec.rb +359 -341
  1404. data/spec/unit/daemon_spec.rb +174 -174
  1405. data/spec/unit/data_bag_item_spec.rb +388 -323
  1406. data/spec/unit/data_bag_spec.rb +260 -260
  1407. data/spec/unit/deprecation_spec.rb +150 -150
  1408. data/spec/unit/digester_spec.rb +49 -49
  1409. data/spec/unit/dsl/audit_spec.rb +43 -43
  1410. data/spec/unit/dsl/data_query_spec.rb +106 -106
  1411. data/spec/unit/dsl/platform_introspection_spec.rb +129 -129
  1412. data/spec/unit/dsl/reboot_pending_spec.rb +100 -100
  1413. data/spec/unit/dsl/recipe_spec.rb +80 -80
  1414. data/spec/unit/dsl/regsitry_helper_spec.rb +52 -52
  1415. data/spec/unit/dsl/resources_spec.rb +85 -85
  1416. data/spec/unit/encrypted_data_bag_item/check_encrypted_spec.rb +95 -95
  1417. data/spec/unit/encrypted_data_bag_item_spec.rb +437 -437
  1418. data/spec/unit/environment_spec.rb +470 -470
  1419. data/spec/unit/event_dispatch/dispatcher_spec.rb +122 -122
  1420. data/spec/unit/event_dispatch/dsl_spec.rb +83 -83
  1421. data/spec/unit/exceptions_spec.rb +130 -130
  1422. data/spec/unit/file_access_control_spec.rb +308 -308
  1423. data/spec/unit/file_cache_spec.rb +114 -114
  1424. data/spec/unit/file_content_management/deploy/cp_spec.rb +44 -44
  1425. data/spec/unit/file_content_management/deploy/mv_unix_spec.rb +101 -101
  1426. data/spec/unit/file_content_management/deploy/mv_windows_spec.rb +232 -232
  1427. data/spec/unit/file_content_management/tempfile_spec.rb +85 -0
  1428. data/spec/unit/formatters/base_spec.rb +71 -71
  1429. data/spec/unit/formatters/doc_spec.rb +78 -78
  1430. data/spec/unit/formatters/error_inspectors/api_error_formatting_spec.rb +76 -76
  1431. data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +265 -265
  1432. data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +126 -126
  1433. data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +43 -43
  1434. data/spec/unit/formatters/error_inspectors/node_load_error_inspector_spec.rb +26 -26
  1435. data/spec/unit/formatters/error_inspectors/registration_error_inspector_spec.rb +26 -26
  1436. data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +191 -191
  1437. data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +91 -91
  1438. data/spec/unit/guard_interpreter/resource_guard_interpreter_spec.rb +155 -155
  1439. data/spec/unit/guard_interpreter_spec.rb +41 -41
  1440. data/spec/unit/handler/json_file_spec.rb +63 -63
  1441. data/spec/unit/handler_spec.rb +215 -215
  1442. data/spec/unit/http/authenticator_spec.rb +80 -80
  1443. data/spec/unit/http/basic_client_spec.rb +129 -129
  1444. data/spec/unit/http/http_request_spec.rb +91 -91
  1445. data/spec/unit/http/json_input_spec.rb +128 -128
  1446. data/spec/unit/http/simple_spec.rb +32 -32
  1447. data/spec/unit/http/socketless_chef_zero_client_spec.rb +173 -173
  1448. data/spec/unit/http/ssl_policies_spec.rb +169 -169
  1449. data/spec/unit/http/validate_content_length_spec.rb +207 -192
  1450. data/spec/unit/http_spec.rb +206 -194
  1451. data/spec/unit/json_compat_spec.rb +105 -105
  1452. data/spec/unit/key_spec.rb +631 -631
  1453. data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +152 -152
  1454. data/spec/unit/knife/bootstrap/client_builder_spec.rb +207 -207
  1455. data/spec/unit/knife/bootstrap_spec.rb +822 -773
  1456. data/spec/unit/knife/client_bulk_delete_spec.rb +166 -166
  1457. data/spec/unit/knife/client_create_spec.rb +186 -186
  1458. data/spec/unit/knife/client_delete_spec.rb +83 -83
  1459. data/spec/unit/knife/client_edit_spec.rb +53 -53
  1460. data/spec/unit/knife/client_list_spec.rb +34 -34
  1461. data/spec/unit/knife/client_reregister_spec.rb +62 -62
  1462. data/spec/unit/knife/client_show_spec.rb +52 -52
  1463. data/spec/unit/knife/configure_client_spec.rb +83 -83
  1464. data/spec/unit/knife/configure_spec.rb +241 -241
  1465. data/spec/unit/knife/cookbook_bulk_delete_spec.rb +87 -87
  1466. data/spec/unit/knife/cookbook_create_spec.rb +260 -260
  1467. data/spec/unit/knife/cookbook_delete_spec.rb +239 -239
  1468. data/spec/unit/knife/cookbook_download_spec.rb +237 -237
  1469. data/spec/unit/knife/cookbook_list_spec.rb +88 -88
  1470. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +65 -65
  1471. data/spec/unit/knife/cookbook_metadata_spec.rb +179 -179
  1472. data/spec/unit/knife/cookbook_show_spec.rb +222 -222
  1473. data/spec/unit/knife/cookbook_site_download_spec.rb +149 -149
  1474. data/spec/unit/knife/cookbook_site_install_spec.rb +197 -197
  1475. data/spec/unit/knife/cookbook_site_share_spec.rb +209 -209
  1476. data/spec/unit/knife/cookbook_site_unshare_spec.rb +77 -77
  1477. data/spec/unit/knife/cookbook_test_spec.rb +84 -84
  1478. data/spec/unit/knife/cookbook_upload_spec.rb +331 -329
  1479. data/spec/unit/knife/core/bootstrap_context_spec.rb +257 -257
  1480. data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +187 -187
  1481. data/spec/unit/knife/core/custom_manifest_loader_spec.rb +41 -41
  1482. data/spec/unit/knife/core/gem_glob_loader_spec.rb +209 -209
  1483. data/spec/unit/knife/core/hashed_command_loader_spec.rb +109 -93
  1484. data/spec/unit/knife/core/node_editor_spec.rb +211 -211
  1485. data/spec/unit/knife/core/object_loader_spec.rb +81 -81
  1486. data/spec/unit/knife/core/subcommand_loader_spec.rb +70 -64
  1487. data/spec/unit/knife/core/ui_spec.rb +598 -591
  1488. data/spec/unit/knife/data_bag_create_spec.rb +109 -109
  1489. data/spec/unit/knife/data_bag_edit_spec.rb +127 -127
  1490. data/spec/unit/knife/data_bag_from_file_spec.rb +172 -172
  1491. data/spec/unit/knife/data_bag_secret_options_spec.rb +165 -165
  1492. data/spec/unit/knife/data_bag_show_spec.rb +123 -123
  1493. data/spec/unit/knife/environment_compare_spec.rb +112 -112
  1494. data/spec/unit/knife/environment_create_spec.rb +91 -91
  1495. data/spec/unit/knife/environment_delete_spec.rb +71 -71
  1496. data/spec/unit/knife/environment_edit_spec.rb +79 -79
  1497. data/spec/unit/knife/environment_from_file_spec.rb +90 -90
  1498. data/spec/unit/knife/environment_list_spec.rb +54 -54
  1499. data/spec/unit/knife/environment_show_spec.rb +52 -52
  1500. data/spec/unit/knife/index_rebuild_spec.rb +125 -125
  1501. data/spec/unit/knife/key_create_spec.rb +223 -223
  1502. data/spec/unit/knife/key_delete_spec.rb +133 -133
  1503. data/spec/unit/knife/key_edit_spec.rb +264 -264
  1504. data/spec/unit/knife/key_helper.rb +74 -74
  1505. data/spec/unit/knife/key_list_spec.rb +216 -216
  1506. data/spec/unit/knife/key_show_spec.rb +126 -126
  1507. data/spec/unit/knife/knife_help.rb +92 -92
  1508. data/spec/unit/knife/node_bulk_delete_spec.rb +94 -94
  1509. data/spec/unit/knife/node_delete_spec.rb +68 -68
  1510. data/spec/unit/knife/node_edit_spec.rb +114 -114
  1511. data/spec/unit/knife/node_environment_set_spec.rb +80 -80
  1512. data/spec/unit/knife/node_from_file_spec.rb +59 -59
  1513. data/spec/unit/knife/node_list_spec.rb +62 -62
  1514. data/spec/unit/knife/node_run_list_add_spec.rb +145 -145
  1515. data/spec/unit/knife/node_run_list_remove_spec.rb +106 -106
  1516. data/spec/unit/knife/node_run_list_set_spec.rb +140 -140
  1517. data/spec/unit/knife/node_show_spec.rb +65 -65
  1518. data/spec/unit/knife/osc_user_create_spec.rb +93 -93
  1519. data/spec/unit/knife/osc_user_delete_spec.rb +44 -44
  1520. data/spec/unit/knife/osc_user_edit_spec.rb +52 -52
  1521. data/spec/unit/knife/osc_user_list_spec.rb +37 -37
  1522. data/spec/unit/knife/osc_user_reregister_spec.rb +58 -58
  1523. data/spec/unit/knife/osc_user_show_spec.rb +46 -46
  1524. data/spec/unit/knife/raw_spec.rb +43 -43
  1525. data/spec/unit/knife/role_bulk_delete_spec.rb +80 -80
  1526. data/spec/unit/knife/role_create_spec.rb +80 -80
  1527. data/spec/unit/knife/role_delete_spec.rb +67 -67
  1528. data/spec/unit/knife/role_edit_spec.rb +77 -77
  1529. data/spec/unit/knife/role_env_run_list_add_spec.rb +217 -217
  1530. data/spec/unit/knife/role_env_run_list_clear_spec.rb +94 -94
  1531. data/spec/unit/knife/role_env_run_list_remove_spec.rb +102 -102
  1532. data/spec/unit/knife/role_env_run_list_replace_spec.rb +105 -105
  1533. data/spec/unit/knife/role_env_run_list_set_spec.rb +99 -99
  1534. data/spec/unit/knife/role_from_file_spec.rb +69 -69
  1535. data/spec/unit/knife/role_list_spec.rb +54 -54
  1536. data/spec/unit/knife/role_run_list_add_spec.rb +179 -179
  1537. data/spec/unit/knife/role_run_list_clear_spec.rb +84 -84
  1538. data/spec/unit/knife/role_run_list_remove_spec.rb +92 -92
  1539. data/spec/unit/knife/role_run_list_replace_spec.rb +98 -98
  1540. data/spec/unit/knife/role_run_list_set_spec.rb +89 -89
  1541. data/spec/unit/knife/role_show_spec.rb +59 -59
  1542. data/spec/unit/knife/ssh_spec.rb +410 -410
  1543. data/spec/unit/knife/ssl_check_spec.rb +240 -240
  1544. data/spec/unit/knife/ssl_fetch_spec.rb +184 -184
  1545. data/spec/unit/knife/status_spec.rb +108 -108
  1546. data/spec/unit/knife/tag_create_spec.rb +23 -23
  1547. data/spec/unit/knife/tag_delete_spec.rb +25 -25
  1548. data/spec/unit/knife/tag_list_spec.rb +23 -23
  1549. data/spec/unit/knife/user_create_spec.rb +214 -214
  1550. data/spec/unit/knife/user_delete_spec.rb +65 -65
  1551. data/spec/unit/knife/user_edit_spec.rb +66 -66
  1552. data/spec/unit/knife/user_list_spec.rb +36 -36
  1553. data/spec/unit/knife/user_reregister_spec.rb +74 -74
  1554. data/spec/unit/knife/user_show_spec.rb +65 -65
  1555. data/spec/unit/knife_spec.rb +529 -522
  1556. data/spec/unit/lib_backcompat_spec.rb +34 -34
  1557. data/spec/unit/log/syslog_spec.rb +53 -53
  1558. data/spec/unit/log/winevt_spec.rb +55 -55
  1559. data/spec/unit/log_spec.rb +24 -24
  1560. data/spec/unit/lwrp_spec.rb +720 -720
  1561. data/spec/unit/mash_spec.rb +51 -51
  1562. data/spec/unit/mixin/api_version_request_handling_spec.rb +126 -126
  1563. data/spec/unit/mixin/checksum_spec.rb +40 -40
  1564. data/spec/unit/mixin/command_spec.rb +104 -104
  1565. data/spec/unit/mixin/convert_to_class_name_spec.rb +54 -54
  1566. data/spec/unit/mixin/deep_merge_spec.rb +342 -342
  1567. data/spec/unit/mixin/deprecation_spec.rb +57 -57
  1568. data/spec/unit/mixin/enforce_ownership_and_permissions_spec.rb +96 -96
  1569. data/spec/unit/mixin/homebrew_user_spec.rb +100 -100
  1570. data/spec/unit/mixin/params_validate_spec.rb +409 -409
  1571. data/spec/unit/mixin/path_sanity_spec.rb +92 -86
  1572. data/spec/unit/mixin/powershell_out_spec.rb +70 -70
  1573. data/spec/unit/mixin/powershell_type_coercions_spec.rb +83 -83
  1574. data/spec/unit/mixin/properties_spec.rb +97 -97
  1575. data/spec/unit/mixin/proxified_socket_spec.rb +94 -94
  1576. data/spec/unit/mixin/securable_spec.rb +314 -314
  1577. data/spec/unit/mixin/shell_out_spec.rb +299 -299
  1578. data/spec/unit/mixin/subclass_directive_spec.rb +45 -45
  1579. data/spec/unit/mixin/template_spec.rb +276 -276
  1580. data/spec/unit/mixin/unformatter_spec.rb +61 -61
  1581. data/spec/unit/mixin/uris_spec.rb +57 -57
  1582. data/spec/unit/mixin/windows_architecture_helper_spec.rb +85 -85
  1583. data/spec/unit/mixin/xml_escape_spec.rb +54 -54
  1584. data/spec/unit/monkey_patches/uri_spec.rb +34 -34
  1585. data/spec/unit/monologger_spec.rb +45 -45
  1586. data/spec/unit/node/attribute_spec.rb +1179 -1179
  1587. data/spec/unit/node/immutable_collections_spec.rb +197 -197
  1588. data/spec/unit/node_map_spec.rb +170 -170
  1589. data/spec/unit/node_spec.rb +1565 -1565
  1590. data/spec/unit/org_spec.rb +196 -196
  1591. data/spec/unit/platform/query_helpers_spec.rb +220 -220
  1592. data/spec/unit/platform_spec.rb +241 -241
  1593. data/spec/unit/policy_builder/dynamic_spec.rb +273 -273
  1594. data/spec/unit/policy_builder/expand_node_object_spec.rb +336 -336
  1595. data/spec/unit/policy_builder/policyfile_spec.rb +745 -739
  1596. data/spec/unit/policy_builder_spec.rb +26 -26
  1597. data/spec/unit/property/state_spec.rb +508 -508
  1598. data/spec/unit/property/validation_spec.rb +704 -704
  1599. data/spec/unit/property_spec.rb +1227 -1227
  1600. data/spec/unit/provider/apt_update_spec.rb +113 -113
  1601. data/spec/unit/provider/breakpoint_spec.rb +53 -53
  1602. data/spec/unit/provider/cookbook_file/content_spec.rb +39 -39
  1603. data/spec/unit/provider/cookbook_file_spec.rb +58 -58
  1604. data/spec/unit/provider/cron/unix_spec.rb +139 -139
  1605. data/spec/unit/provider/cron_spec.rb +1010 -1010
  1606. data/spec/unit/provider/deploy/revision_spec.rb +110 -110
  1607. data/spec/unit/provider/deploy/timestamped_spec.rb +40 -40
  1608. data/spec/unit/provider/deploy_spec.rb +641 -641
  1609. data/spec/unit/provider/directory_spec.rb +287 -287
  1610. data/spec/unit/provider/dsc_resource_spec.rb +167 -118
  1611. data/spec/unit/provider/dsc_script_spec.rb +173 -173
  1612. data/spec/unit/provider/env/windows_spec.rb +103 -103
  1613. data/spec/unit/provider/env_spec.rb +310 -310
  1614. data/spec/unit/provider/erl_call_spec.rb +85 -85
  1615. data/spec/unit/provider/execute_spec.rb +243 -243
  1616. data/spec/unit/provider/file/content_spec.rb +114 -114
  1617. data/spec/unit/provider/file_spec.rb +56 -56
  1618. data/spec/unit/provider/git_spec.rb +668 -668
  1619. data/spec/unit/provider/group/dscl_spec.rb +331 -331
  1620. data/spec/unit/provider/group/gpasswd_spec.rb +116 -116
  1621. data/spec/unit/provider/group/groupadd_spec.rb +174 -174
  1622. data/spec/unit/provider/group/groupmod_spec.rb +133 -133
  1623. data/spec/unit/provider/group/pw_spec.rb +138 -138
  1624. data/spec/unit/provider/group/usermod_spec.rb +115 -115
  1625. data/spec/unit/provider/group/windows_spec.rb +101 -101
  1626. data/spec/unit/provider/group_spec.rb +286 -286
  1627. data/spec/unit/provider/http_request_spec.rb +159 -159
  1628. data/spec/unit/provider/ifconfig/aix_spec.rb +180 -180
  1629. data/spec/unit/provider/ifconfig/debian_spec.rb +344 -344
  1630. data/spec/unit/provider/ifconfig/redhat_spec.rb +73 -73
  1631. data/spec/unit/provider/ifconfig_spec.rb +200 -200
  1632. data/spec/unit/provider/launchd_spec.rb +189 -0
  1633. data/spec/unit/provider/link_spec.rb +252 -252
  1634. data/spec/unit/provider/log_spec.rb +75 -75
  1635. data/spec/unit/provider/mdadm_spec.rb +131 -131
  1636. data/spec/unit/provider/mount/aix_spec.rb +238 -238
  1637. data/spec/unit/provider/mount/mount_spec.rb +480 -480
  1638. data/spec/unit/provider/mount/solaris_spec.rb +822 -822
  1639. data/spec/unit/provider/mount/windows_spec.rb +151 -151
  1640. data/spec/unit/provider/mount_spec.rb +203 -203
  1641. data/spec/unit/provider/ohai_spec.rb +84 -84
  1642. data/spec/unit/provider/osx_profile_spec.rb +249 -249
  1643. data/spec/unit/provider/package/aix_spec.rb +172 -172
  1644. data/spec/unit/provider/package/apt_spec.rb +386 -386
  1645. data/spec/unit/provider/package/chocolatey_spec.rb +501 -504
  1646. data/spec/unit/provider/package/dpkg_spec.rb +287 -287
  1647. data/spec/unit/provider/package/easy_install_spec.rb +108 -108
  1648. data/spec/unit/provider/package/freebsd/pkg_spec.rb +274 -274
  1649. data/spec/unit/provider/package/freebsd/pkgng_spec.rb +148 -148
  1650. data/spec/unit/provider/package/freebsd/port_spec.rb +163 -163
  1651. data/spec/unit/provider/package/homebrew_spec.rb +292 -292
  1652. data/spec/unit/provider/package/ips_spec.rb +227 -227
  1653. data/spec/unit/provider/package/macports_spec.rb +203 -203
  1654. data/spec/unit/provider/package/openbsd_spec.rb +132 -132
  1655. data/spec/unit/provider/package/pacman_spec.rb +194 -194
  1656. data/spec/unit/provider/package/paludis_spec.rb +134 -134
  1657. data/spec/unit/provider/package/portage_spec.rb +310 -310
  1658. data/spec/unit/provider/package/rpm_spec.rb +429 -429
  1659. data/spec/unit/provider/package/rubygems_spec.rb +782 -782
  1660. data/spec/unit/provider/package/smartos_spec.rb +110 -110
  1661. data/spec/unit/provider/package/solaris_spec.rb +167 -167
  1662. data/spec/unit/provider/package/windows/exe_spec.rb +187 -187
  1663. data/spec/unit/provider/package/windows/msi_spec.rb +159 -159
  1664. data/spec/unit/provider/package/windows_spec.rb +397 -376
  1665. data/spec/unit/provider/package/yum_spec.rb +2267 -2267
  1666. data/spec/unit/provider/package/zypper_spec.rb +268 -268
  1667. data/spec/unit/provider/package_spec.rb +870 -870
  1668. data/spec/unit/provider/powershell_script_spec.rb +106 -106
  1669. data/spec/unit/provider/registry_key_spec.rb +295 -295
  1670. data/spec/unit/provider/remote_directory_spec.rb +221 -221
  1671. data/spec/unit/provider/remote_file/cache_control_data_spec.rb +245 -245
  1672. data/spec/unit/provider/remote_file/content_spec.rb +252 -252
  1673. data/spec/unit/provider/remote_file/fetcher_spec.rb +94 -94
  1674. data/spec/unit/provider/remote_file/ftp_spec.rb +219 -219
  1675. data/spec/unit/provider/remote_file/http_spec.rb +301 -301
  1676. data/spec/unit/provider/remote_file/local_file_spec.rb +103 -103
  1677. data/spec/unit/provider/remote_file/network_file_spec.rb +45 -45
  1678. data/spec/unit/provider/remote_file_spec.rb +61 -61
  1679. data/spec/unit/provider/route_spec.rb +242 -242
  1680. data/spec/unit/provider/ruby_block_spec.rb +45 -45
  1681. data/spec/unit/provider/script_spec.rb +114 -114
  1682. data/spec/unit/provider/service/aix_service_spec.rb +195 -195
  1683. data/spec/unit/provider/service/aixinit_service_spec.rb +272 -272
  1684. data/spec/unit/provider/service/arch_service_spec.rb +324 -324
  1685. data/spec/unit/provider/service/debian_service_spec.rb +375 -375
  1686. data/spec/unit/provider/service/freebsd_service_spec.rb +613 -613
  1687. data/spec/unit/provider/service/gentoo_service_spec.rb +144 -144
  1688. data/spec/unit/provider/service/init_service_spec.rb +235 -235
  1689. data/spec/unit/provider/service/insserv_service_spec.rb +75 -75
  1690. data/spec/unit/provider/service/invokercd_service_spec.rb +211 -211
  1691. data/spec/unit/provider/service/macosx_spec.rb +335 -335
  1692. data/spec/unit/provider/service/openbsd_service_spec.rb +545 -545
  1693. data/spec/unit/provider/service/redhat_spec.rb +236 -236
  1694. data/spec/unit/provider/service/simple_service_spec.rb +169 -169
  1695. data/spec/unit/provider/service/solaris_smf_service_spec.rb +255 -255
  1696. data/spec/unit/provider/service/systemd_service_spec.rb +344 -279
  1697. data/spec/unit/provider/service/upstart_service_spec.rb +342 -342
  1698. data/spec/unit/provider/service/windows_spec.rb +463 -463
  1699. data/spec/unit/provider/service_spec.rb +168 -168
  1700. data/spec/unit/provider/subversion_spec.rb +298 -298
  1701. data/spec/unit/provider/template/content_spec.rb +169 -169
  1702. data/spec/unit/provider/template_spec.rb +89 -89
  1703. data/spec/unit/provider/user/dscl_spec.rb +901 -900
  1704. data/spec/unit/provider/user/pw_spec.rb +252 -252
  1705. data/spec/unit/provider/user/solaris_spec.rb +139 -137
  1706. data/spec/unit/provider/user/useradd_spec.rb +51 -51
  1707. data/spec/unit/provider/user/windows_spec.rb +185 -185
  1708. data/spec/unit/provider/user_spec.rb +474 -474
  1709. data/spec/unit/provider/whyrun_safe_ruby_block_spec.rb +46 -46
  1710. data/spec/unit/provider_resolver_spec.rb +893 -893
  1711. data/spec/unit/provider_spec.rb +198 -198
  1712. data/spec/unit/pure_application_spec.rb +32 -32
  1713. data/spec/unit/recipe_spec.rb +699 -699
  1714. data/spec/unit/resource/apt_package_spec.rb +38 -38
  1715. data/spec/unit/resource/apt_update_spec.rb +38 -38
  1716. data/spec/unit/resource/bash_spec.rb +40 -40
  1717. data/spec/unit/resource/batch_spec.rb +49 -49
  1718. data/spec/unit/resource/breakpoint_spec.rb +47 -47
  1719. data/spec/unit/resource/chef_gem_spec.rb +157 -157
  1720. data/spec/unit/resource/chocolatey_package_spec.rb +67 -67
  1721. data/spec/unit/resource/conditional_action_not_nothing_spec.rb +45 -45
  1722. data/spec/unit/resource/conditional_spec.rb +208 -208
  1723. data/spec/unit/resource/cookbook_file_spec.rb +88 -88
  1724. data/spec/unit/resource/cron_spec.rb +186 -186
  1725. data/spec/unit/resource/csh_spec.rb +40 -40
  1726. data/spec/unit/resource/deploy_revision_spec.rb +42 -42
  1727. data/spec/unit/resource/deploy_spec.rb +283 -283
  1728. data/spec/unit/resource/directory_spec.rb +82 -82
  1729. data/spec/unit/resource/dpkg_package_spec.rb +32 -32
  1730. data/spec/unit/resource/dsc_resource_spec.rb +96 -96
  1731. data/spec/unit/resource/dsc_script_spec.rb +134 -134
  1732. data/spec/unit/resource/easy_install_package_spec.rb +39 -39
  1733. data/spec/unit/resource/env_spec.rb +85 -85
  1734. data/spec/unit/resource/erl_call_spec.rb +81 -81
  1735. data/spec/unit/resource/execute_spec.rb +35 -35
  1736. data/spec/unit/resource/file/verification_spec.rb +139 -139
  1737. data/spec/unit/resource/file_spec.rb +130 -130
  1738. data/spec/unit/resource/freebsd_package_spec.rb +87 -87
  1739. data/spec/unit/resource/gem_package_spec.rb +42 -42
  1740. data/spec/unit/resource/git_spec.rb +50 -50
  1741. data/spec/unit/resource/group_spec.rb +162 -157
  1742. data/spec/unit/resource/homebrew_package_spec.rb +50 -50
  1743. data/spec/unit/resource/http_request_spec.rb +59 -59
  1744. data/spec/unit/resource/ifconfig_spec.rb +109 -109
  1745. data/spec/unit/resource/ips_package_spec.rb +40 -40
  1746. data/spec/unit/resource/ksh_spec.rb +40 -40
  1747. data/spec/unit/resource/launchd_spec.rb +31 -0
  1748. data/spec/unit/resource/link_spec.rb +134 -134
  1749. data/spec/unit/resource/log_spec.rb +73 -73
  1750. data/spec/unit/resource/macports_package_spec.rb +32 -32
  1751. data/spec/unit/resource/mdadm_spec.rb +102 -102
  1752. data/spec/unit/resource/mount_spec.rb +214 -214
  1753. data/spec/unit/resource/ohai_spec.rb +61 -61
  1754. data/spec/unit/resource/openbsd_package_spec.rb +48 -48
  1755. data/spec/unit/resource/osx_profile_spec.rb +61 -61
  1756. data/spec/unit/resource/package_spec.rb +93 -93
  1757. data/spec/unit/resource/pacman_package_spec.rb +32 -32
  1758. data/spec/unit/resource/perl_spec.rb +40 -40
  1759. data/spec/unit/resource/portage_package_spec.rb +38 -38
  1760. data/spec/unit/resource/powershell_script_spec.rb +136 -136
  1761. data/spec/unit/resource/python_spec.rb +40 -40
  1762. data/spec/unit/resource/registry_key_spec.rb +199 -199
  1763. data/spec/unit/resource/remote_directory_spec.rb +97 -97
  1764. data/spec/unit/resource/remote_file_spec.rb +207 -207
  1765. data/spec/unit/resource/resource_notification_spec.rb +169 -169
  1766. data/spec/unit/resource/route_spec.rb +107 -107
  1767. data/spec/unit/resource/rpm_package_spec.rb +46 -46
  1768. data/spec/unit/resource/ruby_block_spec.rb +61 -61
  1769. data/spec/unit/resource/ruby_spec.rb +40 -40
  1770. data/spec/unit/resource/scm_spec.rb +193 -193
  1771. data/spec/unit/resource/script_spec.rb +44 -44
  1772. data/spec/unit/resource/service_spec.rb +179 -179
  1773. data/spec/unit/resource/smartos_package_spec.rb +33 -33
  1774. data/spec/unit/resource/solaris_package_spec.rb +42 -42
  1775. data/spec/unit/resource/subversion_spec.rb +71 -71
  1776. data/spec/unit/resource/template_spec.rb +210 -210
  1777. data/spec/unit/resource/timestamped_deploy_spec.rb +32 -32
  1778. data/spec/unit/resource/user_spec.rb +133 -133
  1779. data/spec/unit/resource/windows_package_spec.rb +95 -95
  1780. data/spec/unit/resource/windows_service_spec.rb +49 -49
  1781. data/spec/unit/resource/yum_package_spec.rb +89 -89
  1782. data/spec/unit/resource_builder_spec.rb +1 -1
  1783. data/spec/unit/resource_collection/resource_list_spec.rb +137 -137
  1784. data/spec/unit/resource_collection/resource_set_spec.rb +199 -199
  1785. data/spec/unit/resource_collection/stepable_iterator_spec.rb +144 -144
  1786. data/spec/unit/resource_collection_spec.rb +299 -299
  1787. data/spec/unit/resource_definition_spec.rb +117 -117
  1788. data/spec/unit/resource_reporter_spec.rb +758 -758
  1789. data/spec/unit/resource_resolver_spec.rb +52 -52
  1790. data/spec/unit/resource_spec.rb +1101 -1101
  1791. data/spec/unit/rest/auth_credentials_spec.rb +296 -296
  1792. data/spec/unit/rest_spec.rb +753 -753
  1793. data/spec/unit/role_spec.rb +358 -358
  1794. data/spec/unit/run_context/child_run_context_spec.rb +133 -133
  1795. data/spec/unit/run_context/cookbook_compiler_spec.rb +184 -184
  1796. data/spec/unit/run_context_spec.rb +241 -241
  1797. data/spec/unit/run_list/run_list_expansion_spec.rb +144 -144
  1798. data/spec/unit/run_list/run_list_item_spec.rb +117 -117
  1799. data/spec/unit/run_list/versioned_recipe_list_spec.rb +194 -194
  1800. data/spec/unit/run_list_spec.rb +312 -312
  1801. data/spec/unit/run_lock_spec.rb +140 -140
  1802. data/spec/unit/run_status_spec.rb +144 -144
  1803. data/spec/unit/runner_spec.rb +411 -411
  1804. data/spec/unit/scan_access_control_spec.rb +183 -183
  1805. data/spec/unit/search/query_spec.rb +289 -289
  1806. data/spec/unit/shell/model_wrapper_spec.rb +96 -96
  1807. data/spec/unit/shell/shell_ext_spec.rb +153 -153
  1808. data/spec/unit/shell/shell_session_spec.rb +195 -195
  1809. data/spec/unit/shell_out_spec.rb +18 -18
  1810. data/spec/unit/shell_spec.rb +162 -162
  1811. data/spec/unit/user_spec.rb +275 -275
  1812. data/spec/unit/user_v1_spec.rb +583 -583
  1813. data/spec/unit/util/backup_spec.rb +141 -141
  1814. data/spec/unit/util/diff_spec.rb +576 -576
  1815. data/spec/unit/util/dsc/configuration_generator_spec.rb +193 -193
  1816. data/spec/unit/util/dsc/lcm_output_parser_spec.rb +164 -164
  1817. data/spec/unit/util/dsc/local_configuration_manager_spec.rb +138 -138
  1818. data/spec/unit/util/dsc/resource_store.rb +76 -76
  1819. data/spec/unit/util/editor_spec.rb +152 -152
  1820. data/spec/unit/util/file_edit_spec.rb +224 -224
  1821. data/spec/unit/util/powershell/cmdlet_spec.rb +106 -106
  1822. data/spec/unit/util/powershell/ps_credential_spec.rb +44 -44
  1823. data/spec/unit/util/selinux_spec.rb +171 -171
  1824. data/spec/unit/util/threaded_job_queue_spec.rb +51 -51
  1825. data/spec/unit/version/platform_spec.rb +60 -60
  1826. data/spec/unit/version_class_spec.rb +171 -171
  1827. data/spec/unit/version_constraint/platform_spec.rb +45 -45
  1828. data/spec/unit/version_constraint_spec.rb +179 -179
  1829. data/spec/unit/win32/registry_spec.rb +394 -394
  1830. data/spec/unit/windows_service_spec.rb +116 -116
  1831. data/tasks/cbgb.rb +84 -84
  1832. data/tasks/external_tests.rb +64 -64
  1833. data/tasks/maintainers.rb +210 -210
  1834. data/tasks/rspec.rb +89 -89
  1835. metadata +428 -12
  1836. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbooks_dir.rb +0 -84
@@ -1,127 +1,127 @@
1
- #
2
- # Author:: John Keiser (<jkeiser@chef.io>)
3
- # Copyright:: Copyright 2012-2016, Chef Software Inc.
4
- # License:: Apache License, Version 2.0
5
- #
6
- # Licensed under the Apache License, Version 2.0 (the "License");
7
- # you may not use this file except in compliance with the License.
8
- # You may obtain a copy of the License at
9
- #
10
- # http://www.apache.org/licenses/LICENSE-2.0
11
- #
12
- # Unless required by applicable law or agreed to in writing, software
13
- # distributed under the License is distributed on an "AS IS" BASIS,
14
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- # See the License for the specific language governing permissions and
16
- # limitations under the License.
17
- #
18
-
19
- require "chef/chef_fs"
20
- require "pathname"
21
-
22
- class Chef
23
- module ChefFS
24
- class PathUtils
25
-
26
- # A Chef-FS path is a path in a chef-repository that can be used to address
27
- # both files on a local file-system as well as objects on a chef server.
28
- # These paths are stricter than file-system paths allowed on various OSes.
29
- # Absolute Chef-FS paths begin with "/" (on windows, "\" is acceptable as well).
30
- # "/" is used as the path element separator (on windows, "\" is acceptable as well).
31
- # No directory/path element may contain a literal "\" character. Any such characters
32
- # encountered are either dealt with as separators (on windows) or as escape
33
- # characters (on POSIX systems). Relative Chef-FS paths may use ".." or "." but
34
- # may never use these to back-out of the root of a Chef-FS path. Any such extraneous
35
- # ".."s are ignored.
36
- # Chef-FS paths are case sensitive (since the paths on the server are).
37
- # On OSes with case insensitive paths, you may be unable to locally deal with two
38
- # objects whose server paths only differ by case. OTOH, the case of path segments
39
- # that are outside the Chef-FS root (such as when looking at a file-system absolute
40
- # path to discover the Chef-FS root path) are handled in accordance to the rules
41
- # of the local file-system and OS.
42
-
43
- def self.join(*parts)
44
- return "" if parts.length == 0
45
- # Determine if it started with a slash
46
- absolute = parts[0].length == 0 || parts[0].length > 0 && parts[0] =~ /^#{regexp_path_separator}/
47
- # Remove leading and trailing slashes from each part so that the join will work (and the slash at the end will go away)
48
- parts = parts.map { |part| part.gsub(/^#{regexp_path_separator}+|#{regexp_path_separator}+$/, "") }
49
- # Don't join empty bits
50
- result = parts.select { |part| part != "" }.join("/")
51
- # Put the / back on
52
- absolute ? "/#{result}" : result
53
- end
54
-
55
- def self.split(path)
56
- path.split(Regexp.new(regexp_path_separator))
57
- end
58
-
59
- def self.regexp_path_separator
60
- Chef::ChefFS::windows? ? '[\/\\\\]' : "/"
61
- end
62
-
63
- # Given a server path, determines if it is absolute.
64
- def self.is_absolute?(path)
65
- !!(path =~ /^#{regexp_path_separator}/)
66
- end
67
-
68
- # Given a path which may only be partly real (i.e. /x/y/z when only /x exists,
69
- # or /x/y/*/blah when /x/y/z/blah exists), call File.realpath on the biggest
70
- # part that actually exists. The paths operated on here are not Chef-FS paths.
71
- # These are OS paths that may contain symlinks but may not also fully exist.
72
- #
73
- # If /x is a symlink to /blarghle, and has no subdirectories, then:
74
- # PathUtils.realest_path('/x/y/z') == '/blarghle/y/z'
75
- # PathUtils.realest_path('/x/*/z') == '/blarghle/*/z'
76
- # PathUtils.realest_path('/*/y/z') == '/*/y/z'
77
- #
78
- # TODO: Move this to wherever util/path_helper is these days.
79
- def self.realest_path(path, cwd = Dir.pwd)
80
- path = File.expand_path(path, cwd)
81
- parent_path = File.dirname(path)
82
- suffix = []
83
-
84
- # File.dirname happens to return the path as its own dirname if you're
85
- # at the root (such as at \\foo\bar, C:\ or /)
86
- until parent_path == path do
87
- # This can occur if a path such as "C:" is given. Ruby gives the parent as "C:."
88
- # for reasons only it knows.
89
- raise ArgumentError "Invalid path segment #{path}" if parent_path.length > path.length
90
- begin
91
- path = File.realpath(path)
92
- break
93
- rescue Errno::ENOENT
94
- suffix << File.basename(path)
95
- path = parent_path
96
- parent_path = File.dirname(path)
97
- end
98
- end
99
- File.join(path, *suffix.reverse)
100
- end
101
-
102
- # Compares two path fragments according to the case-sentitivity of the host platform.
103
- def self.os_path_eq?(left, right)
104
- Chef::ChefFS::windows? ? left.casecmp(right) == 0 : left == right
105
- end
106
-
107
- # Given two general OS-dependent file paths, determines the relative path of the
108
- # child with respect to the ancestor. Both child and ancestor must exist and be
109
- # fully resolved - this is strictly a lexical comparison. No trailing slashes
110
- # and other shenanigans are allowed.
111
- #
112
- # TODO: Move this to util/path_helper.
113
- def self.descendant_path(path, ancestor)
114
- candidate_fragment = path[0, ancestor.length]
115
- return nil unless PathUtils.os_path_eq?(candidate_fragment, ancestor)
116
- if ancestor.length == path.length
117
- ""
118
- elsif path[ancestor.length, 1] =~ /#{PathUtils.regexp_path_separator}/
119
- path[ancestor.length + 1..-1]
120
- else
121
- nil
122
- end
123
- end
124
-
125
- end
126
- end
127
- end
1
+ #
2
+ # Author:: John Keiser (<jkeiser@chef.io>)
3
+ # Copyright:: Copyright 2012-2016, Chef Software Inc.
4
+ # License:: Apache License, Version 2.0
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+ #
18
+
19
+ require "chef/chef_fs"
20
+ require "pathname"
21
+
22
+ class Chef
23
+ module ChefFS
24
+ class PathUtils
25
+
26
+ # A Chef-FS path is a path in a chef-repository that can be used to address
27
+ # both files on a local file-system as well as objects on a chef server.
28
+ # These paths are stricter than file-system paths allowed on various OSes.
29
+ # Absolute Chef-FS paths begin with "/" (on windows, "\" is acceptable as well).
30
+ # "/" is used as the path element separator (on windows, "\" is acceptable as well).
31
+ # No directory/path element may contain a literal "\" character. Any such characters
32
+ # encountered are either dealt with as separators (on windows) or as escape
33
+ # characters (on POSIX systems). Relative Chef-FS paths may use ".." or "." but
34
+ # may never use these to back-out of the root of a Chef-FS path. Any such extraneous
35
+ # ".."s are ignored.
36
+ # Chef-FS paths are case sensitive (since the paths on the server are).
37
+ # On OSes with case insensitive paths, you may be unable to locally deal with two
38
+ # objects whose server paths only differ by case. OTOH, the case of path segments
39
+ # that are outside the Chef-FS root (such as when looking at a file-system absolute
40
+ # path to discover the Chef-FS root path) are handled in accordance to the rules
41
+ # of the local file-system and OS.
42
+
43
+ def self.join(*parts)
44
+ return "" if parts.length == 0
45
+ # Determine if it started with a slash
46
+ absolute = parts[0].length == 0 || parts[0].length > 0 && parts[0] =~ /^#{regexp_path_separator}/
47
+ # Remove leading and trailing slashes from each part so that the join will work (and the slash at the end will go away)
48
+ parts = parts.map { |part| part.gsub(/^#{regexp_path_separator}+|#{regexp_path_separator}+$/, "") }
49
+ # Don't join empty bits
50
+ result = parts.select { |part| part != "" }.join("/")
51
+ # Put the / back on
52
+ absolute ? "/#{result}" : result
53
+ end
54
+
55
+ def self.split(path)
56
+ path.split(Regexp.new(regexp_path_separator))
57
+ end
58
+
59
+ def self.regexp_path_separator
60
+ Chef::ChefFS.windows? ? '[\/\\\\]' : "/"
61
+ end
62
+
63
+ # Given a server path, determines if it is absolute.
64
+ def self.is_absolute?(path)
65
+ !!(path =~ /^#{regexp_path_separator}/)
66
+ end
67
+
68
+ # Given a path which may only be partly real (i.e. /x/y/z when only /x exists,
69
+ # or /x/y/*/blah when /x/y/z/blah exists), call File.realpath on the biggest
70
+ # part that actually exists. The paths operated on here are not Chef-FS paths.
71
+ # These are OS paths that may contain symlinks but may not also fully exist.
72
+ #
73
+ # If /x is a symlink to /blarghle, and has no subdirectories, then:
74
+ # PathUtils.realest_path('/x/y/z') == '/blarghle/y/z'
75
+ # PathUtils.realest_path('/x/*/z') == '/blarghle/*/z'
76
+ # PathUtils.realest_path('/*/y/z') == '/*/y/z'
77
+ #
78
+ # TODO: Move this to wherever util/path_helper is these days.
79
+ def self.realest_path(path, cwd = Dir.pwd)
80
+ path = File.expand_path(path, cwd)
81
+ parent_path = File.dirname(path)
82
+ suffix = []
83
+
84
+ # File.dirname happens to return the path as its own dirname if you're
85
+ # at the root (such as at \\foo\bar, C:\ or /)
86
+ until parent_path == path
87
+ # This can occur if a path such as "C:" is given. Ruby gives the parent as "C:."
88
+ # for reasons only it knows.
89
+ raise ArgumentError "Invalid path segment #{path}" if parent_path.length > path.length
90
+ begin
91
+ path = File.realpath(path)
92
+ break
93
+ rescue Errno::ENOENT
94
+ suffix << File.basename(path)
95
+ path = parent_path
96
+ parent_path = File.dirname(path)
97
+ end
98
+ end
99
+ File.join(path, *suffix.reverse)
100
+ end
101
+
102
+ # Compares two path fragments according to the case-sentitivity of the host platform.
103
+ def self.os_path_eq?(left, right)
104
+ Chef::ChefFS.windows? ? left.casecmp(right) == 0 : left == right
105
+ end
106
+
107
+ # Given two general OS-dependent file paths, determines the relative path of the
108
+ # child with respect to the ancestor. Both child and ancestor must exist and be
109
+ # fully resolved - this is strictly a lexical comparison. No trailing slashes
110
+ # and other shenanigans are allowed.
111
+ #
112
+ # TODO: Move this to util/path_helper.
113
+ def self.descendant_path(path, ancestor)
114
+ candidate_fragment = path[0, ancestor.length]
115
+ return nil unless PathUtils.os_path_eq?(candidate_fragment, ancestor)
116
+ if ancestor.length == path.length
117
+ ""
118
+ elsif path[ancestor.length, 1] =~ /#{PathUtils.regexp_path_separator}/
119
+ path[ancestor.length + 1..-1]
120
+ else
121
+ nil
122
+ end
123
+ end
124
+
125
+ end
126
+ end
127
+ end
@@ -1,967 +1,967 @@
1
- #
2
- # Author:: Adam Jacob (<adam@chef.io>)
3
- # Author:: Christopher Walters (<cw@chef.io>)
4
- # Author:: Christopher Brown (<cb@chef.io>)
5
- # Author:: Tim Hinderliter (<tim@chef.io>)
6
- # Copyright:: Copyright 2008-2016, Chef Software, Inc.
7
- # License:: Apache License, Version 2.0
8
- #
9
- # Licensed under the Apache License, Version 2.0 (the "License");
10
- # you may not use this file except in compliance with the License.
11
- # You may obtain a copy of the License at
12
- #
13
- # http://www.apache.org/licenses/LICENSE-2.0
14
- #
15
- # Unless required by applicable law or agreed to in writing, software
16
- # distributed under the License is distributed on an "AS IS" BASIS,
17
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18
- # See the License for the specific language governing permissions and
19
- # limitations under the License.
20
-
21
- require "chef/config"
22
- require "chef/mixin/params_validate"
23
- require "chef/mixin/path_sanity"
24
- require "chef/log"
25
- require "chef/server_api"
26
- require "chef/api_client"
27
- require "chef/api_client/registration"
28
- require "chef/audit/runner"
29
- require "chef/node"
30
- require "chef/role"
31
- require "chef/file_cache"
32
- require "chef/run_context"
33
- require "chef/runner"
34
- require "chef/run_status"
35
- require "chef/cookbook/cookbook_collection"
36
- require "chef/cookbook/file_vendor"
37
- require "chef/cookbook/file_system_file_vendor"
38
- require "chef/cookbook/remote_file_vendor"
39
- require "chef/event_dispatch/dispatcher"
40
- require "chef/event_loggers/base"
41
- require "chef/event_loggers/windows_eventlog"
42
- require "chef/exceptions"
43
- require "chef/formatters/base"
44
- require "chef/formatters/doc"
45
- require "chef/formatters/minimal"
46
- require "chef/version"
47
- require "chef/resource_reporter"
48
- require "chef/audit/audit_reporter"
49
- require "chef/run_lock"
50
- require "chef/policy_builder"
51
- require "chef/request_id"
52
- require "chef/platform/rebooter"
53
- require "chef/mixin/deprecation"
54
- require "ohai"
55
- require "rbconfig"
56
-
57
- class Chef
58
- # == Chef::Client
59
- # The main object in a Chef run. Preps a Chef::Node and Chef::RunContext,
60
- # syncs cookbooks if necessary, and triggers convergence.
61
- class Client
62
- include Chef::Mixin::PathSanity
63
-
64
- extend Chef::Mixin::Deprecation
65
-
66
- #
67
- # The status of the Chef run.
68
- #
69
- # @return [Chef::RunStatus]
70
- #
71
- attr_reader :run_status
72
-
73
- #
74
- # The node represented by this client.
75
- #
76
- # @return [Chef::Node]
77
- #
78
- def node
79
- run_status.node
80
- end
81
-
82
- def node=(value)
83
- run_status.node = value
84
- end
85
-
86
- #
87
- # The ohai system used by this client.
88
- #
89
- # @return [Ohai::System]
90
- #
91
- attr_reader :ohai
92
-
93
- #
94
- # The rest object used to communicate with the Chef server.
95
- #
96
- # @return [Chef::ServerAPI]
97
- #
98
- attr_reader :rest
99
-
100
- #
101
- # A rest object with validate_utf8 set to false. This will not throw exceptions
102
- # on non-UTF8 strings in JSON but will sanitize them so that e.g. POSTs will
103
- # never fail. Cannot be configured on a request-by-request basis, so we carry
104
- # around another rest object for it.
105
- #
106
- attr_reader :rest_clean
107
-
108
- #
109
- # The runner used to converge.
110
- #
111
- # @return [Chef::Runner]
112
- #
113
- attr_accessor :runner
114
-
115
- #
116
- # Extra node attributes that were applied to the node.
117
- #
118
- # @return [Hash]
119
- #
120
- attr_reader :json_attribs
121
-
122
- #
123
- # The event dispatcher for the Chef run, including any configured output
124
- # formatters and event loggers.
125
- #
126
- # @return [EventDispatch::Dispatcher]
127
- #
128
- # @see Chef::Formatters
129
- # @see Chef::Config#formatters
130
- # @see Chef::Config#stdout
131
- # @see Chef::Config#stderr
132
- # @see Chef::Config#force_logger
133
- # @see Chef::Config#force_formatter
134
- # TODO add stdout, stderr, and default formatters to Chef::Config so the
135
- # defaults aren't calculated here. Remove force_logger and force_formatter
136
- # from this code.
137
- # @see Chef::EventLoggers
138
- # @see Chef::Config#disable_event_logger
139
- # @see Chef::Config#event_loggers
140
- # @see Chef::Config#event_handlers
141
- #
142
- attr_reader :events
143
-
144
- #
145
- # Creates a new Chef::Client.
146
- #
147
- # @param json_attribs [Hash] Node attributes to layer into the node when it is
148
- # fetched.
149
- # @param args [Hash] Options:
150
- # @option args [Array<RunList::RunListItem>] :override_runlist A runlist to
151
- # use instead of the node's embedded run list.
152
- # @option args [Array<String>] :specific_recipes A list of recipe file paths
153
- # to load after the run list has been loaded.
154
- #
155
- def initialize(json_attribs = nil, args = {})
156
- @json_attribs = json_attribs || {}
157
- @ohai = Ohai::System.new
158
-
159
- event_handlers = configure_formatters + configure_event_loggers
160
- event_handlers += Array(Chef::Config[:event_handlers])
161
-
162
- @events = EventDispatch::Dispatcher.new(*event_handlers)
163
- # TODO it seems like a bad idea to be deletin' other peoples' hashes.
164
- @override_runlist = args.delete(:override_runlist)
165
- @specific_recipes = args.delete(:specific_recipes)
166
- @run_status = Chef::RunStatus.new(nil, events)
167
-
168
- if new_runlist = args.delete(:runlist)
169
- @json_attribs["run_list"] = new_runlist
170
- end
171
- end
172
-
173
- #
174
- # Do a full run for this Chef::Client.
175
- #
176
- # Locks the run while doing its job.
177
- #
178
- # Fires run_start before doing anything and fires run_completed or
179
- # run_failed when finished. Also notifies client listeners of run_started
180
- # at the beginning of Compile, and run_completed_successfully or run_failed
181
- # when all is complete.
182
- #
183
- # Phase 1: Setup
184
- # --------------
185
- # Gets information about the system and the run we are doing.
186
- #
187
- # 1. Run ohai to collect system information.
188
- # 2. Register / connect to the Chef server (unless in solo mode).
189
- # 3. Retrieve the node (or create a new one).
190
- # 4. Merge in json_attribs, Chef::Config.environment, and override_run_list.
191
- #
192
- # @see #run_ohai
193
- # @see #load_node
194
- # @see #build_node
195
- # @see Chef::Config#lockfile
196
- # @see Chef::RunLock#acquire
197
- #
198
- # Phase 2: Compile
199
- # ----------------
200
- # Decides *what* we plan to converge by compiling recipes.
201
- #
202
- # 1. Sync required cookbooks to the local cache.
203
- # 2. Load libraries from all cookbooks.
204
- # 3. Load attributes from all cookbooks.
205
- # 4. Load LWRPs from all cookbooks.
206
- # 5. Load resource definitions from all cookbooks.
207
- # 6. Load recipes in the run list.
208
- # 7. Load recipes from the command line.
209
- #
210
- # @see #setup_run_context Syncs and compiles cookbooks.
211
- # @see Chef::CookbookCompiler#compile
212
- #
213
- # Phase 3: Converge
214
- # -----------------
215
- # Brings the system up to date.
216
- #
217
- # 1. Converge the resources built from recipes in Phase 2.
218
- # 2. Save the node.
219
- # 3. Reboot if we were asked to.
220
- #
221
- # @see #converge_and_save
222
- # @see Chef::Runner
223
- #
224
- # Phase 4: Audit
225
- # --------------
226
- # Runs 'control_group' audits in recipes. This entire section can be enabled or disabled with config.
227
- #
228
- # 1. 'control_group' DSL collects audits during Phase 2
229
- # 2. Audits are run using RSpec
230
- # 3. Errors are collected and reported using the formatters
231
- #
232
- # @see #run_audits
233
- # @see Chef::Audit::Runner#run
234
- #
235
- # @raise [Chef::Exceptions::RunFailedWrappingError] If converge or audit failed.
236
- #
237
- # @see Chef::Config#enforce_path_sanity
238
- # @see Chef::Config#solo
239
- # @see Chef::Config#audit_mode
240
- #
241
- # @return Always returns true.
242
- #
243
- def run
244
- start_profiling
245
-
246
- run_error = nil
247
-
248
- runlock = RunLock.new(Chef::Config.lockfile)
249
- # TODO feels like acquire should have its own block arg for this
250
- runlock.acquire
251
- # don't add code that may fail before entering this section to be sure to release lock
252
- begin
253
- runlock.save_pid
254
-
255
- request_id = Chef::RequestID.instance.request_id
256
- run_context = nil
257
- events.run_start(Chef::VERSION)
258
- Chef::Log.info("*** Chef #{Chef::VERSION} ***")
259
- Chef::Log.info "Chef-client pid: #{Process.pid}"
260
- Chef::Log.debug("Chef-client request_id: #{request_id}")
261
- enforce_path_sanity
262
- run_ohai
263
-
264
- register unless Chef::Config[:solo]
265
-
266
- load_node
267
-
268
- build_node
269
-
270
- run_status.run_id = request_id
271
- run_status.start_clock
272
- Chef::Log.info("Starting Chef Run for #{node.name}")
273
- run_started
274
-
275
- do_windows_admin_check
276
-
277
- run_context = setup_run_context
278
-
279
- if Chef::Config[:audit_mode] != :audit_only
280
- converge_error = converge_and_save(run_context)
281
- end
282
-
283
- if Chef::Config[:why_run] == true
284
- # why_run should probably be renamed to why_converge
285
- Chef::Log.debug("Not running controls in 'why-run' mode - this mode is used to see potential converge changes")
286
- elsif Chef::Config[:audit_mode] != :disabled
287
- audit_error = run_audits(run_context)
288
- end
289
-
290
- # Raise converge_error so run_failed reporters/events are processed.
291
- raise converge_error if converge_error
292
-
293
- run_status.stop_clock
294
- Chef::Log.info("Chef Run complete in #{run_status.elapsed_time} seconds")
295
- run_completed_successfully
296
- events.run_completed(node)
297
-
298
- # keep this inside the main loop to get exception backtraces
299
- end_profiling
300
-
301
- # rebooting has to be the last thing we do, no exceptions.
302
- Chef::Platform::Rebooter.reboot_if_needed!(node)
303
- rescue Exception => run_error
304
- # CHEF-3336: Send the error first in case something goes wrong below and we don't know why
305
- Chef::Log.debug("Re-raising exception: #{run_error.class} - #{run_error.message}\n#{run_error.backtrace.join("\n ")}")
306
- # If we failed really early, we may not have a run_status yet. Too early for these to be of much use.
307
- if run_status
308
- run_status.stop_clock
309
- run_status.exception = run_error
310
- run_failed
311
- end
312
- events.run_failed(run_error)
313
- ensure
314
- Chef::RequestID.instance.reset_request_id
315
- request_id = nil
316
- @run_status = nil
317
- run_context = nil
318
- runlock.release
319
- end
320
-
321
- # Raise audit, converge, and other errors here so that we exit
322
- # with the proper exit status code and everything gets raised
323
- # as a RunFailedWrappingError
324
- if run_error || converge_error || audit_error
325
- error = if Chef::Config[:audit_mode] == :disabled
326
- run_error || converge_error
327
- else
328
- e = if run_error == converge_error
329
- Chef::Exceptions::RunFailedWrappingError.new(converge_error, audit_error)
330
- else
331
- Chef::Exceptions::RunFailedWrappingError.new(run_error, converge_error, audit_error)
332
- end
333
- e.fill_backtrace
334
- e
335
- end
336
-
337
- Chef::Application.debug_stacktrace(error)
338
- raise error
339
- end
340
-
341
- true
342
- end
343
-
344
- #
345
- # Private API
346
- # TODO make this stuff protected or private
347
- #
348
-
349
- # @api private
350
- def configure_formatters
351
- formatters_for_run.map do |formatter_name, output_path|
352
- if output_path.nil?
353
- Chef::Formatters.new(formatter_name, STDOUT_FD, STDERR_FD)
354
- else
355
- io = File.open(output_path, "a+")
356
- io.sync = true
357
- Chef::Formatters.new(formatter_name, io, io)
358
- end
359
- end
360
- end
361
-
362
- # @api private
363
- def formatters_for_run
364
- if Chef::Config.formatters.empty?
365
- [default_formatter]
366
- else
367
- Chef::Config.formatters
368
- end
369
- end
370
-
371
- # @api private
372
- def default_formatter
373
- if (STDOUT.tty? && !Chef::Config[:force_logger]) || Chef::Config[:force_formatter]
374
- [:doc]
375
- else
376
- [:null]
377
- end
378
- end
379
-
380
- # @api private
381
- def configure_event_loggers
382
- if Chef::Config.disable_event_logger
383
- []
384
- else
385
- Chef::Config.event_loggers.map do |evt_logger|
386
- case evt_logger
387
- when Symbol
388
- Chef::EventLoggers.new(evt_logger)
389
- when Class
390
- evt_logger.new
391
- else
392
- end
393
- end
394
- end
395
- end
396
-
397
- # Rest client for use by API reporters. This rest client will not fail with an exception if
398
- # it is fed non-UTF8 data.
399
- #
400
- # @api private
401
- def rest_clean(client_name = node_name, config = Chef::Config)
402
- @rest_clean ||=
403
- Chef::ServerAPI.new(config[:chef_server_url], client_name: client_name,
404
- signing_key_filename: config[:client_key], validate_utf8: false)
405
- end
406
-
407
- # Resource reporters send event information back to the chef server for
408
- # processing. Can only be called after we have a @rest object
409
- # @api private
410
- def register_reporters
411
- [
412
- Chef::ResourceReporter.new(rest_clean),
413
- Chef::Audit::AuditReporter.new(rest_clean),
414
- ].each do |r|
415
- events.register(r)
416
- end
417
- end
418
-
419
- #
420
- # Callback to fire notifications that the Chef run is starting
421
- #
422
- # @api private
423
- #
424
- def run_started
425
- self.class.run_start_notifications.each do |notification|
426
- notification.call(run_status)
427
- end
428
- events.run_started(run_status)
429
- end
430
-
431
- #
432
- # Callback to fire notifications that the run completed successfully
433
- #
434
- # @api private
435
- #
436
- def run_completed_successfully
437
- success_handlers = self.class.run_completed_successfully_notifications
438
- success_handlers.each do |notification|
439
- notification.call(run_status)
440
- end
441
- end
442
-
443
- #
444
- # Callback to fire notifications that the Chef run failed
445
- #
446
- # @api private
447
- #
448
- def run_failed
449
- failure_handlers = self.class.run_failed_notifications
450
- failure_handlers.each do |notification|
451
- notification.call(run_status)
452
- end
453
- end
454
-
455
- #
456
- # Instantiates a Chef::Node object, possibly loading the node's prior state
457
- # when using chef-client. Sets Chef.node to the new node.
458
- #
459
- # @return [Chef::Node] The node object for this Chef run
460
- #
461
- # @see Chef::PolicyBuilder#load_node
462
- #
463
- # @api private
464
- #
465
- def load_node
466
- policy_builder.load_node
467
- run_status.node = policy_builder.node
468
- Chef.set_node(policy_builder.node)
469
- node
470
- end
471
-
472
- #
473
- # Mutates the `node` object to prepare it for the chef run.
474
- #
475
- # @return [Chef::Node] The updated node object
476
- #
477
- # @see Chef::PolicyBuilder#build_node
478
- #
479
- # @api private
480
- #
481
- def build_node
482
- policy_builder.build_node
483
- run_status.node = node
484
- node
485
- end
486
-
487
- #
488
- # Sync cookbooks to local cache.
489
- #
490
- # TODO this appears to be unused.
491
- #
492
- # @see Chef::PolicyBuilder#sync_cookbooks
493
- #
494
- # @api private
495
- #
496
- def sync_cookbooks
497
- policy_builder.sync_cookbooks
498
- end
499
-
500
- #
501
- # Sets up the run context.
502
- #
503
- # @see Chef::PolicyBuilder#setup_run_context
504
- #
505
- # @return The newly set up run context
506
- #
507
- # @api private
508
- def setup_run_context
509
- run_context = policy_builder.setup_run_context(specific_recipes)
510
- assert_cookbook_path_not_empty(run_context)
511
- run_status.run_context = run_context
512
- run_context
513
- end
514
-
515
- #
516
- # The PolicyBuilder strategy for figuring out run list and cookbooks.
517
- #
518
- # @return [Chef::PolicyBuilder::Policyfile, Chef::PolicyBuilder::ExpandNodeObject]
519
- #
520
- # @api private
521
- #
522
- def policy_builder
523
- @policy_builder ||= Chef::PolicyBuilder::Dynamic.new(node_name, ohai.data, json_attribs, override_runlist, events)
524
- end
525
-
526
- #
527
- # Save the updated node to Chef.
528
- #
529
- # Does not save if we are in solo mode or using override_runlist.
530
- #
531
- # @see Chef::Node#save
532
- # @see Chef::Config#solo
533
- #
534
- # @api private
535
- #
536
- def save_updated_node
537
- if Chef::Config[:solo]
538
- # nothing to do
539
- elsif policy_builder.temporary_policy?
540
- Chef::Log.warn("Skipping final node save because override_runlist was given")
541
- else
542
- Chef::Log.debug("Saving the current state of node #{node_name}")
543
- node.save
544
- end
545
- end
546
-
547
- #
548
- # Run ohai plugins. Runs all ohai plugins unless minimal_ohai is specified.
549
- #
550
- # Sends the ohai_completed event when finished.
551
- #
552
- # @see Chef::EventDispatcher#
553
- # @see Chef::Config#minimal_ohai
554
- #
555
- # @api private
556
- #
557
- def run_ohai
558
- filter = Chef::Config[:minimal_ohai] ? %w{fqdn machinename hostname platform platform_version os os_version} : nil
559
- ohai.all_plugins(filter)
560
- events.ohai_completed(node)
561
- end
562
-
563
- #
564
- # Figure out the node name we are working with.
565
- #
566
- # It tries these, in order:
567
- # - Chef::Config.node_name
568
- # - ohai[:fqdn]
569
- # - ohai[:machinename]
570
- # - ohai[:hostname]
571
- #
572
- # @raise [Chef::Exceptions::CannotDetermineNodeName] If the node name is not
573
- # set and cannot be determined via ohai.
574
- #
575
- # @see Chef::Config#node_name
576
- #
577
- # @api private
578
- #
579
- def node_name
580
- name = Chef::Config[:node_name] || ohai[:fqdn] || ohai[:machinename] || ohai[:hostname]
581
- Chef::Config[:node_name] = name
582
-
583
- raise Chef::Exceptions::CannotDetermineNodeName unless name
584
-
585
- name
586
- end
587
-
588
- #
589
- # Determine our private key and set up the connection to the Chef server.
590
- #
591
- # Skips registration and fires the `skipping_registration` event if
592
- # Chef::Config.client_key is unspecified or already exists.
593
- #
594
- # If Chef::Config.client_key does not exist, we register the client with the
595
- # Chef server and fire the registration_start and registration_completed events.
596
- #
597
- # @return [Chef::ServerAPI] The server connection object.
598
- #
599
- # @see Chef::Config#chef_server_url
600
- # @see Chef::Config#client_key
601
- # @see Chef::ApiClient::Registration#run
602
- # @see Chef::EventDispatcher#skipping_registration
603
- # @see Chef::EventDispatcher#registration_start
604
- # @see Chef::EventDispatcher#registration_completed
605
- # @see Chef::EventDispatcher#registration_failed
606
- #
607
- # @api private
608
- #
609
- def register(client_name = node_name, config = Chef::Config)
610
- if !config[:client_key]
611
- events.skipping_registration(client_name, config)
612
- Chef::Log.debug("Client key is unspecified - skipping registration")
613
- elsif File.exists?(config[:client_key])
614
- events.skipping_registration(client_name, config)
615
- Chef::Log.debug("Client key #{config[:client_key]} is present - skipping registration")
616
- else
617
- events.registration_start(node_name, config)
618
- Chef::Log.info("Client key #{config[:client_key]} is not present - registering")
619
- Chef::ApiClient::Registration.new(node_name, config[:client_key]).run
620
- events.registration_completed
621
- end
622
- # We now have the client key, and should use it from now on.
623
- @rest = Chef::ServerAPI.new(config[:chef_server_url], client_name: client_name,
624
- signing_key_filename: config[:client_key])
625
- # force initialization of the rest_clean API object
626
- rest_clean(client_name, config)
627
- register_reporters
628
- rescue Exception => e
629
- # TODO this should probably only ever fire if we *started* registration.
630
- # Move it to the block above.
631
- # TODO: munge exception so a semantic failure message can be given to the
632
- # user
633
- events.registration_failed(client_name, e, config)
634
- raise
635
- end
636
-
637
- #
638
- # Converges all compiled resources.
639
- #
640
- # Fires the converge_start, converge_complete and converge_failed events.
641
- #
642
- # If the exception `:end_client_run_early` is thrown during convergence, it
643
- # does not mark the run complete *or* failed, and returns `nil`
644
- #
645
- # @param run_context The run context.
646
- #
647
- # @return The thrown exception, if we are in audit mode. `nil` means the
648
- # converge was successful or ended early.
649
- #
650
- # @raise Any converge exception, unless we are in audit mode, in which case
651
- # we *return* the exception.
652
- #
653
- # @see Chef::Runner#converge
654
- # @see Chef::Config#audit_mode
655
- # @see Chef::EventDispatch#converge_start
656
- # @see Chef::EventDispatch#converge_complete
657
- # @see Chef::EventDispatch#converge_failed
658
- #
659
- # @api private
660
- #
661
- def converge(run_context)
662
- converge_exception = nil
663
- catch(:end_client_run_early) do
664
- begin
665
- events.converge_start(run_context)
666
- Chef::Log.debug("Converging node #{node_name}")
667
- @runner = Chef::Runner.new(run_context)
668
- @runner.converge
669
- events.converge_complete
670
- rescue Exception => e
671
- events.converge_failed(e)
672
- raise e if Chef::Config[:audit_mode] == :disabled
673
- converge_exception = e
674
- end
675
- end
676
- converge_exception
677
- end
678
-
679
- #
680
- # Converge the node via and then save it if successful.
681
- #
682
- # @param run_context The run context.
683
- #
684
- # @return The thrown exception, if we are in audit mode. `nil` means the
685
- # converge was successful or ended early.
686
- #
687
- # @raise Any converge or node save exception, unless we are in audit mode,
688
- # in which case we *return* the exception.
689
- #
690
- # @see #converge
691
- # @see #save_updated_mode
692
- # @see Chef::Config#audit_mode
693
- #
694
- # @api private
695
- #
696
- # We don't want to change the old API on the `converge` method to have it perform
697
- # saving. So we wrap it in this method.
698
- # TODO given this seems to be pretty internal stuff, how badly do we need to
699
- # split this stuff up?
700
- #
701
- def converge_and_save(run_context)
702
- converge_exception = converge(run_context)
703
- unless converge_exception
704
- begin
705
- save_updated_node
706
- rescue Exception => e
707
- raise e if Chef::Config[:audit_mode] == :disabled
708
- converge_exception = e
709
- end
710
- end
711
- converge_exception
712
- end
713
-
714
- #
715
- # Run the audit phase.
716
- #
717
- # Triggers the audit_phase_start, audit_phase_complete and
718
- # audit_phase_failed events.
719
- #
720
- # @param run_context The run context.
721
- #
722
- # @return Any thrown exceptions. `nil` if successful.
723
- #
724
- # @see Chef::Audit::Runner#run
725
- # @see Chef::EventDispatch#audit_phase_start
726
- # @see Chef::EventDispatch#audit_phase_complete
727
- # @see Chef::EventDispatch#audit_phase_failed
728
- #
729
- # @api private
730
- #
731
- def run_audits(run_context)
732
- begin
733
- events.audit_phase_start(run_status)
734
- Chef::Log.info("Starting audit phase")
735
- auditor = Chef::Audit::Runner.new(run_context)
736
- auditor.run
737
- if auditor.failed?
738
- audit_exception = Chef::Exceptions::AuditsFailed.new(auditor.num_failed, auditor.num_total)
739
- @events.audit_phase_failed(audit_exception, Chef::Audit::Logger.read_buffer)
740
- else
741
- @events.audit_phase_complete(Chef::Audit::Logger.read_buffer)
742
- end
743
- rescue Exception => e
744
- Chef::Log.error("Audit phase failed with error message: #{e.message}")
745
- @events.audit_phase_failed(e, Chef::Audit::Logger.read_buffer)
746
- audit_exception = e
747
- end
748
- audit_exception
749
- end
750
-
751
- #
752
- # Expands the run list.
753
- #
754
- # @return [Chef::RunListExpansion] The expanded run list.
755
- #
756
- # @see Chef::PolicyBuilder#expand_run_list
757
- #
758
- def expanded_run_list
759
- policy_builder.expand_run_list
760
- end
761
-
762
- #
763
- # Check if the user has Administrator privileges on windows.
764
- #
765
- # Throws an error if the user is not an admin, and
766
- # `Chef::Config.fatal_windows_admin_check` is true.
767
- #
768
- # @raise [Chef::Exceptions::WindowsNotAdmin] If the user is not an admin.
769
- #
770
- # @see Chef::platform#windows?
771
- # @see Chef::Config#fatal_windows_admin_check
772
- #
773
- # @api private
774
- #
775
- def do_windows_admin_check
776
- if Chef::Platform.windows?
777
- Chef::Log.debug("Checking for administrator privileges....")
778
-
779
- if !has_admin_privileges?
780
- message = "chef-client doesn't have administrator privileges on node #{node_name}."
781
- if Chef::Config[:fatal_windows_admin_check]
782
- Chef::Log.fatal(message)
783
- Chef::Log.fatal("fatal_windows_admin_check is set to TRUE.")
784
- raise Chef::Exceptions::WindowsNotAdmin, message
785
- else
786
- Chef::Log.warn("#{message} This might cause unexpected resource failures.")
787
- end
788
- else
789
- Chef::Log.debug("chef-client has administrator privileges on node #{node_name}.")
790
- end
791
- end
792
- end
793
-
794
- # Notification registration
795
- class<<self
796
- #
797
- # Add a listener for the 'client run started' event.
798
- #
799
- # @param notification_block The callback (takes |run_status| parameter).
800
- # @yieldparam [Chef::RunStatus] run_status The run status.
801
- #
802
- def when_run_starts(&notification_block)
803
- run_start_notifications << notification_block
804
- end
805
-
806
- #
807
- # Add a listener for the 'client run success' event.
808
- #
809
- # @param notification_block The callback (takes |run_status| parameter).
810
- # @yieldparam [Chef::RunStatus] run_status The run status.
811
- #
812
- def when_run_completes_successfully(&notification_block)
813
- run_completed_successfully_notifications << notification_block
814
- end
815
-
816
- #
817
- # Add a listener for the 'client run failed' event.
818
- #
819
- # @param notification_block The callback (takes |run_status| parameter).
820
- # @yieldparam [Chef::RunStatus] run_status The run status.
821
- #
822
- def when_run_fails(&notification_block)
823
- run_failed_notifications << notification_block
824
- end
825
-
826
- #
827
- # Clears all listeners for client run status events.
828
- #
829
- # Primarily for testing purposes.
830
- #
831
- # @api private
832
- #
833
- def clear_notifications
834
- @run_start_notifications = nil
835
- @run_completed_successfully_notifications = nil
836
- @run_failed_notifications = nil
837
- end
838
-
839
- #
840
- # TODO These seem protected to me.
841
- #
842
-
843
- #
844
- # Listeners to be run when the client run starts.
845
- #
846
- # @return [Array<Proc>]
847
- #
848
- # @api private
849
- #
850
- def run_start_notifications
851
- @run_start_notifications ||= []
852
- end
853
-
854
- #
855
- # Listeners to be run when the client run completes successfully.
856
- #
857
- # @return [Array<Proc>]
858
- #
859
- # @api private
860
- #
861
- def run_completed_successfully_notifications
862
- @run_completed_successfully_notifications ||= []
863
- end
864
-
865
- #
866
- # Listeners to be run when the client run fails.
867
- #
868
- # @return [Array<Proc>]
869
- #
870
- # @api private
871
- #
872
- def run_failed_notifications
873
- @run_failed_notifications ||= []
874
- end
875
- end
876
-
877
- #
878
- # IO stream that will be used as 'STDOUT' for formatters. Formatters are
879
- # configured during `initialize`, so this provides a convenience for
880
- # setting alternative IO stream during tests.
881
- #
882
- # @api private
883
- #
884
- STDOUT_FD = STDOUT
885
-
886
- #
887
- # IO stream that will be used as 'STDERR' for formatters. Formatters are
888
- # configured during `initialize`, so this provides a convenience for
889
- # setting alternative IO stream during tests.
890
- #
891
- # @api private
892
- #
893
- STDERR_FD = STDERR
894
-
895
- #
896
- # Deprecated writers
897
- #
898
-
899
- include Chef::Mixin::Deprecation
900
- deprecated_attr_writer :ohai, "There is no alternative. Leave ohai alone!"
901
- deprecated_attr_writer :rest, "There is no alternative. Leave rest alone!"
902
- deprecated_attr :runner, "There is no alternative. Leave runner alone!"
903
-
904
- private
905
-
906
- attr_reader :override_runlist
907
- attr_reader :specific_recipes
908
-
909
- def profiling_prereqs!
910
- require "ruby-prof"
911
- rescue LoadError
912
- raise "You must have the ruby-prof gem installed in order to use --profile-ruby"
913
- end
914
-
915
- def start_profiling
916
- return unless Chef::Config[:profile_ruby]
917
- profiling_prereqs!
918
- RubyProf.start
919
- end
920
-
921
- def end_profiling
922
- return unless Chef::Config[:profile_ruby]
923
- profiling_prereqs!
924
- path = Chef::FileCache.create_cache_path("graph_profile.out", false)
925
- File.open(path, "w+") do |file|
926
- RubyProf::GraphPrinter.new(RubyProf.stop).print(file, {})
927
- end
928
- Chef::Log.warn("Ruby execution profile dumped to #{path}")
929
- end
930
-
931
- def empty_directory?(path)
932
- !File.exists?(path) || (Dir.entries(path).size <= 2)
933
- end
934
-
935
- def is_last_element?(index, object)
936
- object.kind_of?(Array) ? index == object.size - 1 : true
937
- end
938
-
939
- def assert_cookbook_path_not_empty(run_context)
940
- if Chef::Config[:solo]
941
- # Check for cookbooks in the path given
942
- # Chef::Config[:cookbook_path] can be a string or an array
943
- # if it's an array, go through it and check each one, raise error at the last one if no files are found
944
- cookbook_paths = Array(Chef::Config[:cookbook_path])
945
- Chef::Log.debug "Loading from cookbook_path: #{cookbook_paths.map { |path| File.expand_path(path) }.join(', ')}"
946
- if cookbook_paths.all? { |path| empty_directory?(path) }
947
- msg = "None of the cookbook paths set in Chef::Config[:cookbook_path], #{cookbook_paths.inspect}, contain any cookbooks"
948
- Chef::Log.fatal(msg)
949
- raise Chef::Exceptions::CookbookNotFound, msg
950
- end
951
- else
952
- Chef::Log.warn("Node #{node_name} has an empty run list.") if run_context.node.run_list.empty?
953
- end
954
- end
955
-
956
- def has_admin_privileges?
957
- require "chef/win32/security"
958
-
959
- Chef::ReservedNames::Win32::Security.has_admin_privileges?
960
- end
961
- end
962
- end
963
-
964
- # HACK cannot load this first, but it must be loaded.
965
- require "chef/cookbook_loader"
966
- require "chef/cookbook_version"
967
- require "chef/cookbook/synchronizer"
1
+ #
2
+ # Author:: Adam Jacob (<adam@chef.io>)
3
+ # Author:: Christopher Walters (<cw@chef.io>)
4
+ # Author:: Christopher Brown (<cb@chef.io>)
5
+ # Author:: Tim Hinderliter (<tim@chef.io>)
6
+ # Copyright:: Copyright 2008-2016, Chef Software, Inc.
7
+ # License:: Apache License, Version 2.0
8
+ #
9
+ # Licensed under the Apache License, Version 2.0 (the "License");
10
+ # you may not use this file except in compliance with the License.
11
+ # You may obtain a copy of the License at
12
+ #
13
+ # http://www.apache.org/licenses/LICENSE-2.0
14
+ #
15
+ # Unless required by applicable law or agreed to in writing, software
16
+ # distributed under the License is distributed on an "AS IS" BASIS,
17
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18
+ # See the License for the specific language governing permissions and
19
+ # limitations under the License.
20
+
21
+ require "chef/config"
22
+ require "chef/mixin/params_validate"
23
+ require "chef/mixin/path_sanity"
24
+ require "chef/log"
25
+ require "chef/server_api"
26
+ require "chef/api_client"
27
+ require "chef/api_client/registration"
28
+ require "chef/audit/runner"
29
+ require "chef/node"
30
+ require "chef/role"
31
+ require "chef/file_cache"
32
+ require "chef/run_context"
33
+ require "chef/runner"
34
+ require "chef/run_status"
35
+ require "chef/cookbook/cookbook_collection"
36
+ require "chef/cookbook/file_vendor"
37
+ require "chef/cookbook/file_system_file_vendor"
38
+ require "chef/cookbook/remote_file_vendor"
39
+ require "chef/event_dispatch/dispatcher"
40
+ require "chef/event_loggers/base"
41
+ require "chef/event_loggers/windows_eventlog"
42
+ require "chef/exceptions"
43
+ require "chef/formatters/base"
44
+ require "chef/formatters/doc"
45
+ require "chef/formatters/minimal"
46
+ require "chef/version"
47
+ require "chef/resource_reporter"
48
+ require "chef/audit/audit_reporter"
49
+ require "chef/run_lock"
50
+ require "chef/policy_builder"
51
+ require "chef/request_id"
52
+ require "chef/platform/rebooter"
53
+ require "chef/mixin/deprecation"
54
+ require "ohai"
55
+ require "rbconfig"
56
+
57
+ class Chef
58
+ # == Chef::Client
59
+ # The main object in a Chef run. Preps a Chef::Node and Chef::RunContext,
60
+ # syncs cookbooks if necessary, and triggers convergence.
61
+ class Client
62
+ include Chef::Mixin::PathSanity
63
+
64
+ extend Chef::Mixin::Deprecation
65
+
66
+ #
67
+ # The status of the Chef run.
68
+ #
69
+ # @return [Chef::RunStatus]
70
+ #
71
+ attr_reader :run_status
72
+
73
+ #
74
+ # The node represented by this client.
75
+ #
76
+ # @return [Chef::Node]
77
+ #
78
+ def node
79
+ run_status.node
80
+ end
81
+
82
+ def node=(value)
83
+ run_status.node = value
84
+ end
85
+
86
+ #
87
+ # The ohai system used by this client.
88
+ #
89
+ # @return [Ohai::System]
90
+ #
91
+ attr_reader :ohai
92
+
93
+ #
94
+ # The rest object used to communicate with the Chef server.
95
+ #
96
+ # @return [Chef::ServerAPI]
97
+ #
98
+ attr_reader :rest
99
+
100
+ #
101
+ # A rest object with validate_utf8 set to false. This will not throw exceptions
102
+ # on non-UTF8 strings in JSON but will sanitize them so that e.g. POSTs will
103
+ # never fail. Cannot be configured on a request-by-request basis, so we carry
104
+ # around another rest object for it.
105
+ #
106
+ attr_reader :rest_clean
107
+
108
+ #
109
+ # The runner used to converge.
110
+ #
111
+ # @return [Chef::Runner]
112
+ #
113
+ attr_accessor :runner
114
+
115
+ #
116
+ # Extra node attributes that were applied to the node.
117
+ #
118
+ # @return [Hash]
119
+ #
120
+ attr_reader :json_attribs
121
+
122
+ #
123
+ # The event dispatcher for the Chef run, including any configured output
124
+ # formatters and event loggers.
125
+ #
126
+ # @return [EventDispatch::Dispatcher]
127
+ #
128
+ # @see Chef::Formatters
129
+ # @see Chef::Config#formatters
130
+ # @see Chef::Config#stdout
131
+ # @see Chef::Config#stderr
132
+ # @see Chef::Config#force_logger
133
+ # @see Chef::Config#force_formatter
134
+ # TODO add stdout, stderr, and default formatters to Chef::Config so the
135
+ # defaults aren't calculated here. Remove force_logger and force_formatter
136
+ # from this code.
137
+ # @see Chef::EventLoggers
138
+ # @see Chef::Config#disable_event_logger
139
+ # @see Chef::Config#event_loggers
140
+ # @see Chef::Config#event_handlers
141
+ #
142
+ attr_reader :events
143
+
144
+ #
145
+ # Creates a new Chef::Client.
146
+ #
147
+ # @param json_attribs [Hash] Node attributes to layer into the node when it is
148
+ # fetched.
149
+ # @param args [Hash] Options:
150
+ # @option args [Array<RunList::RunListItem>] :override_runlist A runlist to
151
+ # use instead of the node's embedded run list.
152
+ # @option args [Array<String>] :specific_recipes A list of recipe file paths
153
+ # to load after the run list has been loaded.
154
+ #
155
+ def initialize(json_attribs = nil, args = {})
156
+ @json_attribs = json_attribs || {}
157
+ @ohai = Ohai::System.new
158
+
159
+ event_handlers = configure_formatters + configure_event_loggers
160
+ event_handlers += Array(Chef::Config[:event_handlers])
161
+
162
+ @events = EventDispatch::Dispatcher.new(*event_handlers)
163
+ # TODO it seems like a bad idea to be deletin' other peoples' hashes.
164
+ @override_runlist = args.delete(:override_runlist)
165
+ @specific_recipes = args.delete(:specific_recipes)
166
+ @run_status = Chef::RunStatus.new(nil, events)
167
+
168
+ if new_runlist = args.delete(:runlist)
169
+ @json_attribs["run_list"] = new_runlist
170
+ end
171
+ end
172
+
173
+ #
174
+ # Do a full run for this Chef::Client.
175
+ #
176
+ # Locks the run while doing its job.
177
+ #
178
+ # Fires run_start before doing anything and fires run_completed or
179
+ # run_failed when finished. Also notifies client listeners of run_started
180
+ # at the beginning of Compile, and run_completed_successfully or run_failed
181
+ # when all is complete.
182
+ #
183
+ # Phase 1: Setup
184
+ # --------------
185
+ # Gets information about the system and the run we are doing.
186
+ #
187
+ # 1. Run ohai to collect system information.
188
+ # 2. Register / connect to the Chef server (unless in solo mode).
189
+ # 3. Retrieve the node (or create a new one).
190
+ # 4. Merge in json_attribs, Chef::Config.environment, and override_run_list.
191
+ #
192
+ # @see #run_ohai
193
+ # @see #load_node
194
+ # @see #build_node
195
+ # @see Chef::Config#lockfile
196
+ # @see Chef::RunLock#acquire
197
+ #
198
+ # Phase 2: Compile
199
+ # ----------------
200
+ # Decides *what* we plan to converge by compiling recipes.
201
+ #
202
+ # 1. Sync required cookbooks to the local cache.
203
+ # 2. Load libraries from all cookbooks.
204
+ # 3. Load attributes from all cookbooks.
205
+ # 4. Load LWRPs from all cookbooks.
206
+ # 5. Load resource definitions from all cookbooks.
207
+ # 6. Load recipes in the run list.
208
+ # 7. Load recipes from the command line.
209
+ #
210
+ # @see #setup_run_context Syncs and compiles cookbooks.
211
+ # @see Chef::CookbookCompiler#compile
212
+ #
213
+ # Phase 3: Converge
214
+ # -----------------
215
+ # Brings the system up to date.
216
+ #
217
+ # 1. Converge the resources built from recipes in Phase 2.
218
+ # 2. Save the node.
219
+ # 3. Reboot if we were asked to.
220
+ #
221
+ # @see #converge_and_save
222
+ # @see Chef::Runner
223
+ #
224
+ # Phase 4: Audit
225
+ # --------------
226
+ # Runs 'control_group' audits in recipes. This entire section can be enabled or disabled with config.
227
+ #
228
+ # 1. 'control_group' DSL collects audits during Phase 2
229
+ # 2. Audits are run using RSpec
230
+ # 3. Errors are collected and reported using the formatters
231
+ #
232
+ # @see #run_audits
233
+ # @see Chef::Audit::Runner#run
234
+ #
235
+ # @raise [Chef::Exceptions::RunFailedWrappingError] If converge or audit failed.
236
+ #
237
+ # @see Chef::Config#enforce_path_sanity
238
+ # @see Chef::Config#solo
239
+ # @see Chef::Config#audit_mode
240
+ #
241
+ # @return Always returns true.
242
+ #
243
+ def run
244
+ start_profiling
245
+
246
+ run_error = nil
247
+
248
+ runlock = RunLock.new(Chef::Config.lockfile)
249
+ # TODO feels like acquire should have its own block arg for this
250
+ runlock.acquire
251
+ # don't add code that may fail before entering this section to be sure to release lock
252
+ begin
253
+ runlock.save_pid
254
+
255
+ request_id = Chef::RequestID.instance.request_id
256
+ run_context = nil
257
+ events.run_start(Chef::VERSION)
258
+ Chef::Log.info("*** Chef #{Chef::VERSION} ***")
259
+ Chef::Log.info "Chef-client pid: #{Process.pid}"
260
+ Chef::Log.debug("Chef-client request_id: #{request_id}")
261
+ enforce_path_sanity
262
+ run_ohai
263
+
264
+ register unless Chef::Config[:solo]
265
+
266
+ load_node
267
+
268
+ build_node
269
+
270
+ run_status.run_id = request_id
271
+ run_status.start_clock
272
+ Chef::Log.info("Starting Chef Run for #{node.name}")
273
+ run_started
274
+
275
+ do_windows_admin_check
276
+
277
+ run_context = setup_run_context
278
+
279
+ if Chef::Config[:audit_mode] != :audit_only
280
+ converge_error = converge_and_save(run_context)
281
+ end
282
+
283
+ if Chef::Config[:why_run] == true
284
+ # why_run should probably be renamed to why_converge
285
+ Chef::Log.debug("Not running controls in 'why-run' mode - this mode is used to see potential converge changes")
286
+ elsif Chef::Config[:audit_mode] != :disabled
287
+ audit_error = run_audits(run_context)
288
+ end
289
+
290
+ # Raise converge_error so run_failed reporters/events are processed.
291
+ raise converge_error if converge_error
292
+
293
+ run_status.stop_clock
294
+ Chef::Log.info("Chef Run complete in #{run_status.elapsed_time} seconds")
295
+ run_completed_successfully
296
+ events.run_completed(node)
297
+
298
+ # keep this inside the main loop to get exception backtraces
299
+ end_profiling
300
+
301
+ # rebooting has to be the last thing we do, no exceptions.
302
+ Chef::Platform::Rebooter.reboot_if_needed!(node)
303
+ rescue Exception => run_error
304
+ # CHEF-3336: Send the error first in case something goes wrong below and we don't know why
305
+ Chef::Log.debug("Re-raising exception: #{run_error.class} - #{run_error.message}\n#{run_error.backtrace.join("\n ")}")
306
+ # If we failed really early, we may not have a run_status yet. Too early for these to be of much use.
307
+ if run_status
308
+ run_status.stop_clock
309
+ run_status.exception = run_error
310
+ run_failed
311
+ end
312
+ events.run_failed(run_error)
313
+ ensure
314
+ Chef::RequestID.instance.reset_request_id
315
+ request_id = nil
316
+ @run_status = nil
317
+ run_context = nil
318
+ runlock.release
319
+ end
320
+
321
+ # Raise audit, converge, and other errors here so that we exit
322
+ # with the proper exit status code and everything gets raised
323
+ # as a RunFailedWrappingError
324
+ if run_error || converge_error || audit_error
325
+ error = if Chef::Config[:audit_mode] == :disabled
326
+ run_error || converge_error
327
+ else
328
+ e = if run_error == converge_error
329
+ Chef::Exceptions::RunFailedWrappingError.new(converge_error, audit_error)
330
+ else
331
+ Chef::Exceptions::RunFailedWrappingError.new(run_error, converge_error, audit_error)
332
+ end
333
+ e.fill_backtrace
334
+ e
335
+ end
336
+
337
+ Chef::Application.debug_stacktrace(error)
338
+ raise error
339
+ end
340
+
341
+ true
342
+ end
343
+
344
+ #
345
+ # Private API
346
+ # TODO make this stuff protected or private
347
+ #
348
+
349
+ # @api private
350
+ def configure_formatters
351
+ formatters_for_run.map do |formatter_name, output_path|
352
+ if output_path.nil?
353
+ Chef::Formatters.new(formatter_name, STDOUT_FD, STDERR_FD)
354
+ else
355
+ io = File.open(output_path, "a+")
356
+ io.sync = true
357
+ Chef::Formatters.new(formatter_name, io, io)
358
+ end
359
+ end
360
+ end
361
+
362
+ # @api private
363
+ def formatters_for_run
364
+ if Chef::Config.formatters.empty?
365
+ [default_formatter]
366
+ else
367
+ Chef::Config.formatters
368
+ end
369
+ end
370
+
371
+ # @api private
372
+ def default_formatter
373
+ if (STDOUT.tty? && !Chef::Config[:force_logger]) || Chef::Config[:force_formatter]
374
+ [:doc]
375
+ else
376
+ [:null]
377
+ end
378
+ end
379
+
380
+ # @api private
381
+ def configure_event_loggers
382
+ if Chef::Config.disable_event_logger
383
+ []
384
+ else
385
+ Chef::Config.event_loggers.map do |evt_logger|
386
+ case evt_logger
387
+ when Symbol
388
+ Chef::EventLoggers.new(evt_logger)
389
+ when Class
390
+ evt_logger.new
391
+ else
392
+ end
393
+ end
394
+ end
395
+ end
396
+
397
+ # Rest client for use by API reporters. This rest client will not fail with an exception if
398
+ # it is fed non-UTF8 data.
399
+ #
400
+ # @api private
401
+ def rest_clean(client_name = node_name, config = Chef::Config)
402
+ @rest_clean ||=
403
+ Chef::ServerAPI.new(config[:chef_server_url], client_name: client_name,
404
+ signing_key_filename: config[:client_key], validate_utf8: false)
405
+ end
406
+
407
+ # Resource reporters send event information back to the chef server for
408
+ # processing. Can only be called after we have a @rest object
409
+ # @api private
410
+ def register_reporters
411
+ [
412
+ Chef::ResourceReporter.new(rest_clean),
413
+ Chef::Audit::AuditReporter.new(rest_clean),
414
+ ].each do |r|
415
+ events.register(r)
416
+ end
417
+ end
418
+
419
+ #
420
+ # Callback to fire notifications that the Chef run is starting
421
+ #
422
+ # @api private
423
+ #
424
+ def run_started
425
+ self.class.run_start_notifications.each do |notification|
426
+ notification.call(run_status)
427
+ end
428
+ events.run_started(run_status)
429
+ end
430
+
431
+ #
432
+ # Callback to fire notifications that the run completed successfully
433
+ #
434
+ # @api private
435
+ #
436
+ def run_completed_successfully
437
+ success_handlers = self.class.run_completed_successfully_notifications
438
+ success_handlers.each do |notification|
439
+ notification.call(run_status)
440
+ end
441
+ end
442
+
443
+ #
444
+ # Callback to fire notifications that the Chef run failed
445
+ #
446
+ # @api private
447
+ #
448
+ def run_failed
449
+ failure_handlers = self.class.run_failed_notifications
450
+ failure_handlers.each do |notification|
451
+ notification.call(run_status)
452
+ end
453
+ end
454
+
455
+ #
456
+ # Instantiates a Chef::Node object, possibly loading the node's prior state
457
+ # when using chef-client. Sets Chef.node to the new node.
458
+ #
459
+ # @return [Chef::Node] The node object for this Chef run
460
+ #
461
+ # @see Chef::PolicyBuilder#load_node
462
+ #
463
+ # @api private
464
+ #
465
+ def load_node
466
+ policy_builder.load_node
467
+ run_status.node = policy_builder.node
468
+ Chef.set_node(policy_builder.node)
469
+ node
470
+ end
471
+
472
+ #
473
+ # Mutates the `node` object to prepare it for the chef run.
474
+ #
475
+ # @return [Chef::Node] The updated node object
476
+ #
477
+ # @see Chef::PolicyBuilder#build_node
478
+ #
479
+ # @api private
480
+ #
481
+ def build_node
482
+ policy_builder.build_node
483
+ run_status.node = node
484
+ node
485
+ end
486
+
487
+ #
488
+ # Sync cookbooks to local cache.
489
+ #
490
+ # TODO this appears to be unused.
491
+ #
492
+ # @see Chef::PolicyBuilder#sync_cookbooks
493
+ #
494
+ # @api private
495
+ #
496
+ def sync_cookbooks
497
+ policy_builder.sync_cookbooks
498
+ end
499
+
500
+ #
501
+ # Sets up the run context.
502
+ #
503
+ # @see Chef::PolicyBuilder#setup_run_context
504
+ #
505
+ # @return The newly set up run context
506
+ #
507
+ # @api private
508
+ def setup_run_context
509
+ run_context = policy_builder.setup_run_context(specific_recipes)
510
+ assert_cookbook_path_not_empty(run_context)
511
+ run_status.run_context = run_context
512
+ run_context
513
+ end
514
+
515
+ #
516
+ # The PolicyBuilder strategy for figuring out run list and cookbooks.
517
+ #
518
+ # @return [Chef::PolicyBuilder::Policyfile, Chef::PolicyBuilder::ExpandNodeObject]
519
+ #
520
+ # @api private
521
+ #
522
+ def policy_builder
523
+ @policy_builder ||= Chef::PolicyBuilder::Dynamic.new(node_name, ohai.data, json_attribs, override_runlist, events)
524
+ end
525
+
526
+ #
527
+ # Save the updated node to Chef.
528
+ #
529
+ # Does not save if we are in solo mode or using override_runlist.
530
+ #
531
+ # @see Chef::Node#save
532
+ # @see Chef::Config#solo
533
+ #
534
+ # @api private
535
+ #
536
+ def save_updated_node
537
+ if Chef::Config[:solo]
538
+ # nothing to do
539
+ elsif policy_builder.temporary_policy?
540
+ Chef::Log.warn("Skipping final node save because override_runlist was given")
541
+ else
542
+ Chef::Log.debug("Saving the current state of node #{node_name}")
543
+ node.save
544
+ end
545
+ end
546
+
547
+ #
548
+ # Run ohai plugins. Runs all ohai plugins unless minimal_ohai is specified.
549
+ #
550
+ # Sends the ohai_completed event when finished.
551
+ #
552
+ # @see Chef::EventDispatcher#
553
+ # @see Chef::Config#minimal_ohai
554
+ #
555
+ # @api private
556
+ #
557
+ def run_ohai
558
+ filter = Chef::Config[:minimal_ohai] ? %w{fqdn machinename hostname platform platform_version os os_version} : nil
559
+ ohai.all_plugins(filter)
560
+ events.ohai_completed(node)
561
+ end
562
+
563
+ #
564
+ # Figure out the node name we are working with.
565
+ #
566
+ # It tries these, in order:
567
+ # - Chef::Config.node_name
568
+ # - ohai[:fqdn]
569
+ # - ohai[:machinename]
570
+ # - ohai[:hostname]
571
+ #
572
+ # @raise [Chef::Exceptions::CannotDetermineNodeName] If the node name is not
573
+ # set and cannot be determined via ohai.
574
+ #
575
+ # @see Chef::Config#node_name
576
+ #
577
+ # @api private
578
+ #
579
+ def node_name
580
+ name = Chef::Config[:node_name] || ohai[:fqdn] || ohai[:machinename] || ohai[:hostname]
581
+ Chef::Config[:node_name] = name
582
+
583
+ raise Chef::Exceptions::CannotDetermineNodeName unless name
584
+
585
+ name
586
+ end
587
+
588
+ #
589
+ # Determine our private key and set up the connection to the Chef server.
590
+ #
591
+ # Skips registration and fires the `skipping_registration` event if
592
+ # Chef::Config.client_key is unspecified or already exists.
593
+ #
594
+ # If Chef::Config.client_key does not exist, we register the client with the
595
+ # Chef server and fire the registration_start and registration_completed events.
596
+ #
597
+ # @return [Chef::ServerAPI] The server connection object.
598
+ #
599
+ # @see Chef::Config#chef_server_url
600
+ # @see Chef::Config#client_key
601
+ # @see Chef::ApiClient::Registration#run
602
+ # @see Chef::EventDispatcher#skipping_registration
603
+ # @see Chef::EventDispatcher#registration_start
604
+ # @see Chef::EventDispatcher#registration_completed
605
+ # @see Chef::EventDispatcher#registration_failed
606
+ #
607
+ # @api private
608
+ #
609
+ def register(client_name = node_name, config = Chef::Config)
610
+ if !config[:client_key]
611
+ events.skipping_registration(client_name, config)
612
+ Chef::Log.debug("Client key is unspecified - skipping registration")
613
+ elsif File.exists?(config[:client_key])
614
+ events.skipping_registration(client_name, config)
615
+ Chef::Log.debug("Client key #{config[:client_key]} is present - skipping registration")
616
+ else
617
+ events.registration_start(node_name, config)
618
+ Chef::Log.info("Client key #{config[:client_key]} is not present - registering")
619
+ Chef::ApiClient::Registration.new(node_name, config[:client_key]).run
620
+ events.registration_completed
621
+ end
622
+ # We now have the client key, and should use it from now on.
623
+ @rest = Chef::ServerAPI.new(config[:chef_server_url], client_name: client_name,
624
+ signing_key_filename: config[:client_key])
625
+ # force initialization of the rest_clean API object
626
+ rest_clean(client_name, config)
627
+ register_reporters
628
+ rescue Exception => e
629
+ # TODO this should probably only ever fire if we *started* registration.
630
+ # Move it to the block above.
631
+ # TODO: munge exception so a semantic failure message can be given to the
632
+ # user
633
+ events.registration_failed(client_name, e, config)
634
+ raise
635
+ end
636
+
637
+ #
638
+ # Converges all compiled resources.
639
+ #
640
+ # Fires the converge_start, converge_complete and converge_failed events.
641
+ #
642
+ # If the exception `:end_client_run_early` is thrown during convergence, it
643
+ # does not mark the run complete *or* failed, and returns `nil`
644
+ #
645
+ # @param run_context The run context.
646
+ #
647
+ # @return The thrown exception, if we are in audit mode. `nil` means the
648
+ # converge was successful or ended early.
649
+ #
650
+ # @raise Any converge exception, unless we are in audit mode, in which case
651
+ # we *return* the exception.
652
+ #
653
+ # @see Chef::Runner#converge
654
+ # @see Chef::Config#audit_mode
655
+ # @see Chef::EventDispatch#converge_start
656
+ # @see Chef::EventDispatch#converge_complete
657
+ # @see Chef::EventDispatch#converge_failed
658
+ #
659
+ # @api private
660
+ #
661
+ def converge(run_context)
662
+ converge_exception = nil
663
+ catch(:end_client_run_early) do
664
+ begin
665
+ events.converge_start(run_context)
666
+ Chef::Log.debug("Converging node #{node_name}")
667
+ @runner = Chef::Runner.new(run_context)
668
+ @runner.converge
669
+ events.converge_complete
670
+ rescue Exception => e
671
+ events.converge_failed(e)
672
+ raise e if Chef::Config[:audit_mode] == :disabled
673
+ converge_exception = e
674
+ end
675
+ end
676
+ converge_exception
677
+ end
678
+
679
+ #
680
+ # Converge the node via and then save it if successful.
681
+ #
682
+ # @param run_context The run context.
683
+ #
684
+ # @return The thrown exception, if we are in audit mode. `nil` means the
685
+ # converge was successful or ended early.
686
+ #
687
+ # @raise Any converge or node save exception, unless we are in audit mode,
688
+ # in which case we *return* the exception.
689
+ #
690
+ # @see #converge
691
+ # @see #save_updated_mode
692
+ # @see Chef::Config#audit_mode
693
+ #
694
+ # @api private
695
+ #
696
+ # We don't want to change the old API on the `converge` method to have it perform
697
+ # saving. So we wrap it in this method.
698
+ # TODO given this seems to be pretty internal stuff, how badly do we need to
699
+ # split this stuff up?
700
+ #
701
+ def converge_and_save(run_context)
702
+ converge_exception = converge(run_context)
703
+ unless converge_exception
704
+ begin
705
+ save_updated_node
706
+ rescue Exception => e
707
+ raise e if Chef::Config[:audit_mode] == :disabled
708
+ converge_exception = e
709
+ end
710
+ end
711
+ converge_exception
712
+ end
713
+
714
+ #
715
+ # Run the audit phase.
716
+ #
717
+ # Triggers the audit_phase_start, audit_phase_complete and
718
+ # audit_phase_failed events.
719
+ #
720
+ # @param run_context The run context.
721
+ #
722
+ # @return Any thrown exceptions. `nil` if successful.
723
+ #
724
+ # @see Chef::Audit::Runner#run
725
+ # @see Chef::EventDispatch#audit_phase_start
726
+ # @see Chef::EventDispatch#audit_phase_complete
727
+ # @see Chef::EventDispatch#audit_phase_failed
728
+ #
729
+ # @api private
730
+ #
731
+ def run_audits(run_context)
732
+ begin
733
+ events.audit_phase_start(run_status)
734
+ Chef::Log.info("Starting audit phase")
735
+ auditor = Chef::Audit::Runner.new(run_context)
736
+ auditor.run
737
+ if auditor.failed?
738
+ audit_exception = Chef::Exceptions::AuditsFailed.new(auditor.num_failed, auditor.num_total)
739
+ @events.audit_phase_failed(audit_exception, Chef::Audit::Logger.read_buffer)
740
+ else
741
+ @events.audit_phase_complete(Chef::Audit::Logger.read_buffer)
742
+ end
743
+ rescue Exception => e
744
+ Chef::Log.error("Audit phase failed with error message: #{e.message}")
745
+ @events.audit_phase_failed(e, Chef::Audit::Logger.read_buffer)
746
+ audit_exception = e
747
+ end
748
+ audit_exception
749
+ end
750
+
751
+ #
752
+ # Expands the run list.
753
+ #
754
+ # @return [Chef::RunListExpansion] The expanded run list.
755
+ #
756
+ # @see Chef::PolicyBuilder#expand_run_list
757
+ #
758
+ def expanded_run_list
759
+ policy_builder.expand_run_list
760
+ end
761
+
762
+ #
763
+ # Check if the user has Administrator privileges on windows.
764
+ #
765
+ # Throws an error if the user is not an admin, and
766
+ # `Chef::Config.fatal_windows_admin_check` is true.
767
+ #
768
+ # @raise [Chef::Exceptions::WindowsNotAdmin] If the user is not an admin.
769
+ #
770
+ # @see Chef::platform#windows?
771
+ # @see Chef::Config#fatal_windows_admin_check
772
+ #
773
+ # @api private
774
+ #
775
+ def do_windows_admin_check
776
+ if Chef::Platform.windows?
777
+ Chef::Log.debug("Checking for administrator privileges....")
778
+
779
+ if !has_admin_privileges?
780
+ message = "chef-client doesn't have administrator privileges on node #{node_name}."
781
+ if Chef::Config[:fatal_windows_admin_check]
782
+ Chef::Log.fatal(message)
783
+ Chef::Log.fatal("fatal_windows_admin_check is set to TRUE.")
784
+ raise Chef::Exceptions::WindowsNotAdmin, message
785
+ else
786
+ Chef::Log.warn("#{message} This might cause unexpected resource failures.")
787
+ end
788
+ else
789
+ Chef::Log.debug("chef-client has administrator privileges on node #{node_name}.")
790
+ end
791
+ end
792
+ end
793
+
794
+ # Notification registration
795
+ class<<self
796
+ #
797
+ # Add a listener for the 'client run started' event.
798
+ #
799
+ # @param notification_block The callback (takes |run_status| parameter).
800
+ # @yieldparam [Chef::RunStatus] run_status The run status.
801
+ #
802
+ def when_run_starts(&notification_block)
803
+ run_start_notifications << notification_block
804
+ end
805
+
806
+ #
807
+ # Add a listener for the 'client run success' event.
808
+ #
809
+ # @param notification_block The callback (takes |run_status| parameter).
810
+ # @yieldparam [Chef::RunStatus] run_status The run status.
811
+ #
812
+ def when_run_completes_successfully(&notification_block)
813
+ run_completed_successfully_notifications << notification_block
814
+ end
815
+
816
+ #
817
+ # Add a listener for the 'client run failed' event.
818
+ #
819
+ # @param notification_block The callback (takes |run_status| parameter).
820
+ # @yieldparam [Chef::RunStatus] run_status The run status.
821
+ #
822
+ def when_run_fails(&notification_block)
823
+ run_failed_notifications << notification_block
824
+ end
825
+
826
+ #
827
+ # Clears all listeners for client run status events.
828
+ #
829
+ # Primarily for testing purposes.
830
+ #
831
+ # @api private
832
+ #
833
+ def clear_notifications
834
+ @run_start_notifications = nil
835
+ @run_completed_successfully_notifications = nil
836
+ @run_failed_notifications = nil
837
+ end
838
+
839
+ #
840
+ # TODO These seem protected to me.
841
+ #
842
+
843
+ #
844
+ # Listeners to be run when the client run starts.
845
+ #
846
+ # @return [Array<Proc>]
847
+ #
848
+ # @api private
849
+ #
850
+ def run_start_notifications
851
+ @run_start_notifications ||= []
852
+ end
853
+
854
+ #
855
+ # Listeners to be run when the client run completes successfully.
856
+ #
857
+ # @return [Array<Proc>]
858
+ #
859
+ # @api private
860
+ #
861
+ def run_completed_successfully_notifications
862
+ @run_completed_successfully_notifications ||= []
863
+ end
864
+
865
+ #
866
+ # Listeners to be run when the client run fails.
867
+ #
868
+ # @return [Array<Proc>]
869
+ #
870
+ # @api private
871
+ #
872
+ def run_failed_notifications
873
+ @run_failed_notifications ||= []
874
+ end
875
+ end
876
+
877
+ #
878
+ # IO stream that will be used as 'STDOUT' for formatters. Formatters are
879
+ # configured during `initialize`, so this provides a convenience for
880
+ # setting alternative IO stream during tests.
881
+ #
882
+ # @api private
883
+ #
884
+ STDOUT_FD = STDOUT
885
+
886
+ #
887
+ # IO stream that will be used as 'STDERR' for formatters. Formatters are
888
+ # configured during `initialize`, so this provides a convenience for
889
+ # setting alternative IO stream during tests.
890
+ #
891
+ # @api private
892
+ #
893
+ STDERR_FD = STDERR
894
+
895
+ #
896
+ # Deprecated writers
897
+ #
898
+
899
+ include Chef::Mixin::Deprecation
900
+ deprecated_attr_writer :ohai, "There is no alternative. Leave ohai alone!"
901
+ deprecated_attr_writer :rest, "There is no alternative. Leave rest alone!"
902
+ deprecated_attr :runner, "There is no alternative. Leave runner alone!"
903
+
904
+ private
905
+
906
+ attr_reader :override_runlist
907
+ attr_reader :specific_recipes
908
+
909
+ def profiling_prereqs!
910
+ require "ruby-prof"
911
+ rescue LoadError
912
+ raise "You must have the ruby-prof gem installed in order to use --profile-ruby"
913
+ end
914
+
915
+ def start_profiling
916
+ return unless Chef::Config[:profile_ruby]
917
+ profiling_prereqs!
918
+ RubyProf.start
919
+ end
920
+
921
+ def end_profiling
922
+ return unless Chef::Config[:profile_ruby]
923
+ profiling_prereqs!
924
+ path = Chef::FileCache.create_cache_path("graph_profile.out", false)
925
+ File.open(path, "w+") do |file|
926
+ RubyProf::GraphPrinter.new(RubyProf.stop).print(file, {})
927
+ end
928
+ Chef::Log.warn("Ruby execution profile dumped to #{path}")
929
+ end
930
+
931
+ def empty_directory?(path)
932
+ !File.exists?(path) || (Dir.entries(path).size <= 2)
933
+ end
934
+
935
+ def is_last_element?(index, object)
936
+ object.kind_of?(Array) ? index == object.size - 1 : true
937
+ end
938
+
939
+ def assert_cookbook_path_not_empty(run_context)
940
+ if Chef::Config[:solo]
941
+ # Check for cookbooks in the path given
942
+ # Chef::Config[:cookbook_path] can be a string or an array
943
+ # if it's an array, go through it and check each one, raise error at the last one if no files are found
944
+ cookbook_paths = Array(Chef::Config[:cookbook_path])
945
+ Chef::Log.debug "Loading from cookbook_path: #{cookbook_paths.map { |path| File.expand_path(path) }.join(', ')}"
946
+ if cookbook_paths.all? { |path| empty_directory?(path) }
947
+ msg = "None of the cookbook paths set in Chef::Config[:cookbook_path], #{cookbook_paths.inspect}, contain any cookbooks"
948
+ Chef::Log.fatal(msg)
949
+ raise Chef::Exceptions::CookbookNotFound, msg
950
+ end
951
+ else
952
+ Chef::Log.warn("Node #{node_name} has an empty run list.") if run_context.node.run_list.empty?
953
+ end
954
+ end
955
+
956
+ def has_admin_privileges?
957
+ require "chef/win32/security"
958
+
959
+ Chef::ReservedNames::Win32::Security.has_admin_privileges?
960
+ end
961
+ end
962
+ end
963
+
964
+ # HACK cannot load this first, but it must be loaded.
965
+ require "chef/cookbook_loader"
966
+ require "chef/cookbook_version"
967
+ require "chef/cookbook/synchronizer"