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