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