chef 14.0.202-universal-mingw32 → 14.1.1-universal-mingw32

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