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