chef 14.3.37-universal-mingw32 → 14.4.56-universal-mingw32

Sign up to get free protection for your applications and to get access to all the features.
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"