chef 14.15.6-universal-mingw32 → 15.0.293-universal-mingw32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2006) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +93 -72
  3. data/LICENSE +201 -201
  4. data/README.md +64 -251
  5. data/Rakefile +80 -75
  6. data/bin/knife +24 -24
  7. data/chef-universal-mingw32.gemspec +22 -24
  8. data/chef.gemspec +60 -62
  9. data/distro/powershell/chef/chef.psm1 +459 -459
  10. data/ext/win32-eventlog/Rakefile +53 -53
  11. data/ext/win32-eventlog/chef-log.man +56 -56
  12. data/lib/chef.rb +35 -34
  13. data/lib/chef/action_collection.rb +252 -0
  14. data/lib/chef/api_client.rb +228 -228
  15. data/lib/chef/api_client/registration.rb +200 -200
  16. data/lib/chef/api_client_v1.rb +326 -326
  17. data/lib/chef/application.rb +409 -398
  18. data/lib/chef/application/apply.rb +223 -226
  19. data/lib/chef/application/client.rb +546 -559
  20. data/lib/chef/application/exit_code.rb +157 -164
  21. data/lib/chef/application/knife.rb +222 -221
  22. data/lib/chef/application/solo.rb +375 -381
  23. data/lib/chef/application/windows_service.rb +338 -337
  24. data/lib/chef/application/windows_service_manager.rb +205 -204
  25. data/lib/chef/applications.rb +4 -4
  26. data/lib/chef/blacklist.rb +81 -81
  27. data/lib/chef/chef_class.rb +248 -248
  28. data/lib/chef/chef_fs.rb +59 -59
  29. data/lib/chef/chef_fs/chef_fs_data_store.rb +870 -870
  30. data/lib/chef/chef_fs/command_line.rb +291 -291
  31. data/lib/chef/chef_fs/config.rb +284 -284
  32. data/lib/chef/chef_fs/data_handler/acl_data_handler.rb +26 -26
  33. data/lib/chef/chef_fs/data_handler/client_data_handler.rb +39 -39
  34. data/lib/chef/chef_fs/data_handler/client_key_data_handler.rb +11 -11
  35. data/lib/chef/chef_fs/data_handler/container_data_handler.rb +35 -35
  36. data/lib/chef/chef_fs/data_handler/cookbook_data_handler.rb +38 -38
  37. data/lib/chef/chef_fs/data_handler/data_bag_item_data_handler.rb +67 -67
  38. data/lib/chef/chef_fs/data_handler/data_handler_base.rb +207 -207
  39. data/lib/chef/chef_fs/data_handler/environment_data_handler.rb +40 -40
  40. data/lib/chef/chef_fs/data_handler/group_data_handler.rb +55 -55
  41. data/lib/chef/chef_fs/data_handler/node_data_handler.rb +36 -36
  42. data/lib/chef/chef_fs/data_handler/organization_data_handler.rb +36 -36
  43. data/lib/chef/chef_fs/data_handler/organization_invites_data_handler.rb +17 -17
  44. data/lib/chef/chef_fs/data_handler/organization_members_data_handler.rb +17 -17
  45. data/lib/chef/chef_fs/data_handler/policy_data_handler.rb +48 -48
  46. data/lib/chef/chef_fs/data_handler/policy_group_data_handler.rb +33 -33
  47. data/lib/chef/chef_fs/data_handler/role_data_handler.rb +40 -40
  48. data/lib/chef/chef_fs/data_handler/user_data_handler.rb +29 -29
  49. data/lib/chef/chef_fs/file_pattern.rb +301 -301
  50. data/lib/chef/chef_fs/file_system.rb +431 -431
  51. data/lib/chef/chef_fs/file_system/base_fs_dir.rb +47 -47
  52. data/lib/chef/chef_fs/file_system/base_fs_object.rb +187 -187
  53. data/lib/chef/chef_fs/file_system/chef_server/acl_dir.rb +65 -65
  54. data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +67 -67
  55. data/lib/chef/chef_fs/file_system/chef_server/acls_dir.rb +75 -75
  56. data/lib/chef/chef_fs/file_system/chef_server/chef_server_root_dir.rb +196 -196
  57. data/lib/chef/chef_fs/file_system/chef_server/cookbook_artifact_dir.rb +38 -38
  58. data/lib/chef/chef_fs/file_system/chef_server/cookbook_artifacts_dir.rb +106 -106
  59. data/lib/chef/chef_fs/file_system/chef_server/cookbook_dir.rb +208 -208
  60. data/lib/chef/chef_fs/file_system/chef_server/cookbook_file.rb +78 -78
  61. data/lib/chef/chef_fs/file_system/chef_server/cookbook_subdir.rb +61 -61
  62. data/lib/chef/chef_fs/file_system/chef_server/cookbooks_acl_dir.rb +42 -42
  63. data/lib/chef/chef_fs/file_system/chef_server/cookbooks_dir.rb +105 -105
  64. data/lib/chef/chef_fs/file_system/chef_server/data_bag_dir.rb +76 -76
  65. data/lib/chef/chef_fs/file_system/chef_server/data_bag_entry.rb +19 -19
  66. data/lib/chef/chef_fs/file_system/chef_server/data_bags_dir.rb +67 -67
  67. data/lib/chef/chef_fs/file_system/chef_server/environments_dir.rb +56 -56
  68. data/lib/chef/chef_fs/file_system/chef_server/nodes_dir.rb +51 -51
  69. data/lib/chef/chef_fs/file_system/chef_server/org_entry.rb +35 -35
  70. data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +65 -65
  71. data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +64 -64
  72. data/lib/chef/chef_fs/file_system/chef_server/policies_acl_dir.rb +41 -41
  73. data/lib/chef/chef_fs/file_system/chef_server/policies_dir.rb +158 -158
  74. data/lib/chef/chef_fs/file_system/chef_server/policy_group_entry.rb +136 -135
  75. data/lib/chef/chef_fs/file_system/chef_server/policy_groups_dir.rb +43 -43
  76. data/lib/chef/chef_fs/file_system/chef_server/policy_revision_entry.rb +38 -38
  77. data/lib/chef/chef_fs/file_system/chef_server/rest_list_dir.rb +176 -176
  78. data/lib/chef/chef_fs/file_system/chef_server/rest_list_entry.rb +207 -207
  79. data/lib/chef/chef_fs/file_system/chef_server/versioned_cookbook_dir.rb +45 -45
  80. data/lib/chef/chef_fs/file_system/chef_server/versioned_cookbooks_dir.rb +111 -111
  81. data/lib/chef/chef_fs/file_system/exceptions.rb +105 -105
  82. data/lib/chef/chef_fs/file_system/memory/memory_dir.rb +53 -53
  83. data/lib/chef/chef_fs/file_system/memory/memory_file.rb +20 -20
  84. data/lib/chef/chef_fs/file_system/memory/memory_root.rb +23 -23
  85. data/lib/chef/chef_fs/file_system/multiplexed_dir.rb +62 -62
  86. data/lib/chef/chef_fs/file_system/nonexistent_fs_object.rb +32 -32
  87. data/lib/chef/chef_fs/file_system/repository/acl.rb +45 -45
  88. data/lib/chef/chef_fs/file_system/repository/acls_dir.rb +50 -50
  89. data/lib/chef/chef_fs/file_system/repository/acls_sub_dir.rb +38 -38
  90. data/lib/chef/chef_fs/file_system/repository/base_file.rb +155 -155
  91. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_artifact_dir.rb +41 -41
  92. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +143 -143
  93. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +177 -177
  94. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +232 -232
  95. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_versioned_cookbook_dir.rb +42 -42
  96. data/lib/chef/chef_fs/file_system/repository/client.rb +38 -38
  97. data/lib/chef/chef_fs/file_system/repository/client_key.rb +38 -38
  98. data/lib/chef/chef_fs/file_system/repository/client_keys_dir.rb +42 -42
  99. data/lib/chef/chef_fs/file_system/repository/client_keys_sub_dir.rb +38 -38
  100. data/lib/chef/chef_fs/file_system/repository/clients_dir.rb +37 -37
  101. data/lib/chef/chef_fs/file_system/repository/container.rb +38 -38
  102. data/lib/chef/chef_fs/file_system/repository/containers_dir.rb +37 -37
  103. data/lib/chef/chef_fs/file_system/repository/cookbook_artifacts_dir.rb +36 -36
  104. data/lib/chef/chef_fs/file_system/repository/cookbooks_dir.rb +51 -51
  105. data/lib/chef/chef_fs/file_system/repository/data_bag.rb +39 -39
  106. data/lib/chef/chef_fs/file_system/repository/data_bag_item.rb +38 -38
  107. data/lib/chef/chef_fs/file_system/repository/data_bags_dir.rb +39 -39
  108. data/lib/chef/chef_fs/file_system/repository/directory.rb +167 -167
  109. data/lib/chef/chef_fs/file_system/repository/environment.rb +38 -38
  110. data/lib/chef/chef_fs/file_system/repository/environments_dir.rb +37 -37
  111. data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +151 -151
  112. data/lib/chef/chef_fs/file_system/repository/group.rb +38 -38
  113. data/lib/chef/chef_fs/file_system/repository/groups_dir.rb +37 -37
  114. data/lib/chef/chef_fs/file_system/repository/node.rb +38 -38
  115. data/lib/chef/chef_fs/file_system/repository/nodes_dir.rb +59 -59
  116. data/lib/chef/chef_fs/file_system/repository/policies_dir.rb +42 -42
  117. data/lib/chef/chef_fs/file_system/repository/policy.rb +38 -38
  118. data/lib/chef/chef_fs/file_system/repository/policy_group.rb +38 -38
  119. data/lib/chef/chef_fs/file_system/repository/policy_groups_dir.rb +37 -37
  120. data/lib/chef/chef_fs/file_system/repository/role.rb +38 -38
  121. data/lib/chef/chef_fs/file_system/repository/roles_dir.rb +37 -37
  122. data/lib/chef/chef_fs/file_system/repository/user.rb +38 -38
  123. data/lib/chef/chef_fs/file_system/repository/users_dir.rb +37 -37
  124. data/lib/chef/chef_fs/file_system/repository/versioned_cookbooks_dir.rb +34 -34
  125. data/lib/chef/chef_fs/file_system_cache.rb +80 -80
  126. data/lib/chef/chef_fs/knife.rb +161 -161
  127. data/lib/chef/chef_fs/parallelizer.rb +103 -103
  128. data/lib/chef/chef_fs/parallelizer/flatten_enumerable.rb +35 -35
  129. data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +277 -277
  130. data/lib/chef/chef_fs/path_utils.rb +127 -127
  131. data/lib/chef/client.rb +934 -1037
  132. data/lib/chef/config.rb +84 -84
  133. data/lib/chef/config_fetcher.rb +72 -72
  134. data/lib/chef/constants.rb +28 -28
  135. data/lib/chef/cookbook/chefignore.rb +77 -78
  136. data/lib/chef/cookbook/cookbook_collection.rb +62 -63
  137. data/lib/chef/cookbook/cookbook_version_loader.rb +278 -267
  138. data/lib/chef/cookbook/file_system_file_vendor.rb +57 -58
  139. data/lib/chef/cookbook/file_vendor.rb +70 -71
  140. data/lib/chef/cookbook/gem_installer.rb +94 -101
  141. data/lib/chef/cookbook/manifest_v0.rb +73 -73
  142. data/lib/chef/cookbook/manifest_v2.rb +45 -45
  143. data/lib/chef/cookbook/metadata.rb +752 -804
  144. data/lib/chef/cookbook/remote_file_vendor.rb +86 -87
  145. data/lib/chef/cookbook/synchronizer.rb +328 -312
  146. data/lib/chef/cookbook/syntax_check.rb +259 -260
  147. data/lib/chef/cookbook_loader.rb +185 -208
  148. data/lib/chef/cookbook_manifest.rb +328 -328
  149. data/lib/chef/cookbook_site_streaming_uploader.rb +241 -241
  150. data/lib/chef/cookbook_uploader.rb +156 -156
  151. data/lib/chef/cookbook_version.rb +544 -544
  152. data/lib/chef/daemon.rb +131 -131
  153. data/lib/chef/data_bag.rb +174 -174
  154. data/lib/chef/data_bag_item.rb +209 -209
  155. data/lib/chef/data_collector.rb +324 -565
  156. data/lib/chef/data_collector/config_validation.rb +88 -0
  157. data/lib/chef/data_collector/error_handlers.rb +116 -0
  158. data/lib/chef/data_collector/message_helpers.rb +50 -0
  159. data/lib/chef/data_collector/run_end_message.rb +172 -0
  160. data/lib/chef/data_collector/run_start_message.rb +60 -0
  161. data/lib/chef/decorator.rb +81 -81
  162. data/lib/chef/decorator/lazy.rb +60 -60
  163. data/lib/chef/decorator/lazy_array.rb +59 -59
  164. data/lib/chef/decorator/unchain.rb +43 -43
  165. data/lib/chef/delayed_evaluator.rb +21 -21
  166. data/lib/chef/deprecated.rb +241 -248
  167. data/lib/chef/deprecation/warnings.rb +38 -38
  168. data/lib/chef/digester.rb +74 -74
  169. data/lib/chef/dist.rb +19 -0
  170. data/lib/chef/dsl.rb +6 -6
  171. data/lib/chef/dsl/cheffish.rb +65 -65
  172. data/lib/chef/dsl/core.rb +52 -52
  173. data/lib/chef/dsl/data_query.rb +103 -103
  174. data/lib/chef/dsl/declare_resource.rb +319 -319
  175. data/lib/chef/dsl/definitions.rb +43 -43
  176. data/lib/chef/dsl/include_attribute.rb +57 -57
  177. data/lib/chef/dsl/include_recipe.rb +34 -40
  178. data/lib/chef/dsl/platform_introspection.rb +269 -269
  179. data/lib/chef/dsl/powershell.rb +29 -29
  180. data/lib/chef/dsl/reboot_pending.rb +57 -57
  181. data/lib/chef/dsl/recipe.rb +74 -76
  182. data/lib/chef/dsl/registry_helper.rb +63 -63
  183. data/lib/chef/dsl/resources.rb +47 -49
  184. data/lib/chef/dsl/universal.rb +62 -60
  185. data/lib/chef/encrypted_data_bag_item.rb +157 -157
  186. data/lib/chef/encrypted_data_bag_item/assertions.rb +54 -54
  187. data/lib/chef/encrypted_data_bag_item/check_encrypted.rb +56 -56
  188. data/lib/chef/encrypted_data_bag_item/decryption_failure.rb +22 -22
  189. data/lib/chef/encrypted_data_bag_item/decryptor.rb +232 -227
  190. data/lib/chef/encrypted_data_bag_item/encrypted_data_bag_item_assertions.rb +37 -37
  191. data/lib/chef/encrypted_data_bag_item/encryption_failure.rb +22 -22
  192. data/lib/chef/encrypted_data_bag_item/encryptor.rb +225 -225
  193. data/lib/chef/encrypted_data_bag_item/unacceptable_encrypted_data_bag_item_format.rb +22 -22
  194. data/lib/chef/encrypted_data_bag_item/unsupported_cipher.rb +22 -22
  195. data/lib/chef/encrypted_data_bag_item/unsupported_encrypted_data_bag_item_format.rb +22 -22
  196. data/lib/chef/environment.rb +319 -319
  197. data/lib/chef/event_dispatch/base.rb +431 -445
  198. data/lib/chef/event_dispatch/dispatcher.rb +88 -62
  199. data/lib/chef/event_dispatch/dsl.rb +65 -65
  200. data/lib/chef/event_dispatch/events_output_stream.rb +37 -37
  201. data/lib/chef/event_loggers/base.rb +62 -62
  202. data/lib/chef/event_loggers/windows_eventlog.rb +101 -101
  203. data/lib/chef/exceptions.rb +514 -543
  204. data/lib/chef/file_access_control.rb +75 -75
  205. data/lib/chef/file_access_control/unix.rb +290 -290
  206. data/lib/chef/file_access_control/windows.rb +337 -337
  207. data/lib/chef/file_cache.rb +223 -223
  208. data/lib/chef/file_content_management/content_base.rb +58 -58
  209. data/lib/chef/file_content_management/deploy.rb +37 -37
  210. data/lib/chef/file_content_management/deploy/cp.rb +48 -48
  211. data/lib/chef/file_content_management/deploy/mv_unix.rb +77 -77
  212. data/lib/chef/file_content_management/deploy/mv_windows.rb +103 -103
  213. data/lib/chef/file_content_management/tempfile.rb +107 -107
  214. data/lib/chef/formatters/base.rb +246 -246
  215. data/lib/chef/formatters/doc.rb +401 -443
  216. data/lib/chef/formatters/error_description.rb +86 -86
  217. data/lib/chef/formatters/error_inspectors.rb +19 -19
  218. data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +184 -183
  219. data/lib/chef/formatters/error_inspectors/compile_error_inspector.rb +154 -154
  220. data/lib/chef/formatters/error_inspectors/cookbook_resolve_error_inspector.rb +168 -168
  221. data/lib/chef/formatters/error_inspectors/cookbook_sync_error_inspector.rb +82 -82
  222. data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +129 -128
  223. data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +148 -147
  224. data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +125 -124
  225. data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +122 -121
  226. data/lib/chef/formatters/error_mapper.rb +85 -85
  227. data/lib/chef/formatters/indentable_output_stream.rb +182 -182
  228. data/lib/chef/formatters/minimal.rb +235 -233
  229. data/lib/chef/guard_interpreter.rb +32 -32
  230. data/lib/chef/guard_interpreter/default_guard_interpreter.rb +44 -47
  231. data/lib/chef/guard_interpreter/resource_guard_interpreter.rb +138 -138
  232. data/lib/chef/handler.rb +266 -266
  233. data/lib/chef/handler/error_report.rb +33 -33
  234. data/lib/chef/handler/json_file.rb +62 -62
  235. data/lib/chef/http.rb +539 -539
  236. data/lib/chef/http/api_versions.rb +56 -56
  237. data/lib/chef/http/auth_credentials.rb +59 -59
  238. data/lib/chef/http/authenticator.rb +118 -118
  239. data/lib/chef/http/basic_client.rb +157 -157
  240. data/lib/chef/http/cookie_jar.rb +31 -31
  241. data/lib/chef/http/cookie_manager.rb +59 -59
  242. data/lib/chef/http/decompressor.rb +142 -142
  243. data/lib/chef/http/http_request.rb +190 -189
  244. data/lib/chef/http/json_input.rb +73 -73
  245. data/lib/chef/http/json_output.rb +81 -81
  246. data/lib/chef/http/json_to_model_output.rb +34 -34
  247. data/lib/chef/http/remote_request_id.rb +46 -46
  248. data/lib/chef/http/simple.rb +40 -40
  249. data/lib/chef/http/simple_json.rb +43 -43
  250. data/lib/chef/http/socketless_chef_zero_client.rb +209 -209
  251. data/lib/chef/http/ssl_policies.rb +130 -130
  252. data/lib/chef/http/validate_content_length.rb +114 -114
  253. data/lib/chef/json_compat.rb +68 -68
  254. data/lib/chef/key.rb +269 -269
  255. data/lib/chef/knife.rb +648 -630
  256. data/lib/chef/knife/bootstrap.rb +1057 -525
  257. data/lib/chef/knife/bootstrap/chef_vault_handler.rb +158 -159
  258. data/lib/chef/knife/bootstrap/client_builder.rb +207 -208
  259. data/lib/chef/knife/bootstrap/templates/README.md +11 -11
  260. data/lib/chef/knife/bootstrap/templates/chef-full.erb +243 -243
  261. data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +276 -0
  262. data/lib/chef/knife/bootstrap/train_connector.rb +325 -0
  263. data/lib/chef/knife/client_bulk_delete.rb +103 -103
  264. data/lib/chef/knife/client_create.rb +101 -110
  265. data/lib/chef/knife/client_delete.rb +62 -62
  266. data/lib/chef/knife/client_edit.rb +52 -52
  267. data/lib/chef/knife/client_key_create.rb +70 -70
  268. data/lib/chef/knife/client_key_delete.rb +77 -77
  269. data/lib/chef/knife/client_key_edit.rb +80 -80
  270. data/lib/chef/knife/client_key_list.rb +70 -70
  271. data/lib/chef/knife/client_key_show.rb +77 -77
  272. data/lib/chef/knife/client_list.rb +41 -41
  273. data/lib/chef/knife/client_reregister.rb +58 -58
  274. data/lib/chef/knife/client_show.rb +48 -48
  275. data/lib/chef/knife/config_get.rb +126 -127
  276. data/lib/chef/knife/config_get_profile.rb +37 -37
  277. data/lib/chef/knife/config_list_profiles.rb +121 -121
  278. data/lib/chef/knife/config_use_profile.rb +50 -50
  279. data/lib/chef/knife/configure.rb +147 -147
  280. data/lib/chef/knife/configure_client.rb +48 -48
  281. data/lib/chef/knife/cookbook_bulk_delete.rb +71 -71
  282. data/lib/chef/knife/cookbook_delete.rb +151 -151
  283. data/lib/chef/knife/cookbook_download.rb +142 -142
  284. data/lib/chef/knife/cookbook_list.rb +47 -47
  285. data/lib/chef/knife/cookbook_metadata.rb +106 -106
  286. data/lib/chef/knife/cookbook_metadata_from_file.rb +43 -43
  287. data/lib/chef/knife/cookbook_show.rb +98 -98
  288. data/lib/chef/knife/cookbook_site_download.rb +40 -40
  289. data/lib/chef/knife/cookbook_site_install.rb +40 -40
  290. data/lib/chef/knife/cookbook_site_list.rb +40 -40
  291. data/lib/chef/knife/cookbook_site_search.rb +40 -40
  292. data/lib/chef/knife/cookbook_site_share.rb +41 -41
  293. data/lib/chef/knife/cookbook_site_show.rb +40 -40
  294. data/lib/chef/knife/cookbook_site_unshare.rb +41 -41
  295. data/lib/chef/knife/cookbook_upload.rb +273 -308
  296. data/lib/chef/knife/core/bootstrap_context.rb +259 -273
  297. data/lib/chef/knife/core/cookbook_scm_repo.rb +159 -159
  298. data/lib/chef/knife/core/gem_glob_loader.rb +138 -138
  299. data/lib/chef/knife/core/generic_presenter.rb +231 -231
  300. data/lib/chef/knife/core/hashed_command_loader.rb +99 -99
  301. data/lib/chef/knife/core/node_editor.rb +130 -130
  302. data/lib/chef/knife/core/node_presenter.rb +158 -158
  303. data/lib/chef/knife/core/object_loader.rb +115 -115
  304. data/lib/chef/knife/core/status_presenter.rb +172 -172
  305. data/lib/chef/knife/core/subcommand_loader.rb +183 -183
  306. data/lib/chef/knife/core/text_formatter.rb +85 -85
  307. data/lib/chef/knife/core/ui.rb +309 -286
  308. data/lib/chef/knife/core/windows_bootstrap_context.rb +379 -0
  309. data/lib/chef/knife/data_bag_create.rb +80 -80
  310. data/lib/chef/knife/data_bag_delete.rb +49 -49
  311. data/lib/chef/knife/data_bag_edit.rb +74 -74
  312. data/lib/chef/knife/data_bag_from_file.rb +113 -113
  313. data/lib/chef/knife/data_bag_list.rb +42 -42
  314. data/lib/chef/knife/data_bag_secret_options.rb +142 -142
  315. data/lib/chef/knife/data_bag_show.rb +69 -69
  316. data/lib/chef/knife/delete.rb +125 -125
  317. data/lib/chef/knife/deps.rb +156 -154
  318. data/lib/chef/knife/diff.rb +83 -84
  319. data/lib/chef/knife/download.rb +84 -84
  320. data/lib/chef/knife/edit.rb +88 -88
  321. data/lib/chef/knife/environment_compare.rb +127 -127
  322. data/lib/chef/knife/environment_create.rb +52 -52
  323. data/lib/chef/knife/environment_delete.rb +44 -44
  324. data/lib/chef/knife/environment_edit.rb +44 -44
  325. data/lib/chef/knife/environment_from_file.rb +84 -84
  326. data/lib/chef/knife/environment_list.rb +41 -41
  327. data/lib/chef/knife/environment_show.rb +47 -47
  328. data/lib/chef/knife/exec.rb +87 -87
  329. data/lib/chef/knife/key_create.rb +112 -112
  330. data/lib/chef/knife/key_create_base.rb +50 -50
  331. data/lib/chef/knife/key_delete.rb +55 -55
  332. data/lib/chef/knife/key_edit.rb +118 -118
  333. data/lib/chef/knife/key_edit_base.rb +55 -55
  334. data/lib/chef/knife/key_list.rb +88 -88
  335. data/lib/chef/knife/key_list_base.rb +45 -45
  336. data/lib/chef/knife/key_show.rb +53 -53
  337. data/lib/chef/knife/list.rb +177 -172
  338. data/lib/chef/knife/node_bulk_delete.rb +74 -74
  339. data/lib/chef/knife/node_create.rb +47 -47
  340. data/lib/chef/knife/node_delete.rb +46 -46
  341. data/lib/chef/knife/node_edit.rb +70 -70
  342. data/lib/chef/knife/node_environment_set.rb +54 -54
  343. data/lib/chef/knife/node_from_file.rb +51 -51
  344. data/lib/chef/knife/node_list.rb +44 -44
  345. data/lib/chef/knife/node_policy_set.rb +79 -79
  346. data/lib/chef/knife/node_run_list_add.rb +104 -104
  347. data/lib/chef/knife/node_run_list_remove.rb +67 -67
  348. data/lib/chef/knife/node_run_list_set.rb +66 -66
  349. data/lib/chef/knife/node_show.rb +61 -61
  350. data/lib/chef/knife/null.rb +13 -10
  351. data/lib/chef/knife/raw.rb +124 -124
  352. data/lib/chef/knife/recipe_list.rb +32 -32
  353. data/lib/chef/knife/rehash.rb +65 -65
  354. data/lib/chef/knife/role_bulk_delete.rb +65 -65
  355. data/lib/chef/knife/role_create.rb +53 -53
  356. data/lib/chef/knife/role_delete.rb +46 -46
  357. data/lib/chef/knife/role_edit.rb +45 -45
  358. data/lib/chef/knife/role_env_run_list_add.rb +87 -87
  359. data/lib/chef/knife/role_env_run_list_clear.rb +55 -55
  360. data/lib/chef/knife/role_env_run_list_remove.rb +57 -57
  361. data/lib/chef/knife/role_env_run_list_replace.rb +60 -60
  362. data/lib/chef/knife/role_env_run_list_set.rb +70 -70
  363. data/lib/chef/knife/role_from_file.rb +51 -51
  364. data/lib/chef/knife/role_list.rb +42 -42
  365. data/lib/chef/knife/role_run_list_add.rb +87 -87
  366. data/lib/chef/knife/role_run_list_clear.rb +55 -55
  367. data/lib/chef/knife/role_run_list_remove.rb +56 -56
  368. data/lib/chef/knife/role_run_list_replace.rb +60 -60
  369. data/lib/chef/knife/role_run_list_set.rb +69 -69
  370. data/lib/chef/knife/role_show.rb +48 -48
  371. data/lib/chef/knife/search.rb +194 -194
  372. data/lib/chef/knife/serve.rb +64 -64
  373. data/lib/chef/knife/show.rb +72 -72
  374. data/lib/chef/knife/ssh.rb +634 -640
  375. data/lib/chef/knife/ssl_check.rb +283 -283
  376. data/lib/chef/knife/ssl_fetch.rb +161 -161
  377. data/lib/chef/knife/status.rb +97 -110
  378. data/lib/chef/knife/supermarket_download.rb +122 -122
  379. data/lib/chef/knife/supermarket_install.rb +193 -193
  380. data/lib/chef/knife/supermarket_list.rb +65 -65
  381. data/lib/chef/knife/supermarket_search.rb +53 -53
  382. data/lib/chef/knife/supermarket_share.rb +166 -166
  383. data/lib/chef/knife/supermarket_show.rb +67 -67
  384. data/lib/chef/knife/supermarket_unshare.rb +61 -61
  385. data/lib/chef/knife/tag_create.rb +52 -52
  386. data/lib/chef/knife/tag_delete.rb +60 -60
  387. data/lib/chef/knife/tag_list.rb +47 -47
  388. data/lib/chef/knife/upload.rb +86 -86
  389. data/lib/chef/knife/user_create.rb +107 -151
  390. data/lib/chef/knife/user_delete.rb +44 -96
  391. data/lib/chef/knife/user_edit.rb +52 -82
  392. data/lib/chef/knife/user_key_create.rb +70 -70
  393. data/lib/chef/knife/user_key_delete.rb +77 -77
  394. data/lib/chef/knife/user_key_edit.rb +80 -80
  395. data/lib/chef/knife/user_key_list.rb +70 -70
  396. data/lib/chef/knife/user_key_show.rb +77 -77
  397. data/lib/chef/knife/user_list.rb +42 -44
  398. data/lib/chef/knife/user_reregister.rb +59 -90
  399. data/lib/chef/knife/user_show.rb +48 -79
  400. data/lib/chef/knife/xargs.rb +282 -282
  401. data/lib/chef/local_mode.rb +126 -129
  402. data/lib/chef/log.rb +70 -70
  403. data/lib/chef/log/syslog.rb +46 -45
  404. data/lib/chef/log/winevt.rb +99 -99
  405. data/lib/chef/mash.rb +232 -232
  406. data/lib/chef/mixin/api_version_request_handling.rb +64 -64
  407. data/lib/chef/mixin/checksum.rb +37 -37
  408. data/lib/chef/mixin/convert_to_class_name.rb +126 -126
  409. data/lib/chef/mixin/create_path.rb +71 -71
  410. data/lib/chef/mixin/deep_merge.rb +140 -140
  411. data/lib/chef/mixin/deprecation.rb +117 -117
  412. data/lib/chef/mixin/descendants_tracker.rb +81 -81
  413. data/lib/chef/mixin/enforce_ownership_and_permissions.rb +39 -39
  414. data/lib/chef/mixin/file_class.rb +35 -35
  415. data/lib/chef/mixin/from_file.rb +55 -55
  416. data/lib/chef/mixin/get_source_from_package.rb +47 -47
  417. data/lib/chef/mixin/homebrew_user.rb +79 -79
  418. data/lib/chef/mixin/lazy_module_include.rb +77 -77
  419. data/lib/chef/mixin/notifying_block.rb +51 -51
  420. data/lib/chef/mixin/openssl_helper.rb +402 -402
  421. data/lib/chef/mixin/params_validate.rb +498 -498
  422. data/lib/chef/mixin/path_sanity.rb +66 -66
  423. data/lib/chef/mixin/powershell_exec.rb +105 -105
  424. data/lib/chef/mixin/powershell_out.rb +98 -98
  425. data/lib/chef/mixin/powershell_type_coercions.rb +84 -84
  426. data/lib/chef/mixin/properties.rb +355 -323
  427. data/lib/chef/mixin/provides.rb +29 -29
  428. data/lib/chef/mixin/proxified_socket.rb +42 -42
  429. data/lib/chef/mixin/securable.rb +192 -192
  430. data/lib/chef/mixin/shell_out.rb +187 -258
  431. data/lib/chef/mixin/subclass_directive.rb +37 -37
  432. data/lib/chef/mixin/template.rb +260 -265
  433. data/lib/chef/mixin/train_or_shell.rb +83 -0
  434. data/lib/chef/mixin/unformatter.rb +32 -32
  435. data/lib/chef/mixin/uris.rb +42 -42
  436. data/lib/chef/mixin/user_context.rb +55 -55
  437. data/lib/chef/mixin/versioned_api.rb +84 -84
  438. data/lib/chef/mixin/which.rb +52 -52
  439. data/lib/chef/mixin/why_run.rb +326 -326
  440. data/lib/chef/mixin/wide_string.rb +54 -54
  441. data/lib/chef/mixin/windows_architecture_helper.rb +113 -113
  442. data/lib/chef/mixin/windows_env_helper.rb +67 -67
  443. data/lib/chef/mixin/xml_escape.rb +138 -138
  444. data/lib/chef/mixins.rb +12 -12
  445. data/lib/chef/monkey_patches/net_http.rb +64 -64
  446. data/lib/chef/monkey_patches/webrick-utils.rb +51 -51
  447. data/lib/chef/monkey_patches/win32/registry.rb +60 -86
  448. data/lib/chef/monologger.rb +4 -4
  449. data/lib/chef/nil_argument.rb +3 -3
  450. data/lib/chef/node.rb +732 -688
  451. data/lib/chef/node/attribute.rb +651 -649
  452. data/lib/chef/node/attribute_collections.rb +178 -213
  453. data/lib/chef/node/common_api.rb +121 -121
  454. data/lib/chef/node/immutable_collections.rb +182 -182
  455. data/lib/chef/node/mixin/deep_merge_cache.rb +61 -61
  456. data/lib/chef/node/mixin/immutablize_array.rb +179 -180
  457. data/lib/chef/node/mixin/immutablize_hash.rb +165 -165
  458. data/lib/chef/node/mixin/mashy_array.rb +68 -0
  459. data/lib/chef/node/mixin/state_tracking.rb +96 -96
  460. data/lib/chef/node_map.rb +328 -315
  461. data/lib/chef/null_logger.rb +79 -79
  462. data/lib/chef/org.rb +144 -144
  463. data/lib/chef/platform.rb +30 -30
  464. data/lib/chef/platform/priority_map.rb +41 -41
  465. data/lib/chef/platform/provider_handler_map.rb +29 -29
  466. data/lib/chef/platform/provider_mapping.rb +55 -55
  467. data/lib/chef/platform/provider_priority_map.rb +11 -11
  468. data/lib/chef/platform/query_helpers.rb +100 -100
  469. data/lib/chef/platform/rebooter.rb +71 -71
  470. data/lib/chef/platform/resource_handler_map.rb +29 -29
  471. data/lib/chef/platform/resource_priority_map.rb +11 -11
  472. data/lib/chef/platform/service_helpers.rb +122 -122
  473. data/lib/chef/policy_builder.rb +42 -42
  474. data/lib/chef/policy_builder/dynamic.rb +186 -185
  475. data/lib/chef/policy_builder/expand_node_object.rb +261 -252
  476. data/lib/chef/policy_builder/policyfile.rb +571 -569
  477. data/lib/chef/powershell.rb +57 -57
  478. data/lib/chef/property.rb +731 -731
  479. data/lib/chef/provider.rb +419 -410
  480. data/lib/chef/provider/apt_preference.rb +94 -94
  481. data/lib/chef/provider/apt_repository.rb +360 -360
  482. data/lib/chef/provider/apt_update.rb +80 -80
  483. data/lib/chef/provider/batch.rb +45 -45
  484. data/lib/chef/provider/cookbook_file.rb +47 -47
  485. data/lib/chef/provider/cookbook_file/content.rb +49 -49
  486. data/lib/chef/provider/cron.rb +256 -256
  487. data/lib/chef/provider/cron/aix.rb +50 -50
  488. data/lib/chef/provider/cron/solaris.rb +22 -22
  489. data/lib/chef/provider/cron/unix.rb +83 -83
  490. data/lib/chef/provider/directory.rb +164 -164
  491. data/lib/chef/provider/dsc_resource.rb +209 -209
  492. data/lib/chef/provider/dsc_script.rb +185 -185
  493. data/lib/chef/provider/execute.rb +133 -130
  494. data/lib/chef/provider/file.rb +479 -478
  495. data/lib/chef/provider/file/content.rb +39 -39
  496. data/lib/chef/provider/git.rb +359 -357
  497. data/lib/chef/provider/group.rb +179 -179
  498. data/lib/chef/provider/group/aix.rb +79 -79
  499. data/lib/chef/provider/group/dscl.rb +177 -177
  500. data/lib/chef/provider/group/gpasswd.rb +58 -58
  501. data/lib/chef/provider/group/groupadd.rb +133 -133
  502. data/lib/chef/provider/group/groupmod.rb +123 -123
  503. data/lib/chef/provider/group/pw.rb +137 -137
  504. data/lib/chef/provider/group/solaris.rb +62 -0
  505. data/lib/chef/provider/group/suse.rb +82 -83
  506. data/lib/chef/provider/group/usermod.rb +87 -90
  507. data/lib/chef/provider/group/windows.rb +110 -110
  508. data/lib/chef/provider/http_request.rb +132 -132
  509. data/lib/chef/provider/ifconfig.rb +271 -282
  510. data/lib/chef/provider/ifconfig/aix.rb +94 -94
  511. data/lib/chef/provider/ifconfig/debian.rb +88 -88
  512. data/lib/chef/provider/ifconfig/redhat.rb +54 -54
  513. data/lib/chef/provider/launchd.rb +231 -231
  514. data/lib/chef/provider/link.rb +168 -168
  515. data/lib/chef/provider/log.rb +43 -43
  516. data/lib/chef/provider/lwrp_base.rb +89 -89
  517. data/lib/chef/provider/mdadm.rb +85 -85
  518. data/lib/chef/provider/mount.rb +175 -175
  519. data/lib/chef/provider/mount/aix.rb +221 -221
  520. data/lib/chef/provider/mount/mount.rb +283 -283
  521. data/lib/chef/provider/mount/solaris.rb +275 -275
  522. data/lib/chef/provider/mount/windows.rb +92 -92
  523. data/lib/chef/provider/noop.rb +37 -37
  524. data/lib/chef/provider/ohai.rb +45 -45
  525. data/lib/chef/provider/osx_profile.rb +251 -251
  526. data/lib/chef/provider/package.rb +600 -687
  527. data/lib/chef/provider/package/apt.rb +234 -249
  528. data/lib/chef/provider/package/bff.rb +142 -142
  529. data/lib/chef/provider/package/cab.rb +187 -187
  530. data/lib/chef/provider/package/chocolatey.rb +285 -285
  531. data/lib/chef/provider/package/deb.rb +131 -0
  532. data/lib/chef/provider/package/dnf.rb +196 -196
  533. data/lib/chef/provider/package/dnf/dnf_helper.py +100 -114
  534. data/lib/chef/provider/package/dnf/python_helper.rb +171 -173
  535. data/lib/chef/provider/package/dnf/version.rb +56 -56
  536. data/lib/chef/provider/package/dpkg.rb +227 -241
  537. data/lib/chef/provider/package/freebsd/base.rb +89 -89
  538. data/lib/chef/provider/package/freebsd/pkgng.rb +76 -76
  539. data/lib/chef/provider/package/freebsd/port.rb +56 -60
  540. data/lib/chef/provider/package/homebrew.rb +138 -138
  541. data/lib/chef/provider/package/ips.rb +85 -85
  542. data/lib/chef/provider/package/macports.rb +101 -101
  543. data/lib/chef/provider/package/msu.rb +161 -161
  544. data/lib/chef/provider/package/openbsd.rb +139 -139
  545. data/lib/chef/provider/package/pacman.rb +103 -103
  546. data/lib/chef/provider/package/paludis.rb +85 -85
  547. data/lib/chef/provider/package/portage.rb +133 -133
  548. data/lib/chef/provider/package/powershell.rb +133 -133
  549. data/lib/chef/provider/package/rpm.rb +126 -126
  550. data/lib/chef/provider/package/rubygems.rb +617 -617
  551. data/lib/chef/provider/package/smartos.rb +92 -92
  552. data/lib/chef/provider/package/snap.rb +358 -0
  553. data/lib/chef/provider/package/solaris.rb +137 -137
  554. data/lib/chef/provider/package/windows.rb +317 -317
  555. data/lib/chef/provider/package/windows/exe.rb +117 -117
  556. data/lib/chef/provider/package/windows/msi.rb +96 -96
  557. data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +99 -99
  558. data/lib/chef/provider/package/yum.rb +289 -289
  559. data/lib/chef/provider/package/yum/python_helper.rb +222 -222
  560. data/lib/chef/provider/package/yum/rpm_utils.rb +641 -651
  561. data/lib/chef/provider/package/yum/simplejson/LICENSE.txt +79 -79
  562. data/lib/chef/provider/package/yum/simplejson/__init__.py +318 -318
  563. data/lib/chef/provider/package/yum/simplejson/decoder.py +354 -354
  564. data/lib/chef/provider/package/yum/simplejson/encoder.py +440 -440
  565. data/lib/chef/provider/package/yum/simplejson/scanner.py +65 -65
  566. data/lib/chef/provider/package/yum/simplejson/tool.py +37 -37
  567. data/lib/chef/provider/package/yum/version.rb +60 -56
  568. data/lib/chef/provider/package/yum/yum_cache.rb +93 -93
  569. data/lib/chef/provider/package/yum/yum_helper.py +211 -211
  570. data/lib/chef/provider/package/zypper.rb +167 -167
  571. data/lib/chef/provider/powershell_script.rb +193 -223
  572. data/lib/chef/provider/reboot.rb +78 -78
  573. data/lib/chef/provider/registry_key.rb +199 -199
  574. data/lib/chef/provider/remote_directory.rb +269 -269
  575. data/lib/chef/provider/remote_file.rb +66 -66
  576. data/lib/chef/provider/remote_file/cache_control_data.rb +195 -195
  577. data/lib/chef/provider/remote_file/content.rb +81 -81
  578. data/lib/chef/provider/remote_file/fetcher.rb +60 -60
  579. data/lib/chef/provider/remote_file/ftp.rb +172 -172
  580. data/lib/chef/provider/remote_file/http.rb +143 -143
  581. data/lib/chef/provider/remote_file/local_file.rb +60 -60
  582. data/lib/chef/provider/remote_file/network_file.rb +61 -61
  583. data/lib/chef/provider/remote_file/sftp.rb +105 -105
  584. data/lib/chef/provider/resource_update.rb +52 -52
  585. data/lib/chef/provider/route.rb +248 -248
  586. data/lib/chef/provider/ruby_block.rb +40 -40
  587. data/lib/chef/provider/script.rb +117 -121
  588. data/lib/chef/provider/service.rb +252 -252
  589. data/lib/chef/provider/service/aix.rb +125 -125
  590. data/lib/chef/provider/service/aixinit.rb +117 -117
  591. data/lib/chef/provider/service/arch.rb +118 -118
  592. data/lib/chef/provider/service/debian.rb +193 -193
  593. data/lib/chef/provider/service/freebsd.rb +194 -194
  594. data/lib/chef/provider/service/gentoo.rb +70 -70
  595. data/lib/chef/provider/service/init.rb +93 -93
  596. data/lib/chef/provider/service/insserv.rb +59 -61
  597. data/lib/chef/provider/service/invokercd.rb +41 -41
  598. data/lib/chef/provider/service/macosx.rb +252 -252
  599. data/lib/chef/provider/service/openbsd.rb +216 -216
  600. data/lib/chef/provider/service/redhat.rb +126 -126
  601. data/lib/chef/provider/service/simple.rb +172 -172
  602. data/lib/chef/provider/service/solaris.rb +127 -127
  603. data/lib/chef/provider/service/systemd.rb +189 -205
  604. data/lib/chef/provider/service/upstart.rb +260 -260
  605. data/lib/chef/provider/service/windows.rb +485 -488
  606. data/lib/chef/provider/subversion.rb +227 -227
  607. data/lib/chef/provider/support/yum_repo.erb +138 -138
  608. data/lib/chef/provider/support/zypper_repo.erb +17 -17
  609. data/lib/chef/provider/systemd_unit.rb +261 -285
  610. data/lib/chef/provider/template.rb +59 -59
  611. data/lib/chef/provider/template/content.rb +93 -93
  612. data/lib/chef/provider/template_finder.rb +62 -62
  613. data/lib/chef/provider/user.rb +221 -221
  614. data/lib/chef/provider/user/aix.rb +131 -131
  615. data/lib/chef/provider/user/dscl.rb +632 -712
  616. data/lib/chef/provider/user/linux.rb +116 -116
  617. data/lib/chef/provider/user/pw.rb +105 -105
  618. data/lib/chef/provider/user/solaris.rb +160 -160
  619. data/lib/chef/provider/user/windows.rb +124 -126
  620. data/lib/chef/provider/whyrun_safe_ruby_block.rb +32 -32
  621. data/lib/chef/provider/windows_env.rb +207 -207
  622. data/lib/chef/provider/windows_path.rb +61 -61
  623. data/lib/chef/provider/windows_script.rb +75 -75
  624. data/lib/chef/provider/windows_task.rb +634 -635
  625. data/lib/chef/provider/yum_repository.rb +130 -130
  626. data/lib/chef/provider/zypper_repository.rb +169 -169
  627. data/lib/chef/provider_resolver.rb +146 -146
  628. data/lib/chef/providers.rb +147 -146
  629. data/lib/chef/recipe.rb +95 -110
  630. data/lib/chef/request_id.rb +37 -37
  631. data/lib/chef/reserved_names.rb +9 -9
  632. data/lib/chef/resource.rb +1592 -1593
  633. data/lib/chef/resource/action_class.rb +90 -90
  634. data/lib/chef/resource/apt_package.rb +48 -40
  635. data/lib/chef/resource/apt_preference.rb +52 -52
  636. data/lib/chef/resource/apt_repository.rb +86 -86
  637. data/lib/chef/resource/apt_update.rb +41 -41
  638. data/lib/chef/resource/archive_file.rb +172 -0
  639. data/lib/chef/resource/bash.rb +34 -34
  640. data/lib/chef/resource/batch.rb +34 -34
  641. data/lib/chef/resource/bff_package.rb +31 -31
  642. data/lib/chef/resource/breakpoint.rb +48 -47
  643. data/lib/chef/resource/build_essential.rb +143 -142
  644. data/lib/chef/resource/cab_package.rb +45 -45
  645. data/lib/chef/resource/chef_gem.rb +62 -59
  646. data/lib/chef/resource/chef_handler.rb +135 -132
  647. data/lib/chef/resource/chocolatey_config.rb +82 -83
  648. data/lib/chef/resource/chocolatey_package.rb +50 -50
  649. data/lib/chef/resource/chocolatey_source.rb +94 -95
  650. data/lib/chef/resource/conditional.rb +135 -135
  651. data/lib/chef/resource/conditional_action_not_nothing.rb +48 -48
  652. data/lib/chef/resource/cookbook_file.rb +46 -45
  653. data/lib/chef/resource/cron.rb +174 -174
  654. data/lib/chef/resource/cron_access.rb +69 -70
  655. data/lib/chef/resource/cron_d.rb +237 -238
  656. data/lib/chef/resource/csh.rb +39 -39
  657. data/lib/chef/resource/directory.rb +51 -51
  658. data/lib/chef/resource/dmg_package.rb +171 -171
  659. data/lib/chef/resource/dnf_package.rb +80 -79
  660. data/lib/chef/resource/dpkg_package.rb +41 -33
  661. data/lib/chef/resource/dsc_resource.rb +120 -120
  662. data/lib/chef/resource/dsc_script.rb +124 -124
  663. data/lib/chef/resource/execute.rb +200 -201
  664. data/lib/chef/resource/file.rb +106 -105
  665. data/lib/chef/resource/file/verification.rb +139 -139
  666. data/lib/chef/resource/file/verification/systemd_unit.rb +67 -67
  667. data/lib/chef/resource/freebsd_package.rb +55 -73
  668. data/lib/chef/resource/gem_package.rb +59 -58
  669. data/lib/chef/resource/git.rb +35 -35
  670. data/lib/chef/resource/group.rb +61 -61
  671. data/lib/chef/resource/homebrew_cask.rb +103 -100
  672. data/lib/chef/resource/homebrew_package.rb +39 -38
  673. data/lib/chef/resource/homebrew_tap.rb +90 -87
  674. data/lib/chef/resource/hostname.rb +267 -265
  675. data/lib/chef/resource/http_request.rb +55 -55
  676. data/lib/chef/resource/ifconfig.rb +105 -105
  677. data/lib/chef/resource/ips_package.rb +38 -38
  678. data/lib/chef/resource/kernel_module.rb +134 -196
  679. data/lib/chef/resource/ksh.rb +39 -39
  680. data/lib/chef/resource/launchd.rb +252 -252
  681. data/lib/chef/resource/link.rb +92 -93
  682. data/lib/chef/resource/locale.rb +149 -94
  683. data/lib/chef/resource/log.rb +52 -52
  684. data/lib/chef/resource/lwrp_base.rb +123 -123
  685. data/lib/chef/resource/macos_userdefaults.rb +132 -132
  686. data/lib/chef/resource/macosx_service.rb +37 -41
  687. data/lib/chef/resource/macports_package.rb +29 -29
  688. data/lib/chef/resource/mdadm.rb +67 -67
  689. data/lib/chef/resource/mount.rb +96 -96
  690. data/lib/chef/resource/msu_package.rb +49 -49
  691. data/lib/chef/resource/ohai.rb +38 -41
  692. data/lib/chef/resource/ohai_hint.rb +97 -95
  693. data/lib/chef/resource/openbsd_package.rb +38 -38
  694. data/lib/chef/resource/openssl_dhparam.rb +77 -77
  695. data/lib/chef/resource/openssl_ec_private_key.rb +92 -93
  696. data/lib/chef/resource/openssl_ec_public_key.rb +74 -75
  697. data/lib/chef/resource/openssl_rsa_private_key.rb +91 -91
  698. data/lib/chef/resource/openssl_rsa_public_key.rb +74 -74
  699. data/lib/chef/resource/openssl_x509_certificate.rb +220 -221
  700. data/lib/chef/resource/openssl_x509_crl.rb +131 -132
  701. data/lib/chef/resource/openssl_x509_request.rb +150 -151
  702. data/lib/chef/resource/osx_profile.rb +48 -48
  703. data/lib/chef/resource/package.rb +65 -73
  704. data/lib/chef/resource/pacman_package.rb +30 -30
  705. data/lib/chef/resource/paludis_package.rb +38 -38
  706. data/lib/chef/resource/perl.rb +38 -38
  707. data/lib/chef/resource/portage_package.rb +33 -33
  708. data/lib/chef/resource/powershell_package.rb +52 -52
  709. data/lib/chef/resource/powershell_package_source.rb +168 -169
  710. data/lib/chef/resource/powershell_script.rb +95 -59
  711. data/lib/chef/resource/python.rb +36 -36
  712. data/lib/chef/resource/reboot.rb +46 -46
  713. data/lib/chef/resource/registry_key.rb +130 -130
  714. data/lib/chef/resource/remote_directory.rb +84 -87
  715. data/lib/chef/resource/remote_file.rb +181 -181
  716. data/lib/chef/resource/resource_notification.rb +139 -143
  717. data/lib/chef/resource/rhsm_errata.rb +46 -46
  718. data/lib/chef/resource/rhsm_errata_level.rb +51 -51
  719. data/lib/chef/resource/rhsm_register.rb +168 -168
  720. data/lib/chef/resource/rhsm_repo.rb +65 -65
  721. data/lib/chef/resource/rhsm_subscription.rb +98 -98
  722. data/lib/chef/resource/route.rb +56 -46
  723. data/lib/chef/resource/rpm_package.rb +33 -33
  724. data/lib/chef/resource/ruby.rb +37 -37
  725. data/lib/chef/resource/ruby_block.rb +46 -45
  726. data/lib/chef/resource/scm.rb +75 -75
  727. data/lib/chef/resource/script.rb +54 -54
  728. data/lib/chef/resource/service.rb +125 -230
  729. data/lib/chef/resource/smartos_package.rb +31 -31
  730. data/{bin/chef-solo → lib/chef/resource/snap_package.rb} +36 -24
  731. data/lib/chef/resource/solaris_package.rb +33 -33
  732. data/lib/chef/resource/ssh_known_hosts_entry.rb +145 -146
  733. data/lib/chef/resource/subversion.rb +56 -55
  734. data/lib/chef/resource/sudo.rb +230 -230
  735. data/lib/chef/resource/support/cron.d.erb +28 -28
  736. data/lib/chef/resource/support/cron_access.erb +4 -4
  737. data/lib/chef/resource/support/ssh_known_hosts.erb +3 -3
  738. data/lib/chef/resource/support/sudoer.erb +18 -18
  739. data/lib/chef/resource/swap_file.rb +209 -209
  740. data/lib/chef/resource/sysctl.rb +151 -151
  741. data/lib/chef/resource/systemd_unit.rb +86 -87
  742. data/lib/chef/resource/template.rb +212 -211
  743. data/lib/chef/resource/timezone.rb +134 -135
  744. data/lib/chef/resource/user.rb +77 -159
  745. data/lib/chef/resource/user/aix_user.rb +31 -31
  746. data/lib/chef/resource/user/dscl_user.rb +35 -31
  747. data/lib/chef/resource/user/linux_user.rb +32 -32
  748. data/lib/chef/resource/user/pw_user.rb +31 -31
  749. data/lib/chef/resource/user/solaris_user.rb +31 -31
  750. data/lib/chef/resource/user/windows_user.rb +35 -35
  751. data/lib/chef/resource/whyrun_safe_ruby_block.rb +24 -24
  752. data/lib/chef/resource/windows_ad_join.rb +120 -120
  753. data/lib/chef/resource/windows_auto_run.rb +87 -87
  754. data/lib/chef/resource/windows_certificate.rb +332 -332
  755. data/lib/chef/resource/windows_dfs_folder.rb +75 -0
  756. data/lib/chef/resource/windows_dfs_namespace.rb +114 -0
  757. data/lib/chef/resource/windows_dfs_server.rb +76 -0
  758. data/lib/chef/resource/windows_dns_record.rb +76 -0
  759. data/lib/chef/resource/windows_dns_zone.rb +80 -0
  760. data/lib/chef/resource/windows_env.rb +49 -49
  761. data/lib/chef/resource/windows_feature.rb +90 -90
  762. data/lib/chef/resource/windows_feature_dism.rb +222 -222
  763. data/lib/chef/resource/windows_feature_powershell.rb +262 -262
  764. data/lib/chef/resource/windows_firewall_rule.rb +204 -205
  765. data/lib/chef/resource/windows_font.rb +125 -125
  766. data/lib/chef/resource/windows_package.rb +61 -61
  767. data/lib/chef/resource/windows_pagefile.rb +206 -206
  768. data/lib/chef/resource/windows_path.rb +38 -38
  769. data/lib/chef/resource/windows_printer.rb +146 -146
  770. data/lib/chef/resource/windows_printer_port.rb +136 -136
  771. data/lib/chef/resource/windows_script.rb +65 -65
  772. data/lib/chef/resource/windows_service.rb +115 -121
  773. data/lib/chef/resource/windows_share.rb +323 -324
  774. data/lib/chef/resource/windows_shortcut.rb +79 -79
  775. data/lib/chef/resource/windows_task.rb +353 -353
  776. data/lib/chef/resource/windows_uac.rb +94 -0
  777. data/lib/chef/resource/windows_workgroup.rb +112 -112
  778. data/lib/chef/resource/yum_package.rb +79 -77
  779. data/lib/chef/resource/yum_repository.rb +187 -187
  780. data/lib/chef/resource/zypper_package.rb +46 -44
  781. data/lib/chef/resource/zypper_repository.rb +103 -103
  782. data/lib/chef/resource_builder.rb +92 -92
  783. data/lib/chef/resource_collection.rb +146 -153
  784. data/lib/chef/resource_collection/resource_collection_serialization.rb +68 -68
  785. data/lib/chef/resource_collection/resource_list.rb +106 -106
  786. data/lib/chef/resource_collection/resource_set.rb +200 -200
  787. data/lib/chef/resource_collection/stepable_iterator.rb +122 -122
  788. data/lib/chef/resource_definition.rb +68 -68
  789. data/lib/chef/resource_definition_list.rb +38 -38
  790. data/lib/chef/resource_inspector.rb +108 -108
  791. data/lib/chef/resource_reporter.rb +246 -337
  792. data/lib/chef/resource_resolver.rb +160 -160
  793. data/lib/chef/resources.rb +155 -147
  794. data/lib/chef/role.rb +274 -274
  795. data/lib/chef/run_context.rb +719 -708
  796. data/lib/chef/run_context/cookbook_compiler.rb +343 -344
  797. data/lib/chef/run_list.rb +168 -168
  798. data/lib/chef/run_list/run_list_expansion.rb +236 -236
  799. data/lib/chef/run_list/run_list_item.rb +98 -98
  800. data/lib/chef/run_list/versioned_recipe_list.rb +104 -104
  801. data/lib/chef/run_lock.rb +198 -197
  802. data/lib/chef/run_status.rb +128 -127
  803. data/lib/chef/runner.rb +148 -184
  804. data/lib/chef/sandbox.rb +20 -20
  805. data/lib/chef/scan_access_control.rb +138 -138
  806. data/lib/chef/search/query.rb +182 -182
  807. data/lib/chef/server_api.rb +83 -83
  808. data/lib/chef/server_api_versions.rb +59 -59
  809. data/lib/chef/shell.rb +354 -353
  810. data/lib/chef/shell/ext.rb +593 -593
  811. data/lib/chef/shell/model_wrapper.rb +120 -120
  812. data/lib/chef/shell/shell_session.rb +310 -310
  813. data/lib/chef/train_transport.rb +129 -0
  814. data/lib/chef/user.rb +194 -194
  815. data/lib/chef/user_v1.rb +325 -325
  816. data/lib/chef/util/backup.rb +94 -94
  817. data/lib/chef/util/diff.rb +184 -184
  818. data/lib/chef/util/dsc/configuration_generator.rb +139 -139
  819. data/lib/chef/util/dsc/lcm_output_parser.rb +192 -192
  820. data/lib/chef/util/dsc/local_configuration_manager.rb +151 -151
  821. data/lib/chef/util/dsc/resource_info.rb +26 -26
  822. data/lib/chef/util/dsc/resource_store.rb +109 -109
  823. data/lib/chef/util/editor.rb +91 -91
  824. data/lib/chef/util/file_edit.rb +100 -100
  825. data/lib/chef/util/path_helper.rb +25 -25
  826. data/lib/chef/util/powershell/cmdlet.rb +173 -173
  827. data/lib/chef/util/powershell/cmdlet_result.rb +61 -61
  828. data/lib/chef/util/powershell/ps_credential.rb +41 -41
  829. data/lib/chef/util/selinux.rb +93 -93
  830. data/lib/chef/util/threaded_job_queue.rb +61 -61
  831. data/lib/chef/util/windows.rb +24 -24
  832. data/lib/chef/util/windows/logon_session.rb +129 -129
  833. data/lib/chef/util/windows/net_group.rb +78 -78
  834. data/lib/chef/util/windows/net_use.rb +81 -81
  835. data/lib/chef/util/windows/net_user.rb +172 -172
  836. data/lib/chef/util/windows/volume.rb +49 -49
  837. data/lib/chef/version.rb +36 -36
  838. data/lib/chef/version/platform.rb +62 -62
  839. data/lib/chef/version_class.rb +75 -75
  840. data/lib/chef/version_constraint.rb +118 -118
  841. data/lib/chef/version_constraint/platform.rb +28 -28
  842. data/lib/chef/version_string.rb +143 -143
  843. data/lib/chef/whitelist.rb +86 -86
  844. data/lib/chef/win32/api.rb +372 -372
  845. data/lib/chef/win32/api/crypto.rb +63 -63
  846. data/lib/chef/win32/api/error.rb +953 -953
  847. data/lib/chef/win32/api/file.rb +620 -620
  848. data/lib/chef/win32/api/installer.rb +165 -165
  849. data/lib/chef/win32/api/memory.rb +105 -105
  850. data/lib/chef/win32/api/net.rb +328 -328
  851. data/lib/chef/win32/api/process.rb +42 -42
  852. data/lib/chef/win32/api/psapi.rb +51 -51
  853. data/lib/chef/win32/api/registry.rb +51 -51
  854. data/lib/chef/win32/api/security.rb +476 -476
  855. data/lib/chef/win32/api/synchronization.rb +89 -89
  856. data/lib/chef/win32/api/system.rb +238 -238
  857. data/lib/chef/win32/api/unicode.rb +135 -135
  858. data/lib/chef/win32/crypto.rb +50 -50
  859. data/lib/chef/win32/error.rb +86 -86
  860. data/lib/chef/win32/eventlog.rb +31 -31
  861. data/lib/chef/win32/file.rb +226 -226
  862. data/lib/chef/win32/file/info.rb +99 -99
  863. data/lib/chef/win32/file/version_info.rb +93 -93
  864. data/lib/chef/win32/handle.rb +55 -55
  865. data/lib/chef/win32/memory.rb +101 -101
  866. data/lib/chef/win32/mutex.rb +116 -116
  867. data/lib/chef/win32/net.rb +326 -326
  868. data/lib/chef/win32/process.rb +97 -97
  869. data/lib/chef/win32/registry.rb +374 -374
  870. data/lib/chef/win32/security.rb +698 -698
  871. data/lib/chef/win32/security/ace.rb +123 -123
  872. data/lib/chef/win32/security/acl.rb +103 -103
  873. data/lib/chef/win32/security/securable_object.rb +109 -109
  874. data/lib/chef/win32/security/security_descriptor.rb +93 -93
  875. data/lib/chef/win32/security/sid.rb +347 -347
  876. data/lib/chef/win32/security/token.rb +72 -72
  877. data/lib/chef/win32/system.rb +62 -62
  878. data/lib/chef/win32/unicode.rb +66 -66
  879. data/lib/chef/win32/version.rb +151 -151
  880. data/lib/chef/win32_service_constants.rb +143 -143
  881. data/lib/chef/workstation_config_loader.rb +23 -23
  882. data/spec/data/apt/chef-integration-test-1.0/debian/changelog +5 -5
  883. data/spec/data/apt/chef-integration-test-1.0/debian/compat +1 -1
  884. data/spec/data/apt/chef-integration-test-1.0/debian/control +13 -13
  885. data/spec/data/apt/chef-integration-test-1.0/debian/copyright +34 -34
  886. data/spec/data/apt/chef-integration-test-1.0/debian/files +1 -1
  887. data/spec/data/apt/chef-integration-test-1.0/debian/rules +13 -13
  888. data/spec/data/apt/chef-integration-test-1.0/debian/source/format +1 -1
  889. data/spec/data/apt/chef-integration-test-1.1/debian/changelog +11 -11
  890. data/spec/data/apt/chef-integration-test-1.1/debian/compat +1 -1
  891. data/spec/data/apt/chef-integration-test-1.1/debian/control +13 -13
  892. data/spec/data/apt/chef-integration-test-1.1/debian/copyright +34 -34
  893. data/spec/data/apt/chef-integration-test-1.1/debian/files +1 -1
  894. data/spec/data/apt/chef-integration-test-1.1/debian/rules +13 -13
  895. data/spec/data/apt/chef-integration-test-1.1/debian/source/format +1 -1
  896. data/spec/data/apt/chef-integration-test2-1.0/debian/changelog +5 -5
  897. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2.debhelper.log +45 -45
  898. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2.substvars +1 -1
  899. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/conffiles +1 -1
  900. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/control +10 -10
  901. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/md5sums +1 -1
  902. data/spec/data/apt/chef-integration-test2-1.0/debian/compat +1 -1
  903. data/spec/data/apt/chef-integration-test2-1.0/debian/conffiles +1 -1
  904. data/spec/data/apt/chef-integration-test2-1.0/debian/control +13 -13
  905. data/spec/data/apt/chef-integration-test2-1.0/debian/copyright +34 -34
  906. data/spec/data/apt/chef-integration-test2-1.0/debian/files +1 -1
  907. data/spec/data/apt/chef-integration-test2-1.0/debian/rules +13 -13
  908. data/spec/data/apt/chef-integration-test2-1.0/debian/source/format +1 -1
  909. data/spec/data/apt/chef-integration-test2_1.0-1.dsc +18 -18
  910. data/spec/data/apt/chef-integration-test2_1.0-1_amd64.build +91 -91
  911. data/spec/data/apt/chef-integration-test2_1.0-1_amd64.changes +31 -31
  912. data/spec/data/apt/chef-integration-test_1.0-1_amd64.changes +22 -22
  913. data/spec/data/apt/chef-integration-test_1.1-1_amd64.changes +22 -22
  914. data/spec/data/apt/var/www/apt/conf/distributions +7 -7
  915. data/spec/data/apt/var/www/apt/conf/incoming +4 -4
  916. data/spec/data/apt/var/www/apt/conf/pulls +3 -3
  917. data/spec/data/apt/var/www/apt/db/version +4 -4
  918. data/spec/data/apt/var/www/apt/dists/sid/Release +19 -19
  919. data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Packages +16 -16
  920. data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Release +5 -5
  921. data/spec/data/bootstrap/encrypted_data_bag_secret +1 -1
  922. data/spec/data/bootstrap/no_proxy.erb +2 -2
  923. data/spec/data/bootstrap/secret.erb +9 -9
  924. data/spec/data/bootstrap/test-hints.erb +12 -12
  925. data/spec/data/bootstrap/test.erb +1 -1
  926. data/spec/data/cb_version_cookbooks/tatft/README.rdoc +2 -2
  927. data/spec/data/cb_version_cookbooks/tatft/attributes/default.rb +1 -1
  928. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-600hhz-0 +1 -1
  929. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ahd2gq-0 +1 -1
  930. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-api8ux-0 +1 -1
  931. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-b0r1m1-0 +1 -1
  932. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-bfygsi-0 +1 -1
  933. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-el14l6-0 +1 -1
  934. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ivrl3y-0 +1 -1
  935. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-kkbs85-0 +1 -1
  936. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ory1ux-0 +1 -1
  937. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-pgsq76-0 +1 -1
  938. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ra8uim-0 +1 -1
  939. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t7k1g-0 +1 -1
  940. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t8g0sv-0 +1 -1
  941. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ufy6g3-0 +1 -1
  942. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-x2d6j9-0 +1 -1
  943. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-xi0l6h-0 +1 -1
  944. data/spec/data/client.d_00/00-foo.rb +2 -2
  945. data/spec/data/client.d_00/01-bar.rb +1 -1
  946. data/spec/data/client.d_00/02-strings.rb +2 -2
  947. data/spec/data/client.d_00/bar +1 -1
  948. data/spec/data/client.d_01/foo/bar.rb +1 -1
  949. data/spec/data/client.d_02/foo.rb/foo.txt +1 -1
  950. data/spec/data/config.rb +6 -6
  951. data/spec/data/cookbooks/angrybash/metadata.rb +2 -2
  952. data/spec/data/cookbooks/angrybash/recipes/default.rb +8 -8
  953. data/spec/data/cookbooks/apache2/files/default/apache2_module_conf_generate.pl +2 -2
  954. data/spec/data/cookbooks/apache2/metadata.rb +2 -2
  955. data/spec/data/cookbooks/apache2/recipes/default.rb +2 -2
  956. data/spec/data/cookbooks/borken/metadata.rb +2 -2
  957. data/spec/data/cookbooks/borken/recipes/default.rb +1 -1
  958. data/spec/data/cookbooks/borken/templates/default/borken.erb +1 -1
  959. data/spec/data/cookbooks/chefignore +8 -8
  960. data/spec/data/cookbooks/ignorken/files/default/not_me.rb +2 -2
  961. data/spec/data/cookbooks/ignorken/metadata.rb +2 -2
  962. data/spec/data/cookbooks/ignorken/recipes/ignoreme.rb +1 -1
  963. data/spec/data/cookbooks/ignorken/templates/ubuntu-12.10/not_me.rb +2 -2
  964. data/spec/data/cookbooks/irssi/files/default/irssi.response +2 -0
  965. data/spec/data/cookbooks/java/files/default/java.response +1 -1
  966. data/spec/data/cookbooks/java/metadata.rb +2 -2
  967. data/spec/data/cookbooks/name-mismatch-versionnumber/README.md +4 -4
  968. data/spec/data/cookbooks/name-mismatch-versionnumber/metadata.rb +8 -8
  969. data/spec/data/cookbooks/name-mismatch-versionnumber/recipes/default.rb +8 -8
  970. data/spec/data/cookbooks/openldap/attributes/default.rb +16 -16
  971. data/spec/data/cookbooks/openldap/attributes/smokey.rb +1 -1
  972. data/spec/data/cookbooks/openldap/definitions/client.rb +5 -5
  973. data/spec/data/cookbooks/openldap/definitions/server.rb +5 -5
  974. data/spec/data/cookbooks/openldap/files/default/.dotfile +1 -1
  975. data/spec/data/cookbooks/openldap/files/default/remotedir/.a_dotdir/.a_dotfile_in_a_dotdir +1 -1
  976. data/spec/data/cookbooks/openldap/files/default/remotedir/not_a_template.erb +2 -2
  977. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file1.txt +2 -2
  978. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file2.txt +2 -2
  979. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/.a_dotfile +1 -1
  980. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file1.txt +2 -2
  981. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file2.txt +2 -2
  982. data/spec/data/cookbooks/openldap/files/default/remotedir/subdir_with_no_file_just_a_subsubdir/the_subsubdir/some_file.txt +3 -3
  983. data/spec/data/cookbooks/openldap/libraries/openldap.rb +4 -4
  984. data/spec/data/cookbooks/openldap/libraries/openldap/version.rb +3 -3
  985. data/spec/data/cookbooks/openldap/metadata.rb +8 -8
  986. data/spec/data/cookbooks/openldap/recipes/default.rb +4 -4
  987. data/spec/data/cookbooks/openldap/recipes/gigantor.rb +3 -3
  988. data/spec/data/cookbooks/openldap/recipes/one.rb +15 -15
  989. data/spec/data/cookbooks/openldap/recipes/return.rb +2 -2
  990. data/spec/data/cookbooks/openldap/templates/default/helper_test.erb +1 -1
  991. data/spec/data/cookbooks/openldap/templates/default/helpers.erb +14 -14
  992. data/spec/data/cookbooks/openldap/templates/default/helpers_via_partial_test.erb +1 -1
  993. data/spec/data/cookbooks/openldap/templates/default/nested_openldap_partials.erb +1 -1
  994. data/spec/data/cookbooks/openldap/templates/default/nested_partial.erb +1 -1
  995. data/spec/data/cookbooks/openldap/templates/default/no_windows_line_endings.erb +4 -4
  996. data/spec/data/cookbooks/openldap/templates/default/openldap_nested_variable_stuff.erb +1 -1
  997. data/spec/data/cookbooks/openldap/templates/default/openldap_variable_stuff.conf.erb +1 -1
  998. data/spec/data/cookbooks/openldap/templates/default/test.erb +1 -1
  999. data/spec/data/cookbooks/preseed/files/default/preseed-file.seed +1 -1
  1000. data/spec/data/cookbooks/preseed/files/default/preseed-template.seed +4 -4
  1001. data/spec/data/cookbooks/preseed/metadata.rb +2 -2
  1002. data/spec/data/cookbooks/preseed/templates/default/preseed-template-variables.seed +1 -1
  1003. data/spec/data/cookbooks/preseed/templates/default/preseed-template.seed +1 -1
  1004. data/spec/data/cookbooks/supports-platform-constraints/metadata.rb +5 -5
  1005. data/spec/data/cookbooks/wget/files/default/wget.response +2 -0
  1006. data/spec/data/definitions/test.rb +4 -4
  1007. data/spec/data/environment-config.rb +4 -4
  1008. data/spec/data/file-providers-method-snapshot-chef-11-4.json +127 -127
  1009. data/spec/data/fileedit/hosts +4 -4
  1010. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/README.md +4 -4
  1011. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/metadata.rb +13 -13
  1012. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/recipes/default.rb +8 -8
  1013. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/README.md +4 -4
  1014. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/metadata.rb +9 -9
  1015. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/recipes/default.rb +8 -8
  1016. data/spec/data/kitchen/chefignore +6 -6
  1017. data/spec/data/kitchen/openldap/attributes/default.rb +3 -3
  1018. data/spec/data/kitchen/openldap/attributes/robinson.rb +2 -2
  1019. data/spec/data/kitchen/openldap/definitions/client.rb +3 -3
  1020. data/spec/data/kitchen/openldap/definitions/drewbarrymore.rb +2 -2
  1021. data/spec/data/kitchen/openldap/recipes/gigantor.rb +2 -2
  1022. data/spec/data/kitchen/openldap/recipes/ignoreme.rb +2 -2
  1023. data/spec/data/kitchen/openldap/recipes/woot.rb +3 -3
  1024. data/spec/data/knife_subcommand/test_explicit_category.rb +6 -6
  1025. data/spec/data/knife_subcommand/test_name_mapping.rb +4 -4
  1026. data/spec/data/knife_subcommand/test_yourself.rb +21 -21
  1027. data/spec/data/lwrp/providers/buck_passer.rb +28 -28
  1028. data/spec/data/lwrp/providers/buck_passer_2.rb +26 -26
  1029. data/spec/data/lwrp/providers/embedded_resource_accesses_providers_scope.rb +28 -28
  1030. data/spec/data/lwrp/providers/inline_compiler.rb +24 -24
  1031. data/spec/data/lwrp/providers/monkey_name_printer.rb +5 -5
  1032. data/spec/data/lwrp/providers/paint_drying_watcher.rb +7 -7
  1033. data/spec/data/lwrp/providers/thumb_twiddler.rb +7 -7
  1034. data/spec/data/lwrp/resources/bar.rb +2 -2
  1035. data/spec/data/lwrp/resources/buck_passer.rb +5 -5
  1036. data/spec/data/lwrp/resources/buck_passer_2.rb +3 -3
  1037. data/spec/data/lwrp/resources/embedded_resource_accesses_providers_scope.rb +3 -3
  1038. data/spec/data/lwrp/resources/foo.rb +4 -4
  1039. data/spec/data/lwrp/resources/inline_compiler.rb +3 -3
  1040. data/spec/data/lwrp/resources/monkey_name_printer.rb +5 -5
  1041. data/spec/data/lwrp/resources/paint_drying_watcher.rb +3 -3
  1042. data/spec/data/lwrp/resources/thumb_twiddler.rb +3 -3
  1043. data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +1 -1
  1044. data/spec/data/lwrp_override/providers/buck_passer.rb +5 -5
  1045. data/spec/data/lwrp_override/resources/foo.rb +10 -10
  1046. data/spec/data/mac_users/10.9.plist.xml +560 -560
  1047. data/spec/data/mac_users/10.9.shadow.xml +21 -21
  1048. data/spec/data/metadata/quick_start/metadata.rb +14 -14
  1049. data/spec/data/mixin/invalid_data.rb +3 -3
  1050. data/spec/data/mixin/real_data.rb +2 -2
  1051. data/spec/data/nested.json +2 -2
  1052. data/spec/data/nodes/default.rb +15 -15
  1053. data/spec/data/nodes/test.example.com.rb +17 -17
  1054. data/spec/data/nodes/test.rb +15 -15
  1055. data/spec/data/null_config.rb +1 -1
  1056. data/spec/data/object_loader/environments/test.json +7 -7
  1057. data/spec/data/object_loader/environments/test.rb +2 -2
  1058. data/spec/data/object_loader/environments/test_json_class.json +8 -8
  1059. data/spec/data/object_loader/nodes/test.json +7 -7
  1060. data/spec/data/object_loader/nodes/test.rb +2 -2
  1061. data/spec/data/object_loader/nodes/test_json_class.json +8 -8
  1062. data/spec/data/object_loader/roles/test.json +7 -7
  1063. data/spec/data/object_loader/roles/test.rb +2 -2
  1064. data/spec/data/object_loader/roles/test_json_class.json +8 -8
  1065. data/spec/data/partial_one.erb +1 -1
  1066. data/spec/data/prefer_metadata_json/metadata.json +51 -51
  1067. data/spec/data/prefer_metadata_json/metadata.rb +6 -6
  1068. data/spec/data/recipes/test.rb +7 -7
  1069. data/spec/data/root_alias_cookbooks/dup_attr/attributes.rb +1 -1
  1070. data/spec/data/root_alias_cookbooks/dup_attr/attributes/default.rb +1 -1
  1071. data/spec/data/root_alias_cookbooks/dup_attr/metadata.rb +2 -2
  1072. data/spec/data/root_alias_cookbooks/dup_attr/recipe.rb +3 -3
  1073. data/spec/data/root_alias_cookbooks/dup_recipe/attributes.rb +1 -1
  1074. data/spec/data/root_alias_cookbooks/dup_recipe/metadata.rb +2 -2
  1075. data/spec/data/root_alias_cookbooks/dup_recipe/recipe.rb +3 -3
  1076. data/spec/data/root_alias_cookbooks/dup_recipe/recipes/default.rb +3 -3
  1077. data/spec/data/root_alias_cookbooks/simple/attributes.rb +1 -1
  1078. data/spec/data/root_alias_cookbooks/simple/metadata.rb +2 -2
  1079. data/spec/data/root_alias_cookbooks/simple/recipe.rb +3 -3
  1080. data/spec/data/run_context/cookbooks/circular-dep1/attributes/default.rb +2 -2
  1081. data/spec/data/run_context/cookbooks/circular-dep1/definitions/circular_dep1_res.rb +1 -1
  1082. data/spec/data/run_context/cookbooks/circular-dep1/libraries/lib.rb +2 -2
  1083. data/spec/data/run_context/cookbooks/circular-dep1/metadata.rb +2 -2
  1084. data/spec/data/run_context/cookbooks/circular-dep1/providers/provider.rb +1 -1
  1085. data/spec/data/run_context/cookbooks/circular-dep1/resources/resource.rb +1 -1
  1086. data/spec/data/run_context/cookbooks/circular-dep2/attributes/default.rb +2 -2
  1087. data/spec/data/run_context/cookbooks/circular-dep2/definitions/circular_dep2_res.rb +1 -1
  1088. data/spec/data/run_context/cookbooks/circular-dep2/libraries/lib.rb +2 -2
  1089. data/spec/data/run_context/cookbooks/circular-dep2/metadata.rb +2 -2
  1090. data/spec/data/run_context/cookbooks/circular-dep2/providers/provider.rb +1 -1
  1091. data/spec/data/run_context/cookbooks/circular-dep2/resources/resource.rb +1 -1
  1092. data/spec/data/run_context/cookbooks/dependency1/attributes/aa_first.rb +2 -2
  1093. data/spec/data/run_context/cookbooks/dependency1/attributes/default.rb +2 -2
  1094. data/spec/data/run_context/cookbooks/dependency1/attributes/unparsed_file +1 -0
  1095. data/spec/data/run_context/cookbooks/dependency1/attributes/zz_last.rb +2 -2
  1096. data/spec/data/run_context/cookbooks/dependency1/definitions/dependency1_res.rb +1 -1
  1097. data/spec/data/run_context/cookbooks/dependency1/definitions/unparsed_file +1 -0
  1098. data/spec/data/run_context/cookbooks/dependency1/libraries/lib.rb +2 -2
  1099. data/spec/data/run_context/cookbooks/dependency1/libraries/unparsed_file +1 -0
  1100. data/spec/data/run_context/cookbooks/dependency1/providers/provider.rb +1 -1
  1101. data/spec/data/run_context/cookbooks/dependency1/providers/unparsed_file +1 -0
  1102. data/spec/data/run_context/cookbooks/dependency1/recipes/unparsed_file +1 -0
  1103. data/spec/data/run_context/cookbooks/dependency1/resources/resource.rb +1 -1
  1104. data/spec/data/run_context/cookbooks/dependency1/resources/unparsed_file +1 -0
  1105. data/spec/data/run_context/cookbooks/dependency2/attributes/default.rb +2 -2
  1106. data/spec/data/run_context/cookbooks/dependency2/definitions/dependency2_res.rb +1 -1
  1107. data/spec/data/run_context/cookbooks/dependency2/libraries/lib.rb +2 -2
  1108. data/spec/data/run_context/cookbooks/dependency2/providers/provider.rb +1 -1
  1109. data/spec/data/run_context/cookbooks/dependency2/resources/resource.rb +1 -1
  1110. data/spec/data/run_context/cookbooks/include/recipes/default.rb +24 -24
  1111. data/spec/data/run_context/cookbooks/include/recipes/includee.rb +3 -3
  1112. data/spec/data/run_context/cookbooks/no-default-attr/attributes/server.rb +2 -2
  1113. data/spec/data/run_context/cookbooks/no-default-attr/definitions/no_default-attr_res.rb +1 -1
  1114. data/spec/data/run_context/cookbooks/no-default-attr/providers/provider.rb +1 -1
  1115. data/spec/data/run_context/cookbooks/no-default-attr/resources/resource.rb +1 -1
  1116. data/spec/data/run_context/cookbooks/test-with-circular-deps/attributes/default.rb +2 -2
  1117. data/spec/data/run_context/cookbooks/test-with-circular-deps/definitions/test_with-circular-deps_res.rb +1 -1
  1118. data/spec/data/run_context/cookbooks/test-with-circular-deps/libraries/lib.rb +2 -2
  1119. data/spec/data/run_context/cookbooks/test-with-circular-deps/metadata.rb +2 -2
  1120. data/spec/data/run_context/cookbooks/test-with-circular-deps/providers/provider.rb +1 -1
  1121. data/spec/data/run_context/cookbooks/test-with-circular-deps/resources/resource.rb +1 -1
  1122. data/spec/data/run_context/cookbooks/test-with-deps/attributes/default.rb +2 -2
  1123. data/spec/data/run_context/cookbooks/test-with-deps/definitions/test_with-deps_res.rb +1 -1
  1124. data/spec/data/run_context/cookbooks/test-with-deps/libraries/lib.rb +1 -1
  1125. data/spec/data/run_context/cookbooks/test-with-deps/metadata.rb +3 -3
  1126. data/spec/data/run_context/cookbooks/test-with-deps/providers/provider.rb +1 -1
  1127. data/spec/data/run_context/cookbooks/test-with-deps/resources/resource.rb +1 -1
  1128. data/spec/data/run_context/cookbooks/test/attributes/george.rb +1 -1
  1129. data/spec/data/run_context/cookbooks/test/definitions/new_animals.rb +9 -9
  1130. data/spec/data/run_context/cookbooks/test/definitions/new_cat.rb +5 -5
  1131. data/spec/data/run_context/cookbooks/test/definitions/test_res.rb +1 -1
  1132. data/spec/data/run_context/cookbooks/test/providers/provider.rb +1 -1
  1133. data/spec/data/run_context/cookbooks/test/recipes/default.rb +5 -5
  1134. data/spec/data/run_context/cookbooks/test/recipes/one.rb +7 -7
  1135. data/spec/data/run_context/cookbooks/test/recipes/two.rb +7 -7
  1136. data/spec/data/run_context/cookbooks/test/resources/resource.rb +1 -1
  1137. data/spec/data/run_context/nodes/run_context.rb +5 -5
  1138. data/spec/data/sample_msu1.xml +10 -10
  1139. data/spec/data/sample_msu2.xml +14 -14
  1140. data/spec/data/sample_msu3.xml +16 -16
  1141. data/spec/data/search_queries_to_transform.txt +98 -98
  1142. data/spec/data/shef-config.rb +11 -11
  1143. data/spec/data/snap_package/async_result_success.json +6 -0
  1144. data/spec/data/snap_package/change_id_result.json +175 -0
  1145. data/spec/data/snap_package/find_result_failure.json +10 -0
  1146. data/spec/data/snap_package/find_result_success.json +70 -0
  1147. data/spec/data/snap_package/get_by_name_result_failure.json +10 -0
  1148. data/spec/data/snap_package/get_by_name_result_success.json +38 -0
  1149. data/spec/data/snap_package/get_conf_success.json +10 -0
  1150. data/spec/data/snap_package/result_failure.json +9 -0
  1151. data/spec/data/ssl/5e707473.0 +18 -18
  1152. data/spec/data/ssl/chef-rspec.cert +27 -27
  1153. data/spec/data/ssl/chef-rspec.key +27 -27
  1154. data/spec/data/ssl/key.pem +15 -15
  1155. data/spec/data/ssl/private_key.pem +27 -27
  1156. data/spec/data/ssl/private_key_with_whitespace.pem +32 -32
  1157. data/spec/data/standalone_cookbook/chefignore +9 -9
  1158. data/spec/data/standalone_cookbook/recipes/default.rb +2 -2
  1159. data/spec/data/trusted_certs/example.crt +22 -22
  1160. data/spec/data/trusted_certs/example_no_cn.crt +36 -36
  1161. data/spec/data/trusted_certs/intermediate.pem +27 -27
  1162. data/spec/data/trusted_certs/opscode.pem +57 -57
  1163. data/spec/data/trusted_certs/root.pem +22 -22
  1164. data/spec/data/trusted_certs_empty/.gitkeep +0 -0
  1165. data/spec/data/trusted_certs_empty/README.md +1 -0
  1166. data/spec/data/windows_certificates/base64_test.cer +22 -22
  1167. data/spec/data/windows_certificates/test.pem +21 -21
  1168. data/spec/functional/application_spec.rb +58 -58
  1169. data/spec/functional/assets/chefinittest +36 -36
  1170. data/spec/functional/assets/testchefsubsys +10 -10
  1171. data/spec/functional/assets/yumrepo/repodata/repomd.xml +21 -21
  1172. data/spec/functional/dsl/reboot_pending_spec.rb +87 -88
  1173. data/spec/functional/dsl/registry_helper_spec.rb +61 -61
  1174. data/spec/functional/event_loggers/windows_eventlog_spec.rb +104 -106
  1175. data/spec/functional/file_content_management/deploy_strategies_spec.rb +229 -229
  1176. data/spec/functional/http/simple_spec.rb +146 -146
  1177. data/spec/functional/knife/configure_spec.rb +33 -33
  1178. data/spec/functional/knife/cookbook_delete_spec.rb +156 -156
  1179. data/spec/functional/knife/exec_spec.rb +55 -55
  1180. data/spec/functional/knife/rehash_spec.rb +39 -39
  1181. data/spec/functional/knife/smoke_test.rb +42 -42
  1182. data/spec/functional/knife/ssh_spec.rb +359 -359
  1183. data/spec/functional/mixin/from_file_spec.rb +82 -82
  1184. data/spec/functional/mixin/powershell_out_spec.rb +43 -43
  1185. data/spec/functional/mixin/shell_out_spec.rb +48 -78
  1186. data/spec/functional/mixin/user_context_spec.rb +117 -119
  1187. data/spec/functional/notifications_spec.rb +238 -238
  1188. data/spec/functional/provider/remote_file/cache_control_data_spec.rb +100 -100
  1189. data/spec/functional/provider/whyrun_safe_ruby_block_spec.rb +51 -51
  1190. data/spec/functional/rebooter_spec.rb +117 -117
  1191. data/spec/functional/resource/aix_service_spec.rb +138 -138
  1192. data/spec/functional/resource/aixinit_service_spec.rb +211 -211
  1193. data/spec/functional/resource/apt_package_spec.rb +386 -386
  1194. data/spec/functional/resource/base.rb +28 -28
  1195. data/spec/functional/resource/bash_spec.rb +54 -54
  1196. data/spec/functional/resource/batch_spec.rb +34 -34
  1197. data/spec/functional/resource/bff_spec.rb +120 -120
  1198. data/spec/functional/resource/chocolatey_package_spec.rb +118 -118
  1199. data/spec/functional/resource/cookbook_file_spec.rb +81 -79
  1200. data/spec/functional/resource/cron_spec.rb +179 -180
  1201. data/spec/functional/resource/directory_spec.rb +43 -43
  1202. data/spec/functional/resource/dnf_package_spec.rb +686 -686
  1203. data/spec/functional/resource/dpkg_package_spec.rb +339 -339
  1204. data/spec/functional/resource/dsc_resource_spec.rb +90 -91
  1205. data/spec/functional/resource/dsc_script_spec.rb +484 -480
  1206. data/spec/functional/resource/execute_spec.rb +171 -171
  1207. data/spec/functional/resource/file_spec.rb +167 -167
  1208. data/spec/functional/resource/git_spec.rb +257 -257
  1209. data/spec/functional/resource/group_spec.rb +464 -499
  1210. data/spec/functional/resource/ifconfig_spec.rb +172 -170
  1211. data/spec/functional/resource/link_spec.rb +699 -699
  1212. data/spec/functional/resource/locale_spec.rb +97 -0
  1213. data/spec/functional/resource/mount_spec.rb +207 -203
  1214. data/spec/functional/resource/msu_package_spec.rb +98 -98
  1215. data/spec/functional/resource/ohai_spec.rb +62 -62
  1216. data/spec/functional/resource/powershell_script_spec.rb +605 -600
  1217. data/spec/functional/resource/reboot_spec.rb +103 -103
  1218. data/spec/functional/resource/registry_spec.rb +676 -676
  1219. data/spec/functional/resource/remote_directory_spec.rb +220 -220
  1220. data/spec/functional/resource/remote_file_spec.rb +424 -424
  1221. data/spec/functional/resource/rpm_spec.rb +120 -120
  1222. data/spec/functional/resource/template_spec.rb +245 -245
  1223. data/spec/functional/resource/timezone_spec.rb +39 -39
  1224. data/spec/functional/resource/user/dscl_spec.rb +188 -195
  1225. data/spec/functional/resource/user/windows_spec.rb +245 -245
  1226. data/spec/functional/resource/windows_certificate_spec.rb +492 -492
  1227. data/spec/functional/resource/windows_env_spec.rb +285 -285
  1228. data/spec/functional/resource/windows_package_spec.rb +168 -168
  1229. data/spec/functional/resource/windows_path_spec.rb +64 -64
  1230. data/spec/functional/resource/windows_service_spec.rb +102 -102
  1231. data/spec/functional/resource/windows_task_spec.rb +1969 -1968
  1232. data/spec/functional/resource/yum_package_spec.rb +978 -959
  1233. data/spec/functional/resource/zypper_package_spec.rb +233 -233
  1234. data/spec/functional/root_alias_spec.rb +78 -78
  1235. data/spec/functional/run_lock_spec.rb +473 -480
  1236. data/spec/functional/shell_spec.rb +145 -146
  1237. data/spec/functional/tiny_server_spec.rb +79 -79
  1238. data/spec/functional/util/path_helper_spec.rb +37 -37
  1239. data/spec/functional/util/powershell/cmdlet_spec.rb +111 -111
  1240. data/spec/functional/version_spec.rb +35 -35
  1241. data/spec/functional/win32/crypto_spec.rb +54 -54
  1242. data/spec/functional/win32/registry_spec.rb +624 -624
  1243. data/spec/functional/win32/security_spec.rb +206 -211
  1244. data/spec/functional/win32/service_manager_spec.rb +220 -220
  1245. data/spec/functional/win32/sid_spec.rb +55 -55
  1246. data/spec/functional/win32/version_info_spec.rb +50 -50
  1247. data/spec/functional/win32/versions_spec.rb +115 -115
  1248. data/spec/integration/client/client_spec.rb +721 -714
  1249. data/spec/integration/client/exit_code_spec.rb +114 -142
  1250. data/spec/integration/client/ipv6_spec.rb +134 -134
  1251. data/spec/integration/knife/chef_fs_data_store_spec.rb +556 -556
  1252. data/spec/integration/knife/chef_repo_path_spec.rb +959 -961
  1253. data/spec/integration/knife/chef_repository_file_system_spec.rb +199 -199
  1254. data/spec/integration/knife/chefignore_spec.rb +300 -300
  1255. data/spec/integration/knife/client_bulk_delete_spec.rb +130 -130
  1256. data/spec/integration/knife/client_create_spec.rb +69 -69
  1257. data/spec/integration/knife/client_delete_spec.rb +63 -63
  1258. data/spec/integration/knife/client_key_create_spec.rb +65 -65
  1259. data/spec/integration/knife/client_key_delete_spec.rb +42 -42
  1260. data/spec/integration/knife/client_key_list_spec.rb +60 -60
  1261. data/spec/integration/knife/client_key_show_spec.rb +44 -44
  1262. data/spec/integration/knife/client_list_spec.rb +48 -48
  1263. data/spec/integration/knife/client_show_spec.rb +36 -36
  1264. data/spec/integration/knife/common_options_spec.rb +173 -173
  1265. data/spec/integration/knife/config_get_profile_spec.rb +112 -112
  1266. data/spec/integration/knife/config_get_spec.rb +183 -190
  1267. data/spec/integration/knife/config_list_profiles_spec.rb +188 -189
  1268. data/spec/integration/knife/config_use_profile_spec.rb +100 -100
  1269. data/spec/integration/knife/cookbook_api_ipv6_spec.rb +112 -112
  1270. data/spec/integration/knife/cookbook_bulk_delete_spec.rb +64 -64
  1271. data/spec/integration/knife/cookbook_download_spec.rb +71 -71
  1272. data/spec/integration/knife/cookbook_list_spec.rb +54 -54
  1273. data/spec/integration/knife/cookbook_show_spec.rb +146 -148
  1274. data/spec/integration/knife/cookbook_upload_spec.rb +90 -90
  1275. data/spec/integration/knife/data_bag_create_spec.rb +124 -124
  1276. data/spec/integration/knife/data_bag_delete_spec.rb +58 -58
  1277. data/spec/integration/knife/data_bag_edit_spec.rb +104 -104
  1278. data/spec/integration/knife/data_bag_from_file_spec.rb +115 -115
  1279. data/spec/integration/knife/data_bag_list_spec.rb +43 -43
  1280. data/spec/integration/knife/data_bag_show_spec.rb +94 -94
  1281. data/spec/integration/knife/delete_spec.rb +1017 -1017
  1282. data/spec/integration/knife/deps_spec.rb +702 -702
  1283. data/spec/integration/knife/diff_spec.rb +602 -602
  1284. data/spec/integration/knife/download_spec.rb +1333 -1333
  1285. data/spec/integration/knife/environment_compare_spec.rb +74 -74
  1286. data/spec/integration/knife/environment_create_spec.rb +40 -40
  1287. data/spec/integration/knife/environment_delete_spec.rb +36 -36
  1288. data/spec/integration/knife/environment_from_file_spec.rb +115 -115
  1289. data/spec/integration/knife/environment_list_spec.rb +41 -41
  1290. data/spec/integration/knife/environment_show_spec.rb +76 -76
  1291. data/spec/integration/knife/list_spec.rb +1059 -1059
  1292. data/spec/integration/knife/node_bulk_delete_spec.rb +51 -51
  1293. data/spec/integration/knife/node_create_spec.rb +46 -46
  1294. data/spec/integration/knife/node_delete_spec.rb +47 -47
  1295. data/spec/integration/knife/node_environment_set_spec.rb +45 -45
  1296. data/spec/integration/knife/node_from_file_spec.rb +58 -58
  1297. data/spec/integration/knife/node_list_spec.rb +44 -44
  1298. data/spec/integration/knife/node_run_list_add_spec.rb +53 -53
  1299. data/spec/integration/knife/node_run_list_remove_spec.rb +35 -35
  1300. data/spec/integration/knife/node_run_list_set_spec.rb +40 -40
  1301. data/spec/integration/knife/node_show_spec.rb +35 -35
  1302. data/spec/integration/knife/raw_spec.rb +248 -248
  1303. data/spec/integration/knife/redirection_spec.rb +54 -54
  1304. data/spec/integration/knife/role_bulk_delete_spec.rb +51 -51
  1305. data/spec/integration/knife/role_create_spec.rb +40 -40
  1306. data/spec/integration/knife/role_delete_spec.rb +47 -47
  1307. data/spec/integration/knife/role_from_file_spec.rb +95 -95
  1308. data/spec/integration/knife/role_list_spec.rb +44 -44
  1309. data/spec/integration/knife/role_show_spec.rb +50 -50
  1310. data/spec/integration/knife/search_node_spec.rb +39 -39
  1311. data/spec/integration/knife/serve_spec.rb +93 -93
  1312. data/spec/integration/knife/show_spec.rb +167 -167
  1313. data/spec/integration/knife/upload_spec.rb +1540 -1540
  1314. data/spec/integration/recipes/accumulator_spec.rb +232 -232
  1315. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +171 -171
  1316. data/spec/integration/recipes/lwrp_spec.rb +53 -53
  1317. data/spec/integration/recipes/noop_resource_spec.rb +24 -24
  1318. data/spec/integration/recipes/notifies_spec.rb +394 -394
  1319. data/spec/integration/recipes/notifying_block_spec.rb +111 -111
  1320. data/spec/integration/recipes/provider_choice.rb +37 -36
  1321. data/spec/integration/recipes/recipe_dsl_spec.rb +1373 -1373
  1322. data/spec/integration/recipes/remote_directory.rb +74 -74
  1323. data/spec/integration/recipes/resource_action_spec.rb +504 -504
  1324. data/spec/integration/recipes/resource_converge_if_changed_spec.rb +552 -552
  1325. data/spec/integration/recipes/resource_load_spec.rb +192 -192
  1326. data/spec/integration/solo/solo_spec.rb +217 -217
  1327. data/spec/rcov.opts +2 -2
  1328. data/spec/scripts/ssl-serve.rb +47 -47
  1329. data/spec/spec_helper.rb +326 -329
  1330. data/spec/stress/win32/file_spec.rb +37 -37
  1331. data/spec/stress/win32/memory_spec.rb +22 -22
  1332. data/spec/stress/win32/security_spec.rb +69 -69
  1333. data/spec/support/chef_helpers.rb +114 -115
  1334. data/spec/support/key_helpers.rb +104 -104
  1335. data/spec/support/lib/chef/provider/easy.rb +35 -35
  1336. data/spec/support/lib/chef/provider/openldap_includer.rb +29 -29
  1337. data/spec/support/lib/chef/provider/snakeoil.rb +42 -42
  1338. data/spec/support/lib/chef/resource/cat.rb +39 -39
  1339. data/spec/support/lib/chef/resource/one_two_three_four.rb +36 -36
  1340. data/spec/support/lib/chef/resource/openldap_includer.rb +28 -28
  1341. data/spec/support/lib/chef/resource/with_state.rb +30 -30
  1342. data/spec/support/lib/chef/resource/zen_follower.rb +35 -35
  1343. data/spec/support/lib/chef/resource/zen_master.rb +40 -40
  1344. data/spec/support/lib/library_load_order.rb +20 -20
  1345. data/spec/support/matchers/leak.rb +98 -98
  1346. data/spec/support/mock/constant.rb +52 -52
  1347. data/spec/support/mock/platform.rb +25 -25
  1348. data/spec/support/platform_helpers.rb +251 -285
  1349. data/spec/support/platforms/prof/gc.rb +51 -51
  1350. data/spec/support/platforms/prof/win32.rb +45 -45
  1351. data/spec/support/platforms/win32/spec_service.rb +59 -55
  1352. data/spec/support/shared/context/config.rb +21 -21
  1353. data/spec/support/shared/context/win32.rb +34 -34
  1354. data/spec/support/shared/functional/diff_disabled.rb +10 -10
  1355. data/spec/support/shared/functional/directory_resource.rb +178 -178
  1356. data/spec/support/shared/functional/execute_resource.rb +150 -150
  1357. data/spec/support/shared/functional/file_resource.rb +1050 -1048
  1358. data/spec/support/shared/functional/http.rb +248 -224
  1359. data/spec/support/shared/functional/knife.rb +37 -37
  1360. data/spec/support/shared/functional/securable_resource.rb +578 -574
  1361. data/spec/support/shared/functional/securable_resource_with_reporting.rb +394 -394
  1362. data/spec/support/shared/functional/win32_service.rb +57 -57
  1363. data/spec/support/shared/functional/windows_script.rb +272 -273
  1364. data/spec/support/shared/integration/app_server_support.rb +40 -39
  1365. data/spec/support/shared/integration/integration_helper.rb +154 -155
  1366. data/spec/support/shared/integration/knife_support.rb +196 -196
  1367. data/spec/support/shared/matchers/exit_with_code.rb +32 -32
  1368. data/spec/support/shared/matchers/match_environment_variable.rb +17 -17
  1369. data/spec/support/shared/shared_examples.rb +14 -14
  1370. data/spec/support/shared/unit/api_error_inspector.rb +190 -190
  1371. data/spec/support/shared/unit/api_versioning.rb +77 -77
  1372. data/spec/support/shared/unit/application_dot_d.rb +75 -81
  1373. data/spec/support/shared/unit/execute_resource.rb +168 -168
  1374. data/spec/support/shared/unit/file_system_support.rb +69 -70
  1375. data/spec/support/shared/unit/knife_shared.rb +39 -39
  1376. data/spec/support/shared/unit/mock_shellout.rb +49 -49
  1377. data/spec/support/shared/unit/platform_introspector.rb +189 -189
  1378. data/spec/support/shared/unit/provider/file.rb +854 -854
  1379. data/spec/support/shared/unit/provider/package/package_shared.rb +95 -0
  1380. data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +402 -402
  1381. data/spec/support/shared/unit/resource/static_provider_resolution.rb +63 -63
  1382. data/spec/support/shared/unit/script_resource.rb +90 -90
  1383. data/spec/support/shared/unit/user_and_client_shared.rb +114 -114
  1384. data/spec/support/shared/unit/windows_script_resource.rb +80 -80
  1385. data/spec/tiny_server.rb +191 -191
  1386. data/{bin/chef-apply → spec/unit/action_collection_spec.rb} +19 -24
  1387. data/spec/unit/api_client/registration_spec.rb +278 -278
  1388. data/spec/unit/api_client_spec.rb +341 -341
  1389. data/spec/unit/api_client_v1_spec.rb +455 -455
  1390. data/spec/unit/application/apply_spec.rb +113 -113
  1391. data/spec/unit/application/client_spec.rb +595 -559
  1392. data/spec/unit/application/exit_code_spec.rb +134 -145
  1393. data/spec/unit/application/knife_spec.rb +225 -228
  1394. data/spec/unit/application/solo_spec.rb +220 -225
  1395. data/spec/unit/application_spec.rb +493 -486
  1396. data/spec/unit/chef_class_spec.rb +240 -240
  1397. data/spec/unit/chef_fs/config_spec.rb +235 -235
  1398. data/spec/unit/chef_fs/data_handler/data_bag_item_data_handler.rb +82 -82
  1399. data/spec/unit/chef_fs/data_handler/data_handler_base_spec.rb +65 -65
  1400. data/spec/unit/chef_fs/data_handler/group_handler_spec.rb +63 -63
  1401. data/spec/unit/chef_fs/diff_spec.rb +328 -328
  1402. data/spec/unit/chef_fs/file_pattern_spec.rb +512 -512
  1403. data/spec/unit/chef_fs/file_system/cookbook_subdir_spec.rb +34 -34
  1404. data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +47 -47
  1405. data/spec/unit/chef_fs/file_system/repository/base_file_spec.rb +126 -126
  1406. data/spec/unit/chef_fs/file_system/repository/directory_spec.rb +175 -175
  1407. data/spec/unit/chef_fs/file_system_spec.rb +148 -148
  1408. data/spec/unit/chef_fs/parallelizer.rb +475 -477
  1409. data/spec/unit/chef_fs/path_util_spec.rb +108 -108
  1410. data/spec/unit/chef_spec.rb +25 -25
  1411. data/spec/unit/client_spec.rb +785 -595
  1412. data/spec/unit/config_fetcher_spec.rb +125 -125
  1413. data/spec/unit/config_spec.rb +31 -31
  1414. data/spec/unit/cookbook/chefignore_spec.rb +49 -49
  1415. data/spec/unit/cookbook/cookbook_version_loader_spec.rb +210 -210
  1416. data/spec/unit/cookbook/file_vendor_spec.rb +123 -123
  1417. data/spec/unit/cookbook/gem_installer_spec.rb +92 -113
  1418. data/spec/unit/cookbook/manifest_v0_spec.rb +133 -133
  1419. data/spec/unit/cookbook/manifest_v2_spec.rb +70 -70
  1420. data/spec/unit/cookbook/metadata_spec.rb +600 -892
  1421. data/spec/unit/cookbook/synchronizer_spec.rb +557 -557
  1422. data/spec/unit/cookbook/syntax_check_spec.rb +226 -226
  1423. data/spec/unit/cookbook_loader_spec.rb +265 -302
  1424. data/spec/unit/cookbook_manifest_spec.rb +228 -228
  1425. data/spec/unit/cookbook_site_streaming_uploader_spec.rb +199 -198
  1426. data/spec/unit/cookbook_spec.rb +62 -62
  1427. data/spec/unit/cookbook_uploader_spec.rb +199 -199
  1428. data/spec/unit/cookbook_version_file_specificity_spec.rb +623 -623
  1429. data/spec/unit/cookbook_version_spec.rb +250 -250
  1430. data/spec/unit/daemon_spec.rb +183 -183
  1431. data/spec/unit/data_bag_item_spec.rb +392 -392
  1432. data/spec/unit/data_bag_spec.rb +260 -260
  1433. data/spec/unit/data_collector_spec.rb +882 -876
  1434. data/spec/unit/decorator/lazy_array_spec.rb +58 -58
  1435. data/spec/unit/decorator/lazy_spec.rb +39 -39
  1436. data/spec/unit/decorator_spec.rb +142 -142
  1437. data/spec/unit/deprecated_spec.rb +65 -65
  1438. data/spec/unit/deprecation_spec.rb +129 -129
  1439. data/spec/unit/digester_spec.rb +49 -49
  1440. data/spec/unit/dsl/data_query_spec.rb +107 -108
  1441. data/spec/unit/dsl/declare_resource_spec.rb +374 -374
  1442. data/spec/unit/dsl/platform_introspection_spec.rb +129 -129
  1443. data/spec/unit/dsl/reboot_pending_spec.rb +87 -87
  1444. data/spec/unit/dsl/recipe_spec.rb +76 -76
  1445. data/spec/unit/dsl/registry_helper_spec.rb +52 -52
  1446. data/spec/unit/dsl/resources_spec.rb +85 -85
  1447. data/spec/unit/encrypted_data_bag_item/check_encrypted_spec.rb +96 -97
  1448. data/spec/unit/encrypted_data_bag_item_spec.rb +438 -439
  1449. data/spec/unit/environment_spec.rb +470 -470
  1450. data/spec/unit/event_dispatch/dispatcher_spec.rb +169 -122
  1451. data/spec/unit/event_dispatch/dsl_spec.rb +83 -83
  1452. data/spec/unit/exceptions_spec.rb +132 -132
  1453. data/spec/unit/file_access_control_spec.rb +308 -308
  1454. data/spec/unit/file_cache_spec.rb +114 -114
  1455. data/spec/unit/file_content_management/deploy/cp_spec.rb +44 -44
  1456. data/spec/unit/file_content_management/deploy/mv_unix_spec.rb +113 -113
  1457. data/spec/unit/file_content_management/deploy/mv_windows_spec.rb +232 -232
  1458. data/spec/unit/file_content_management/tempfile_spec.rb +115 -115
  1459. data/spec/unit/formatters/base_spec.rb +100 -100
  1460. data/spec/unit/formatters/doc_spec.rb +92 -110
  1461. data/spec/unit/formatters/error_description_spec.rb +141 -141
  1462. data/spec/unit/formatters/error_inspectors/api_error_formatting_spec.rb +76 -76
  1463. data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +265 -265
  1464. data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +126 -126
  1465. data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +43 -43
  1466. data/spec/unit/formatters/error_inspectors/node_load_error_inspector_spec.rb +26 -26
  1467. data/spec/unit/formatters/error_inspectors/registration_error_inspector_spec.rb +26 -26
  1468. data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +191 -191
  1469. data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +91 -91
  1470. data/spec/unit/guard_interpreter/resource_guard_interpreter_spec.rb +155 -155
  1471. data/spec/unit/guard_interpreter_spec.rb +41 -41
  1472. data/spec/unit/handler/json_file_spec.rb +63 -63
  1473. data/spec/unit/handler_spec.rb +302 -302
  1474. data/spec/unit/http/api_versions_spec.rb +82 -82
  1475. data/spec/unit/http/authenticator_spec.rb +125 -126
  1476. data/spec/unit/http/basic_client_spec.rb +72 -72
  1477. data/spec/unit/http/http_request_spec.rb +97 -97
  1478. data/spec/unit/http/json_input_spec.rb +128 -128
  1479. data/spec/unit/http/simple_spec.rb +32 -32
  1480. data/spec/unit/http/socketless_chef_zero_client_spec.rb +174 -174
  1481. data/spec/unit/http/ssl_policies_spec.rb +169 -169
  1482. data/spec/unit/http/validate_content_length_spec.rb +207 -207
  1483. data/spec/unit/http_spec.rb +229 -229
  1484. data/spec/unit/json_compat_spec.rb +73 -73
  1485. data/spec/unit/key_spec.rb +631 -631
  1486. data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +152 -152
  1487. data/spec/unit/knife/bootstrap/client_builder_spec.rb +207 -207
  1488. data/spec/unit/knife/bootstrap/train_connector_spec.rb +216 -0
  1489. data/spec/unit/knife/bootstrap_spec.rb +2159 -976
  1490. data/spec/unit/knife/client_bulk_delete_spec.rb +166 -166
  1491. data/spec/unit/knife/client_create_spec.rb +169 -186
  1492. data/spec/unit/knife/client_delete_spec.rb +99 -99
  1493. data/spec/unit/knife/client_edit_spec.rb +53 -53
  1494. data/spec/unit/knife/client_list_spec.rb +34 -34
  1495. data/spec/unit/knife/client_reregister_spec.rb +62 -62
  1496. data/spec/unit/knife/client_show_spec.rb +52 -52
  1497. data/spec/unit/knife/configure_client_spec.rb +81 -81
  1498. data/spec/unit/knife/configure_spec.rb +190 -190
  1499. data/spec/unit/knife/cookbook_bulk_delete_spec.rb +87 -87
  1500. data/spec/unit/knife/cookbook_delete_spec.rb +239 -239
  1501. data/spec/unit/knife/cookbook_download_spec.rb +255 -255
  1502. data/spec/unit/knife/cookbook_list_spec.rb +88 -88
  1503. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +65 -65
  1504. data/spec/unit/knife/cookbook_metadata_spec.rb +182 -182
  1505. data/spec/unit/knife/cookbook_show_spec.rb +253 -254
  1506. data/spec/unit/knife/cookbook_upload_spec.rb +304 -333
  1507. data/spec/unit/knife/core/bootstrap_context_spec.rb +307 -324
  1508. data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +187 -187
  1509. data/spec/unit/knife/core/gem_glob_loader_spec.rb +209 -209
  1510. data/spec/unit/knife/core/hashed_command_loader_spec.rb +110 -112
  1511. data/spec/unit/knife/core/node_editor_spec.rb +211 -211
  1512. data/spec/unit/knife/core/object_loader_spec.rb +81 -81
  1513. data/spec/unit/knife/core/subcommand_loader_spec.rb +64 -64
  1514. data/spec/unit/knife/core/ui_spec.rb +639 -639
  1515. data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +278 -0
  1516. data/spec/unit/knife/data_bag_create_spec.rb +175 -175
  1517. data/spec/unit/knife/data_bag_edit_spec.rb +126 -126
  1518. data/spec/unit/knife/data_bag_from_file_spec.rb +173 -174
  1519. data/spec/unit/knife/data_bag_secret_options_spec.rb +165 -165
  1520. data/spec/unit/knife/data_bag_show_spec.rb +138 -139
  1521. data/spec/unit/knife/environment_compare_spec.rb +112 -112
  1522. data/spec/unit/knife/environment_create_spec.rb +91 -91
  1523. data/spec/unit/knife/environment_delete_spec.rb +71 -71
  1524. data/spec/unit/knife/environment_edit_spec.rb +79 -79
  1525. data/spec/unit/knife/environment_from_file_spec.rb +90 -90
  1526. data/spec/unit/knife/environment_list_spec.rb +54 -54
  1527. data/spec/unit/knife/environment_show_spec.rb +52 -52
  1528. data/spec/unit/knife/key_create_spec.rb +223 -223
  1529. data/spec/unit/knife/key_delete_spec.rb +133 -133
  1530. data/spec/unit/knife/key_edit_spec.rb +264 -264
  1531. data/spec/unit/knife/key_helper.rb +74 -74
  1532. data/spec/unit/knife/key_list_spec.rb +216 -216
  1533. data/spec/unit/knife/key_show_spec.rb +126 -126
  1534. data/spec/unit/knife/node_bulk_delete_spec.rb +94 -94
  1535. data/spec/unit/knife/node_delete_spec.rb +77 -77
  1536. data/spec/unit/knife/node_edit_spec.rb +116 -116
  1537. data/spec/unit/knife/node_environment_set_spec.rb +56 -56
  1538. data/spec/unit/knife/node_from_file_spec.rb +59 -59
  1539. data/spec/unit/knife/node_list_spec.rb +62 -62
  1540. data/spec/unit/knife/node_policy_set_spec.rb +122 -122
  1541. data/spec/unit/knife/node_run_list_add_spec.rb +145 -145
  1542. data/spec/unit/knife/node_run_list_remove_spec.rb +106 -106
  1543. data/spec/unit/knife/node_run_list_set_spec.rb +115 -115
  1544. data/spec/unit/knife/node_show_spec.rb +65 -65
  1545. data/spec/unit/knife/raw_spec.rb +43 -43
  1546. data/spec/unit/knife/role_bulk_delete_spec.rb +80 -80
  1547. data/spec/unit/knife/role_create_spec.rb +80 -80
  1548. data/spec/unit/knife/role_delete_spec.rb +67 -67
  1549. data/spec/unit/knife/role_edit_spec.rb +77 -77
  1550. data/spec/unit/knife/role_env_run_list_add_spec.rb +217 -217
  1551. data/spec/unit/knife/role_env_run_list_clear_spec.rb +94 -94
  1552. data/spec/unit/knife/role_env_run_list_remove_spec.rb +102 -102
  1553. data/spec/unit/knife/role_env_run_list_replace_spec.rb +105 -105
  1554. data/spec/unit/knife/role_env_run_list_set_spec.rb +99 -99
  1555. data/spec/unit/knife/role_from_file_spec.rb +69 -69
  1556. data/spec/unit/knife/role_list_spec.rb +54 -54
  1557. data/spec/unit/knife/role_run_list_add_spec.rb +179 -179
  1558. data/spec/unit/knife/role_run_list_clear_spec.rb +84 -84
  1559. data/spec/unit/knife/role_run_list_remove_spec.rb +92 -92
  1560. data/spec/unit/knife/role_run_list_replace_spec.rb +98 -98
  1561. data/spec/unit/knife/role_run_list_set_spec.rb +89 -89
  1562. data/spec/unit/knife/role_show_spec.rb +59 -59
  1563. data/spec/unit/knife/ssh_spec.rb +496 -506
  1564. data/spec/unit/knife/ssl_check_spec.rb +256 -256
  1565. data/spec/unit/knife/ssl_fetch_spec.rb +222 -222
  1566. data/spec/unit/knife/status_spec.rb +111 -112
  1567. data/spec/unit/knife/supermarket_download_spec.rb +152 -152
  1568. data/spec/unit/knife/supermarket_install_spec.rb +201 -202
  1569. data/spec/unit/knife/supermarket_share_spec.rb +209 -209
  1570. data/spec/unit/knife/supermarket_unshare_spec.rb +78 -78
  1571. data/spec/unit/knife/tag_create_spec.rb +23 -23
  1572. data/spec/unit/knife/tag_delete_spec.rb +25 -25
  1573. data/spec/unit/knife/tag_list_spec.rb +23 -23
  1574. data/spec/unit/knife/user_create_spec.rb +184 -214
  1575. data/spec/unit/knife/user_delete_spec.rb +46 -65
  1576. data/spec/unit/knife/user_edit_spec.rb +48 -66
  1577. data/spec/unit/knife/user_list_spec.rb +36 -36
  1578. data/spec/unit/knife/user_reregister_spec.rb +56 -74
  1579. data/spec/unit/knife/user_show_spec.rb +46 -65
  1580. data/spec/unit/knife_spec.rb +613 -589
  1581. data/spec/unit/log/syslog_spec.rb +51 -51
  1582. data/spec/unit/log/winevt_spec.rb +54 -54
  1583. data/spec/unit/log_spec.rb +24 -24
  1584. data/spec/unit/lwrp_spec.rb +690 -690
  1585. data/spec/unit/mash_spec.rb +51 -51
  1586. data/spec/unit/mixin/api_version_request_handling_spec.rb +126 -126
  1587. data/spec/unit/mixin/checksum_spec.rb +54 -54
  1588. data/spec/unit/mixin/convert_to_class_name_spec.rb +54 -54
  1589. data/spec/unit/mixin/deep_merge_spec.rb +342 -342
  1590. data/spec/unit/mixin/deprecation_spec.rb +57 -57
  1591. data/spec/unit/mixin/enforce_ownership_and_permissions_spec.rb +96 -96
  1592. data/spec/unit/mixin/homebrew_user_spec.rb +96 -96
  1593. data/spec/unit/mixin/lazy_module_include.rb +71 -71
  1594. data/spec/unit/mixin/openssl_helper_spec.rb +857 -857
  1595. data/spec/unit/mixin/params_validate_spec.rb +421 -421
  1596. data/spec/unit/mixin/path_sanity_spec.rb +92 -92
  1597. data/spec/unit/mixin/powershell_exec_spec.rb +43 -43
  1598. data/spec/unit/mixin/powershell_out_spec.rb +94 -94
  1599. data/spec/unit/mixin/powershell_type_coercions_spec.rb +84 -84
  1600. data/spec/unit/mixin/properties_spec.rb +107 -107
  1601. data/spec/unit/mixin/proxified_socket_spec.rb +97 -97
  1602. data/spec/unit/mixin/securable_spec.rb +314 -314
  1603. data/spec/unit/mixin/shell_out_spec.rb +318 -450
  1604. data/spec/unit/mixin/subclass_directive_spec.rb +45 -45
  1605. data/spec/unit/mixin/template_spec.rb +276 -317
  1606. data/spec/unit/mixin/unformatter_spec.rb +61 -60
  1607. data/spec/unit/mixin/uris_spec.rb +57 -57
  1608. data/spec/unit/mixin/user_context_spec.rb +108 -107
  1609. data/spec/unit/mixin/versioned_api_spec.rb +128 -128
  1610. data/spec/unit/mixin/which.rb +160 -162
  1611. data/spec/unit/mixin/windows_architecture_helper_spec.rb +85 -85
  1612. data/spec/unit/mixin/xml_escape_spec.rb +54 -54
  1613. data/spec/unit/monkey_patches/uri_spec.rb +34 -34
  1614. data/spec/unit/monologger_spec.rb +45 -45
  1615. data/spec/unit/node/attribute_spec.rb +1300 -1276
  1616. data/spec/unit/node/immutable_collections_spec.rb +326 -327
  1617. data/spec/unit/node/vivid_mash_spec.rb +458 -353
  1618. data/spec/unit/node_map_spec.rb +276 -242
  1619. data/spec/unit/node_spec.rb +1843 -1851
  1620. data/spec/unit/org_spec.rb +196 -196
  1621. data/spec/unit/platform/query_helpers_spec.rb +207 -207
  1622. data/spec/unit/policy_builder/dynamic_spec.rb +261 -273
  1623. data/spec/unit/policy_builder/expand_node_object_spec.rb +311 -311
  1624. data/spec/unit/policy_builder/policyfile_spec.rb +872 -872
  1625. data/spec/unit/policy_builder_spec.rb +26 -26
  1626. data/spec/unit/property/state_spec.rb +508 -509
  1627. data/spec/unit/property/validation_spec.rb +758 -759
  1628. data/spec/unit/property_spec.rb +1324 -1232
  1629. data/spec/unit/provider/apt_preference_spec.rb +87 -87
  1630. data/spec/unit/provider/apt_repository_spec.rb +254 -254
  1631. data/spec/unit/provider/apt_update_spec.rb +116 -116
  1632. data/spec/unit/provider/cookbook_file/content_spec.rb +39 -39
  1633. data/spec/unit/provider/cookbook_file_spec.rb +59 -59
  1634. data/spec/unit/provider/cron/unix_spec.rb +144 -144
  1635. data/spec/unit/provider/cron_spec.rb +1084 -1084
  1636. data/spec/unit/provider/directory_spec.rb +300 -300
  1637. data/spec/unit/provider/dsc_resource_spec.rb +343 -346
  1638. data/spec/unit/provider/dsc_script_spec.rb +173 -173
  1639. data/spec/unit/provider/execute_spec.rb +251 -251
  1640. data/spec/unit/provider/file/content_spec.rb +114 -114
  1641. data/spec/unit/provider/file_spec.rb +57 -57
  1642. data/spec/unit/provider/git_spec.rb +782 -782
  1643. data/spec/unit/provider/group/dscl_spec.rb +339 -339
  1644. data/spec/unit/provider/group/gpasswd_spec.rb +119 -119
  1645. data/spec/unit/provider/group/groupadd_spec.rb +194 -194
  1646. data/spec/unit/provider/group/groupmod_spec.rb +136 -136
  1647. data/spec/unit/provider/group/pw_spec.rb +141 -141
  1648. data/spec/unit/provider/group/solaris_spec.rb +106 -0
  1649. data/spec/unit/provider/group/suse_spec.rb +90 -90
  1650. data/spec/unit/provider/group/usermod_spec.rb +112 -115
  1651. data/spec/unit/provider/group/windows_spec.rb +124 -124
  1652. data/spec/unit/provider/group_spec.rb +286 -285
  1653. data/spec/unit/provider/http_request_spec.rb +159 -159
  1654. data/spec/unit/provider/ifconfig/aix_spec.rb +180 -180
  1655. data/spec/unit/provider/ifconfig/debian_spec.rb +332 -332
  1656. data/spec/unit/provider/ifconfig/redhat_spec.rb +83 -83
  1657. data/spec/unit/provider/ifconfig_spec.rb +206 -246
  1658. data/spec/unit/provider/launchd_spec.rb +268 -276
  1659. data/spec/unit/provider/link_spec.rb +409 -420
  1660. data/spec/unit/provider/log_spec.rb +94 -94
  1661. data/spec/unit/provider/mdadm_spec.rb +140 -140
  1662. data/spec/unit/provider/mount/aix_spec.rb +277 -277
  1663. data/spec/unit/provider/mount/mount_spec.rb +527 -527
  1664. data/spec/unit/provider/mount/solaris_spec.rb +822 -822
  1665. data/spec/unit/provider/mount/windows_spec.rb +149 -149
  1666. data/spec/unit/provider/mount_spec.rb +191 -191
  1667. data/spec/unit/provider/ohai_spec.rb +84 -84
  1668. data/spec/unit/provider/osx_profile_spec.rb +257 -255
  1669. data/spec/unit/provider/package/apt_spec.rb +632 -610
  1670. data/spec/unit/provider/package/bff_spec.rb +187 -187
  1671. data/spec/unit/provider/package/cab_spec.rb +272 -272
  1672. data/spec/unit/provider/package/chocolatey_spec.rb +507 -507
  1673. data/spec/unit/provider/package/deb_spec.rb +135 -0
  1674. data/spec/unit/provider/package/dnf/python_helper_spec.rb +29 -29
  1675. data/spec/unit/provider/package/dpkg_spec.rb +314 -287
  1676. data/spec/unit/provider/package/freebsd/pkgng_spec.rb +147 -148
  1677. data/spec/unit/provider/package/freebsd/port_spec.rb +151 -163
  1678. data/spec/unit/provider/package/homebrew_spec.rb +293 -293
  1679. data/spec/unit/provider/package/ips_spec.rb +233 -233
  1680. data/spec/unit/provider/package/macports_spec.rb +203 -203
  1681. data/spec/unit/provider/package/msu_spec.rb +283 -283
  1682. data/spec/unit/provider/package/openbsd_spec.rb +132 -136
  1683. data/spec/unit/provider/package/pacman_spec.rb +194 -194
  1684. data/spec/unit/provider/package/paludis_spec.rb +134 -134
  1685. data/spec/unit/provider/package/portage_spec.rb +179 -179
  1686. data/spec/unit/provider/package/powershell_spec.rb +501 -501
  1687. data/spec/unit/provider/package/rpm_spec.rb +440 -429
  1688. data/spec/unit/provider/package/rubygems_spec.rb +981 -981
  1689. data/spec/unit/provider/package/smartos_spec.rb +110 -110
  1690. data/spec/unit/provider/package/snap_spec.rb +208 -0
  1691. data/spec/unit/provider/package/solaris_spec.rb +167 -167
  1692. data/spec/unit/provider/package/windows/exe_spec.rb +201 -201
  1693. data/spec/unit/provider/package/windows/msi_spec.rb +168 -168
  1694. data/spec/unit/provider/package/windows/registry_uninstall_entry_spec.rb +78 -78
  1695. data/spec/unit/provider/package/windows_spec.rb +463 -464
  1696. data/spec/unit/provider/package/yum/python_helper_spec.rb +29 -29
  1697. data/spec/unit/provider/package/yum/yum_cache_spec.rb +109 -109
  1698. data/spec/unit/provider/package/zypper_spec.rb +478 -487
  1699. data/spec/unit/provider/package_spec.rb +791 -1013
  1700. data/spec/unit/provider/powershell_script_spec.rb +125 -116
  1701. data/spec/unit/provider/registry_key_spec.rb +487 -487
  1702. data/spec/unit/provider/remote_directory_spec.rb +236 -236
  1703. data/spec/unit/provider/remote_file/cache_control_data_spec.rb +245 -245
  1704. data/spec/unit/provider/remote_file/content_spec.rb +253 -253
  1705. data/spec/unit/provider/remote_file/fetcher_spec.rb +95 -95
  1706. data/spec/unit/provider/remote_file/ftp_spec.rb +217 -217
  1707. data/spec/unit/provider/remote_file/http_spec.rb +324 -324
  1708. data/spec/unit/provider/remote_file/local_file_spec.rb +105 -105
  1709. data/spec/unit/provider/remote_file/network_file_spec.rb +50 -50
  1710. data/spec/unit/provider/remote_file/sftp_spec.rb +150 -150
  1711. data/spec/unit/provider/remote_file_spec.rb +62 -62
  1712. data/spec/unit/provider/route_spec.rb +270 -270
  1713. data/spec/unit/provider/ruby_block_spec.rb +45 -45
  1714. data/spec/unit/provider/script_spec.rb +157 -157
  1715. data/spec/unit/provider/service/aix_service_spec.rb +195 -195
  1716. data/spec/unit/provider/service/aixinit_service_spec.rb +272 -272
  1717. data/spec/unit/provider/service/arch_service_spec.rb +324 -324
  1718. data/spec/unit/provider/service/debian_service_spec.rb +249 -250
  1719. data/spec/unit/provider/service/freebsd_service_spec.rb +617 -621
  1720. data/spec/unit/provider/service/gentoo_service_spec.rb +144 -144
  1721. data/spec/unit/provider/service/init_service_spec.rb +235 -235
  1722. data/spec/unit/provider/service/insserv_service_spec.rb +75 -75
  1723. data/spec/unit/provider/service/invokercd_service_spec.rb +211 -211
  1724. data/spec/unit/provider/service/macosx_spec.rb +340 -340
  1725. data/spec/unit/provider/service/openbsd_service_spec.rb +549 -553
  1726. data/spec/unit/provider/service/redhat_spec.rb +250 -250
  1727. data/spec/unit/provider/service/simple_service_spec.rb +169 -169
  1728. data/spec/unit/provider/service/solaris_smf_service_spec.rb +292 -292
  1729. data/spec/unit/provider/service/systemd_service_spec.rb +364 -388
  1730. data/spec/unit/provider/service/upstart_service_spec.rb +351 -351
  1731. data/spec/unit/provider/service/windows_spec.rb +952 -928
  1732. data/spec/unit/provider/service_spec.rb +168 -168
  1733. data/spec/unit/provider/subversion_spec.rb +361 -365
  1734. data/spec/unit/provider/systemd_unit_spec.rb +967 -1016
  1735. data/spec/unit/provider/template/content_spec.rb +169 -169
  1736. data/spec/unit/provider/template_spec.rb +87 -87
  1737. data/spec/unit/provider/user/aix_spec.rb +96 -96
  1738. data/spec/unit/provider/user/dscl_spec.rb +698 -920
  1739. data/spec/unit/provider/user/linux_spec.rb +73 -74
  1740. data/spec/unit/provider/user/pw_spec.rb +235 -235
  1741. data/spec/unit/provider/user/solaris_spec.rb +177 -177
  1742. data/spec/unit/provider/user/windows_spec.rb +197 -197
  1743. data/spec/unit/provider/user_spec.rb +478 -494
  1744. data/spec/unit/provider/whyrun_safe_ruby_block_spec.rb +46 -46
  1745. data/spec/unit/provider/windows_env_spec.rb +400 -400
  1746. data/spec/unit/provider/windows_path_spec.rb +65 -65
  1747. data/spec/unit/provider/windows_task_spec.rb +430 -435
  1748. data/spec/unit/provider/yum_repository_spec.rb +35 -35
  1749. data/spec/unit/provider/zypper_repository_spec.rb +126 -126
  1750. data/spec/unit/provider_resolver_spec.rb +900 -923
  1751. data/spec/unit/provider_spec.rb +201 -199
  1752. data/spec/unit/pure_application_spec.rb +32 -32
  1753. data/spec/unit/recipe_spec.rb +584 -589
  1754. data/spec/unit/resource/apt_package_spec.rb +66 -56
  1755. data/spec/unit/resource/apt_preference_spec.rb +57 -57
  1756. data/spec/unit/resource/apt_repository_spec.rb +92 -92
  1757. data/spec/unit/resource/apt_update_spec.rb +62 -62
  1758. data/spec/unit/resource/archive_file_spec.rb +47 -0
  1759. data/spec/unit/resource/bash_spec.rb +45 -45
  1760. data/spec/unit/resource/batch_spec.rb +46 -46
  1761. data/spec/unit/resource/bff_package_spec.rb +51 -51
  1762. data/spec/unit/resource/breakpoint_spec.rb +64 -64
  1763. data/spec/unit/resource/build_essential_spec.rb +43 -43
  1764. data/spec/unit/resource/cab_package_spec.rb +64 -64
  1765. data/spec/unit/resource/chef_gem_spec.rb +122 -125
  1766. data/spec/unit/resource/chef_handler_spec.rb +40 -40
  1767. data/spec/unit/resource/chocolatey_config_spec.rb +93 -98
  1768. data/spec/unit/resource/chocolatey_package_spec.rb +91 -91
  1769. data/spec/unit/resource/chocolatey_source_spec.rb +97 -102
  1770. data/spec/unit/resource/conditional_action_not_nothing_spec.rb +45 -45
  1771. data/spec/unit/resource/conditional_spec.rb +254 -254
  1772. data/spec/unit/resource/cookbook_file_spec.rb +93 -93
  1773. data/spec/unit/resource/cron_access_spec.rb +36 -36
  1774. data/spec/unit/resource/cron_d_spec.rb +90 -90
  1775. data/spec/unit/resource/cron_spec.rb +173 -173
  1776. data/spec/unit/resource/csh_spec.rb +45 -45
  1777. data/spec/unit/resource/directory_spec.rb +69 -69
  1778. data/spec/unit/resource/dmg_package_spec.rb +39 -39
  1779. data/spec/unit/resource/dnf_package_spec.rb +108 -108
  1780. data/spec/unit/resource/dpkg_package_spec.rb +60 -50
  1781. data/spec/unit/resource/dsc_resource_spec.rb +102 -102
  1782. data/spec/unit/resource/dsc_script_spec.rb +134 -134
  1783. data/spec/unit/resource/execute_spec.rb +277 -277
  1784. data/spec/unit/resource/file/verification/systemd_unit_spec.rb +103 -103
  1785. data/spec/unit/resource/file/verification_spec.rb +147 -146
  1786. data/spec/unit/resource/file_spec.rb +127 -127
  1787. data/spec/unit/resource/freebsd_package_spec.rb +77 -103
  1788. data/spec/unit/resource/gem_package_spec.rb +67 -67
  1789. data/spec/unit/resource/git_spec.rb +62 -62
  1790. data/spec/unit/resource/group_spec.rb +165 -165
  1791. data/spec/unit/resource/homebrew_cask_spec.rb +40 -40
  1792. data/spec/unit/resource/homebrew_package_spec.rb +68 -68
  1793. data/spec/unit/resource/homebrew_tap_spec.rb +44 -44
  1794. data/spec/unit/resource/hostname_spec.rb +47 -47
  1795. data/spec/unit/resource/http_request_spec.rb +65 -65
  1796. data/spec/unit/resource/ifconfig_spec.rb +109 -109
  1797. data/spec/unit/resource/ips_package_spec.rb +54 -54
  1798. data/spec/unit/resource/kernel_module_spec.rb +43 -48
  1799. data/spec/unit/resource/ksh_spec.rb +45 -45
  1800. data/spec/unit/resource/launchd_spec.rb +40 -40
  1801. data/spec/unit/resource/link_spec.rb +124 -124
  1802. data/spec/unit/resource/locale_spec.rb +223 -60
  1803. data/spec/unit/resource/log_spec.rb +64 -64
  1804. data/spec/unit/resource/macos_user_defaults_spec.rb +35 -35
  1805. data/spec/unit/{knife/osc_user_list_spec.rb → resource/macosx_service.rb} +37 -37
  1806. data/spec/unit/resource/macports_package_spec.rb +51 -51
  1807. data/spec/unit/resource/mdadm_spec.rb +104 -104
  1808. data/spec/unit/resource/mount_spec.rb +178 -178
  1809. data/spec/unit/resource/msu_package_spec.rb +63 -63
  1810. data/spec/unit/resource/ohai_hint_spec.rb +44 -44
  1811. data/spec/unit/resource/ohai_spec.rb +58 -62
  1812. data/spec/unit/resource/openbsd_package_spec.rb +58 -58
  1813. data/spec/unit/resource/{openssl_dhparam.rb → openssl_dhparam_spec.rb} +61 -61
  1814. data/spec/unit/resource/openssl_ec_private_key_spec.rb +64 -64
  1815. data/spec/unit/resource/openssl_ec_public_key_spec.rb +43 -43
  1816. data/spec/unit/resource/openssl_rsa_private_key_spec.rb +64 -64
  1817. data/spec/unit/resource/openssl_rsa_public_key_spec.rb +43 -43
  1818. data/spec/unit/resource/openssl_x509_certificate_spec.rb +72 -72
  1819. data/spec/unit/resource/openssl_x509_crl_spec.rb +61 -61
  1820. data/spec/unit/resource/openssl_x509_request.rb +68 -68
  1821. data/spec/unit/resource/osx_profile_spec.rb +60 -61
  1822. data/spec/unit/resource/package_spec.rb +98 -108
  1823. data/spec/unit/resource/pacman_package_spec.rb +46 -46
  1824. data/spec/unit/resource/paludis_package_spec.rb +36 -36
  1825. data/spec/unit/resource/perl_spec.rb +44 -44
  1826. data/spec/unit/resource/portage_package_spec.rb +46 -46
  1827. data/spec/unit/resource/powershell_package_source_spec.rb +219 -219
  1828. data/spec/unit/resource/powershell_package_spec.rb +98 -98
  1829. data/spec/unit/resource/powershell_script_spec.rb +158 -141
  1830. data/spec/unit/resource/python_spec.rb +40 -40
  1831. data/spec/unit/resource/reboot_spec.rb +47 -47
  1832. data/spec/unit/resource/registry_key_spec.rb +215 -215
  1833. data/spec/unit/resource/remote_directory_spec.rb +118 -105
  1834. data/spec/unit/resource/remote_file_spec.rb +220 -220
  1835. data/spec/unit/resource/resource_notification_spec.rb +169 -169
  1836. data/spec/unit/resource/rhsm_errata_level_spec.rb +50 -50
  1837. data/spec/unit/resource/rhsm_errata_spec.rb +39 -39
  1838. data/spec/unit/resource/rhsm_register_spec.rb +204 -204
  1839. data/spec/unit/resource/rhsm_repo_spec.rb +64 -64
  1840. data/spec/unit/resource/rhsm_subscription_spec.rb +98 -98
  1841. data/spec/unit/resource/route_spec.rb +100 -95
  1842. data/spec/unit/resource/rpm_package_spec.rb +62 -62
  1843. data/spec/unit/resource/ruby_block_spec.rb +58 -58
  1844. data/spec/unit/resource/ruby_spec.rb +39 -39
  1845. data/spec/unit/resource/scm_spec.rb +173 -173
  1846. data/spec/unit/resource/script_spec.rb +52 -52
  1847. data/spec/unit/resource/service_spec.rb +199 -206
  1848. data/spec/unit/resource/smartos_package_spec.rb +52 -52
  1849. data/spec/unit/resource/snap_package_spec.rb +60 -0
  1850. data/spec/unit/resource/solaris_package_spec.rb +54 -54
  1851. data/spec/unit/resource/ssh_known_hosts_entry_spec.rb +50 -55
  1852. data/spec/unit/resource/subversion_spec.rb +91 -91
  1853. data/spec/unit/resource/sudo_spec.rb +99 -99
  1854. data/spec/unit/resource/swap_file_spec.rb +39 -39
  1855. data/spec/unit/resource/sysctl_spec.rb +54 -54
  1856. data/spec/unit/resource/systemd_unit_spec.rb +130 -130
  1857. data/spec/unit/resource/template_spec.rb +222 -222
  1858. data/spec/unit/resource/{timezone.rb → timezone_spec.rb} +39 -39
  1859. data/spec/unit/resource/user_spec.rb +121 -122
  1860. data/spec/unit/resource/windows_ad_join_spec.rb +51 -51
  1861. data/spec/unit/resource/windows_auto_run_spec.rb +50 -50
  1862. data/spec/unit/resource/{windows_certificate.rb → windows_certificate_spec.rb} +83 -83
  1863. data/spec/unit/resource/windows_dfs_folder_spec.rb +39 -0
  1864. data/spec/unit/resource/windows_dfs_namespace_spec.rb +39 -0
  1865. data/spec/unit/{audit/rspec_formatter_spec.rb → resource/windows_dfs_server_spec.rb} +34 -29
  1866. data/spec/unit/resource/windows_dns_record_spec.rb +55 -0
  1867. data/spec/unit/resource/windows_dns_zone_spec.rb +51 -0
  1868. data/spec/unit/resource/windows_env_spec.rb +75 -75
  1869. data/spec/unit/resource/{windows_feature_dism.rb → windows_feature_dism_spec.rb} +72 -72
  1870. data/spec/unit/resource/{windows_feature_powershell.rb → windows_feature_powershell_spec.rb} +72 -72
  1871. data/spec/unit/resource/{windows_feature.rb → windows_feature_spec.rb} +64 -64
  1872. data/spec/unit/resource/windows_firewall_rule_spec.rb +401 -401
  1873. data/spec/unit/resource/windows_font_spec.rb +43 -43
  1874. data/spec/unit/resource/windows_package_spec.rb +105 -105
  1875. data/spec/unit/resource/windows_pagefile_spec.rb +49 -49
  1876. data/spec/unit/resource/windows_path_spec.rb +40 -40
  1877. data/spec/unit/resource/windows_printer_port_spec.rb +62 -62
  1878. data/spec/unit/resource/windows_printer_spec.rb +52 -52
  1879. data/spec/unit/resource/windows_service_spec.rb +108 -93
  1880. data/spec/unit/resource/{windows_share.rb → windows_share_spec.rb} +39 -39
  1881. data/spec/unit/resource/windows_shortcut_spec.rb +38 -38
  1882. data/spec/unit/resource/windows_task_spec.rb +403 -403
  1883. data/spec/unit/resource/windows_uac_spec.rb +50 -0
  1884. data/spec/unit/resource/windows_workgroup_spec.rb +74 -74
  1885. data/spec/unit/resource/yum_package_spec.rb +150 -150
  1886. data/spec/unit/resource/yum_repository_spec.rb +152 -152
  1887. data/spec/unit/resource/zypper_package_spec.rb +51 -51
  1888. data/spec/unit/resource/zypper_repository_spec.rb +115 -115
  1889. data/spec/unit/resource_builder_spec.rb +1 -1
  1890. data/spec/unit/resource_collection/resource_list_spec.rb +137 -137
  1891. data/spec/unit/resource_collection/resource_set_spec.rb +244 -244
  1892. data/spec/unit/resource_collection/stepable_iterator_spec.rb +144 -144
  1893. data/spec/unit/resource_collection_spec.rb +400 -408
  1894. data/spec/unit/resource_definition_spec.rb +117 -117
  1895. data/spec/unit/resource_inspector_spec.rb +60 -60
  1896. data/spec/unit/resource_reporter_spec.rb +808 -782
  1897. data/spec/unit/resource_resolver_spec.rb +52 -52
  1898. data/spec/unit/resource_spec.rb +1218 -1195
  1899. data/spec/unit/role_spec.rb +358 -358
  1900. data/spec/unit/run_context/child_run_context_spec.rb +126 -133
  1901. data/spec/unit/run_context/cookbook_compiler_spec.rb +236 -224
  1902. data/spec/unit/run_context_spec.rb +241 -241
  1903. data/spec/unit/run_list/run_list_expansion_spec.rb +144 -147
  1904. data/spec/unit/run_list/run_list_item_spec.rb +117 -117
  1905. data/spec/unit/run_list/versioned_recipe_list_spec.rb +197 -197
  1906. data/spec/unit/run_list_spec.rb +312 -312
  1907. data/spec/unit/run_lock_spec.rb +140 -140
  1908. data/spec/unit/run_status_spec.rb +144 -144
  1909. data/spec/unit/runner_spec.rb +398 -398
  1910. data/spec/unit/scan_access_control_spec.rb +183 -183
  1911. data/spec/unit/search/query_spec.rb +283 -284
  1912. data/spec/unit/server_api_spec.rb +124 -124
  1913. data/spec/unit/server_api_versions_spec.rb +66 -66
  1914. data/spec/unit/shell/model_wrapper_spec.rb +96 -96
  1915. data/spec/unit/shell/shell_ext_spec.rb +153 -153
  1916. data/spec/unit/shell/shell_session_spec.rb +250 -247
  1917. data/spec/unit/shell_spec.rb +162 -161
  1918. data/spec/unit/train_transport_spec.rb +79 -0
  1919. data/spec/unit/user_spec.rb +275 -275
  1920. data/spec/unit/user_v1_spec.rb +583 -583
  1921. data/spec/unit/util/backup_spec.rb +141 -141
  1922. data/spec/unit/util/diff_spec.rb +576 -576
  1923. data/spec/unit/util/dsc/configuration_generator_spec.rb +193 -193
  1924. data/spec/unit/util/dsc/lcm_output_parser_spec.rb +248 -248
  1925. data/spec/unit/util/dsc/local_configuration_manager_spec.rb +200 -200
  1926. data/spec/unit/util/dsc/resource_store.rb +78 -78
  1927. data/spec/unit/util/editor_spec.rb +152 -152
  1928. data/spec/unit/util/file_edit_spec.rb +224 -224
  1929. data/spec/unit/util/powershell/cmdlet_spec.rb +106 -106
  1930. data/spec/unit/util/powershell/ps_credential_spec.rb +44 -45
  1931. data/spec/unit/util/selinux_spec.rb +157 -157
  1932. data/spec/unit/util/threaded_job_queue_spec.rb +51 -51
  1933. data/spec/unit/util/windows/logon_session_spec.rb +285 -285
  1934. data/spec/unit/version/platform_spec.rb +60 -60
  1935. data/spec/unit/version_class_spec.rb +171 -171
  1936. data/spec/unit/version_constraint/platform_spec.rb +45 -45
  1937. data/spec/unit/version_constraint_spec.rb +179 -179
  1938. data/spec/unit/version_string_spec.rb +79 -79
  1939. data/spec/unit/win32/error_spec.rb +77 -77
  1940. data/spec/unit/win32/link_spec.rb +73 -73
  1941. data/spec/unit/win32/registry_spec.rb +394 -394
  1942. data/spec/unit/win32/security_spec.rb +134 -135
  1943. data/spec/unit/windows_service_spec.rb +118 -118
  1944. data/tasks/announce.rb +51 -51
  1945. data/tasks/bin/run_external_test +33 -29
  1946. data/tasks/dependencies.rb +58 -58
  1947. data/tasks/rspec.rb +90 -90
  1948. data/tasks/templates/release.md.erb +34 -34
  1949. metadata +171 -168
  1950. data/bin/chef-client +0 -25
  1951. data/bin/chef-resource-inspector +0 -26
  1952. data/bin/chef-service-manager +0 -37
  1953. data/bin/chef-shell +0 -31
  1954. data/bin/chef-windows-service +0 -34
  1955. data/lib/chef/audit/audit_event_proxy.rb +0 -93
  1956. data/lib/chef/audit/audit_reporter.rb +0 -176
  1957. data/lib/chef/audit/control_group_data.rb +0 -145
  1958. data/lib/chef/audit/logger.rb +0 -36
  1959. data/lib/chef/audit/rspec_formatter.rb +0 -37
  1960. data/lib/chef/audit/runner.rb +0 -196
  1961. data/lib/chef/data_collector/messages.rb +0 -100
  1962. data/lib/chef/data_collector/messages/helpers.rb +0 -159
  1963. data/lib/chef/data_collector/resource_report.rb +0 -123
  1964. data/lib/chef/dsl/audit.rb +0 -51
  1965. data/lib/chef/dsl/chef_provisioning.rb +0 -57
  1966. data/lib/chef/knife/cookbook_create.rb +0 -29
  1967. data/lib/chef/knife/cookbook_test.rb +0 -95
  1968. data/lib/chef/knife/osc_user_create.rb +0 -97
  1969. data/lib/chef/knife/osc_user_delete.rb +0 -51
  1970. data/lib/chef/knife/osc_user_edit.rb +0 -58
  1971. data/lib/chef/knife/osc_user_list.rb +0 -47
  1972. data/lib/chef/knife/osc_user_reregister.rb +0 -64
  1973. data/lib/chef/knife/osc_user_show.rb +0 -53
  1974. data/lib/chef/provider/package/freebsd/pkg.rb +0 -114
  1975. data/lib/chef/provider/user/useradd.rb +0 -161
  1976. data/spec/data/mac_users/10.7-8.plist.xml +0 -559
  1977. data/spec/data/mac_users/10.7-8.shadow.xml +0 -11
  1978. data/spec/data/mac_users/10.7.plist.xml +0 -559
  1979. data/spec/data/mac_users/10.7.shadow.xml +0 -11
  1980. data/spec/data/mac_users/10.8.plist.xml +0 -559
  1981. data/spec/data/mac_users/10.8.shadow.xml +0 -21
  1982. data/spec/data/templates/failed.erb +0 -5
  1983. data/spec/functional/assets/inittest +0 -36
  1984. data/spec/functional/audit/rspec_formatter_spec.rb +0 -54
  1985. data/spec/functional/audit/runner_spec.rb +0 -121
  1986. data/spec/functional/resource/insserv_spec.rb +0 -206
  1987. data/spec/integration/recipes/unified_mode_spec.rb +0 -876
  1988. data/spec/support/shared/context/client.rb +0 -306
  1989. data/spec/support/shared/examples/client.rb +0 -104
  1990. data/spec/unit/audit/audit_event_proxy_spec.rb +0 -325
  1991. data/spec/unit/audit/audit_reporter_spec.rb +0 -444
  1992. data/spec/unit/audit/control_group_data_spec.rb +0 -487
  1993. data/spec/unit/audit/logger_spec.rb +0 -42
  1994. data/spec/unit/audit/runner_spec.rb +0 -144
  1995. data/spec/unit/data_collector/messages/helpers_spec.rb +0 -202
  1996. data/spec/unit/data_collector/messages_spec.rb +0 -329
  1997. data/spec/unit/data_collector/resource_report_spec.rb +0 -145
  1998. data/spec/unit/dsl/audit_spec.rb +0 -43
  1999. data/spec/unit/knife/cookbook_create_spec.rb +0 -42
  2000. data/spec/unit/knife/cookbook_test_spec.rb +0 -84
  2001. data/spec/unit/knife/osc_user_create_spec.rb +0 -93
  2002. data/spec/unit/knife/osc_user_delete_spec.rb +0 -44
  2003. data/spec/unit/knife/osc_user_edit_spec.rb +0 -52
  2004. data/spec/unit/knife/osc_user_reregister_spec.rb +0 -58
  2005. data/spec/unit/knife/osc_user_show_spec.rb +0 -46
  2006. data/spec/unit/provider/package/freebsd/pkg_spec.rb +0 -274
@@ -1,110 +1,95 @@
1
- #--
2
- # Author:: Adam Jacob (<adam@chef.io>)
3
- # Author:: Christopher Walters (<cw@chef.io>)
4
- # Copyright:: Copyright 2008-2018, Chef Software Inc.
5
- # License:: Apache License, Version 2.0
6
- #
7
- # Licensed under the Apache License, Version 2.0 (the "License");
8
- # you may not use this file except in compliance with the License.
9
- # You may obtain a copy of the License at
10
- #
11
- # http://www.apache.org/licenses/LICENSE-2.0
12
- #
13
- # Unless required by applicable law or agreed to in writing, software
14
- # distributed under the License is distributed on an "AS IS" BASIS,
15
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
- # See the License for the specific language governing permissions and
17
- # limitations under the License.
18
- #
19
-
20
- require "chef/dsl/recipe"
21
- require "chef/mixin/from_file"
22
- require "chef/mixin/deprecation"
23
-
24
- class Chef
25
- # == Chef::Recipe
26
- # A Recipe object is the context in which Chef recipes are evaluated.
27
- class Recipe
28
- attr_accessor :cookbook_name, :recipe_name, :recipe, :params, :run_context
29
-
30
- include Chef::DSL::Recipe
31
-
32
- include Chef::Mixin::FromFile
33
- include Chef::Mixin::Deprecation
34
-
35
- # Parses a potentially fully-qualified recipe name into its
36
- # cookbook name and recipe short name.
37
- #
38
- # For example:
39
- # "aws::elastic_ip" returns [:aws, "elastic_ip"]
40
- # "aws" returns [:aws, "default"]
41
- # "::elastic_ip" returns [ current_cookbook, "elastic_ip" ]
42
- #--
43
- # TODO: Duplicates functionality of RunListItem
44
- def self.parse_recipe_name(recipe_name, current_cookbook: nil)
45
- case recipe_name
46
- when /(.+?)::(.+)/
47
- [ $1.to_sym, $2 ]
48
- when /^::(.+)/
49
- raise "current_cookbook is nil, cannot resolve #{recipe_name}" if current_cookbook.nil?
50
- [ current_cookbook.to_sym, $1 ]
51
- else
52
- [ recipe_name.to_sym, "default" ]
53
- end
54
- end
55
-
56
- def initialize(cookbook_name, recipe_name, run_context)
57
- @cookbook_name = cookbook_name
58
- @recipe_name = recipe_name
59
- @run_context = run_context
60
- # TODO: 5/19/2010 cw/tim: determine whether this can be removed
61
- @params = Hash.new
62
- end
63
-
64
- # Used in DSL mixins
65
- def node
66
- run_context.node
67
- end
68
-
69
- # This was moved to Chef::Node#tag, redirecting here for compatibility
70
- def tag(*tags)
71
- run_context.node.tag(*tags)
72
- end
73
-
74
- # Returns true if the node is tagged with *all* of the supplied +tags+.
75
- #
76
- # === Parameters
77
- # tags<Array>:: A list of tags
78
- #
79
- # === Returns
80
- # true<TrueClass>:: If all the parameters are present
81
- # false<FalseClass>:: If any of the parameters are missing
82
- def tagged?(*tags)
83
- tags.each do |tag|
84
- return false unless run_context.node.tags.include?(tag)
85
- end
86
- true
87
- end
88
-
89
- # Removes the list of tags from the node.
90
- #
91
- # === Parameters
92
- # tags<Array>:: A list of tags
93
- #
94
- # === Returns
95
- # tags<Array>:: The current list of run_context.node.tags
96
- def untag(*tags)
97
- tags.each do |tag|
98
- run_context.node.tags.delete(tag)
99
- end
100
- end
101
-
102
- def to_s
103
- "cookbook: #{cookbook_name ? cookbook_name : "(none)"}, recipe: #{recipe_name ? recipe_name : "(none)"} "
104
- end
105
-
106
- def inspect
107
- to_s
108
- end
109
- end
110
- end
1
+ #--
2
+ # Author:: Adam Jacob (<adam@chef.io>)
3
+ # Author:: Christopher Walters (<cw@chef.io>)
4
+ # Copyright:: Copyright 2008-2018, Chef Software Inc.
5
+ # License:: Apache License, Version 2.0
6
+ #
7
+ # Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ # See the License for the specific language governing permissions and
17
+ # limitations under the License.
18
+ #
19
+
20
+ require_relative "dsl/recipe"
21
+ require_relative "mixin/from_file"
22
+ require_relative "mixin/deprecation"
23
+
24
+ class Chef
25
+ # == Chef::Recipe
26
+ # A Recipe object is the context in which Chef recipes are evaluated.
27
+ class Recipe
28
+ attr_accessor :cookbook_name, :recipe_name, :recipe, :params, :run_context
29
+
30
+ include Chef::DSL::Recipe
31
+
32
+ include Chef::Mixin::FromFile
33
+ include Chef::Mixin::Deprecation
34
+
35
+ # Parses a potentially fully-qualified recipe name into its
36
+ # cookbook name and recipe short name.
37
+ #
38
+ # For example:
39
+ # "aws::elastic_ip" returns [:aws, "elastic_ip"]
40
+ # "aws" returns [:aws, "default"]
41
+ # "::elastic_ip" returns [ current_cookbook, "elastic_ip" ]
42
+ #--
43
+ # TODO: Duplicates functionality of RunListItem
44
+ def self.parse_recipe_name(recipe_name, current_cookbook: nil)
45
+ case recipe_name
46
+ when /(.+?)::(.+)/
47
+ [ $1.to_sym, $2 ]
48
+ when /^::(.+)/
49
+ raise "current_cookbook is nil, cannot resolve #{recipe_name}" if current_cookbook.nil?
50
+ [ current_cookbook.to_sym, $1 ]
51
+ else
52
+ [ recipe_name.to_sym, "default" ]
53
+ end
54
+ end
55
+
56
+ def initialize(cookbook_name, recipe_name, run_context)
57
+ @cookbook_name = cookbook_name
58
+ @recipe_name = recipe_name
59
+ @run_context = run_context
60
+ # TODO: 5/19/2010 cw/tim: determine whether this can be removed
61
+ @params = Hash.new
62
+ end
63
+
64
+ # Used in DSL mixins
65
+ def node
66
+ run_context.node
67
+ end
68
+
69
+ # This was moved to Chef::Node#tag, redirecting here for compatibility
70
+ def tag(*tags)
71
+ run_context.node.tag(*tags)
72
+ end
73
+
74
+ # Removes the list of tags from the node.
75
+ #
76
+ # === Parameters
77
+ # tags<Array>:: A list of tags
78
+ #
79
+ # === Returns
80
+ # tags<Array>:: The current list of run_context.node.tags
81
+ def untag(*tags)
82
+ tags.each do |tag|
83
+ run_context.node.tags.delete(tag)
84
+ end
85
+ end
86
+
87
+ def to_s
88
+ "cookbook: #{cookbook_name ? cookbook_name : "(none)"}, recipe: #{recipe_name ? recipe_name : "(none)"} "
89
+ end
90
+
91
+ def inspect
92
+ to_s
93
+ end
94
+ end
95
+ end
@@ -1,37 +1,37 @@
1
- # Author:: Prajakta Purohit (<prajakta@chef.io>)
2
- # Copyright:: Copyright 2009-2016, Chef Software Inc.
3
- # License:: Apache License, Version 2.0
4
- #
5
- # Licensed under the Apache License, Version 2.0 (the "License");
6
- # you may not use this file except in compliance with the License.
7
- # You may obtain a copy of the License at
8
- #
9
- # http://www.apache.org/licenses/LICENSE-2.0
10
- #
11
- # Unless required by applicable law or agreed to in writing, software
12
- # distributed under the License is distributed on an "AS IS" BASIS,
13
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
- # See the License for the specific language governing permissions and
15
- # limitations under the License.
16
- #
17
-
18
- require "securerandom"
19
- require "singleton"
20
-
21
- class Chef
22
- class RequestID
23
- include Singleton
24
-
25
- def reset_request_id
26
- @request_id = nil
27
- end
28
-
29
- def request_id
30
- @request_id ||= generate_request_id
31
- end
32
-
33
- def generate_request_id
34
- SecureRandom.uuid
35
- end
36
- end
37
- end
1
+ # Author:: Prajakta Purohit (<prajakta@chef.io>)
2
+ # Copyright:: Copyright 2009-2016, Chef Software Inc.
3
+ # License:: Apache License, Version 2.0
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+ #
17
+
18
+ require "securerandom"
19
+ require "singleton"
20
+
21
+ class Chef
22
+ class RequestID
23
+ include Singleton
24
+
25
+ def reset_request_id
26
+ @request_id = nil
27
+ end
28
+
29
+ def request_id
30
+ @request_id ||= generate_request_id
31
+ end
32
+
33
+ def generate_request_id
34
+ SecureRandom.uuid
35
+ end
36
+ end
37
+ end
@@ -1,9 +1,9 @@
1
- class Chef
2
-
3
- # This module exists to hide conflicting constant names from the DSL.
4
- # Hopefully we'll have a better/prettier/more sustainable solution in the
5
- # future, but for now this will fix a regression introduced in Chef 0.10.10
6
- # (conflict with the Win32 namespace)
7
- module ReservedNames
8
- end
9
- end
1
+ class Chef
2
+
3
+ # This module exists to hide conflicting constant names from the DSL.
4
+ # Hopefully we'll have a better/prettier/more sustainable solution in the
5
+ # future, but for now this will fix a regression introduced in Chef 0.10.10
6
+ # (conflict with the Win32 namespace)
7
+ module ReservedNames
8
+ end
9
+ end
@@ -1,1593 +1,1592 @@
1
- #
2
- # Author:: Adam Jacob (<adam@chef.io>)
3
- # Author:: Christopher Walters (<cw@chef.io>)
4
- # Author:: John Keiser (<jkeiser@chef.io)
5
- # Copyright:: Copyright 2008-2016, Chef, Inc.
6
- # License:: Apache License, Version 2.0
7
- #
8
- # Licensed under the Apache License, Version 2.0 (the "License");
9
- # you may not use this file except in compliance with the License.
10
- # You may obtain a copy of the License at
11
- #
12
- # http://www.apache.org/licenses/LICENSE-2.0
13
- #
14
- # Unless required by applicable law or agreed to in writing, software
15
- # distributed under the License is distributed on an "AS IS" BASIS,
16
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
- # See the License for the specific language governing permissions and
18
- # limitations under the License.
19
- #
20
-
21
- require "chef/exceptions"
22
- require "chef/dsl/data_query"
23
- require "chef/dsl/registry_helper"
24
- require "chef/dsl/reboot_pending"
25
- require "chef/dsl/resources"
26
- require "chef/dsl/declare_resource"
27
- require "chef/json_compat"
28
- require "chef/mixin/convert_to_class_name"
29
- require "chef/guard_interpreter/resource_guard_interpreter"
30
- require "chef/resource/conditional"
31
- require "chef/resource/conditional_action_not_nothing"
32
- require "chef/resource/action_class"
33
- require "chef/resource_collection"
34
- require "chef/node_map"
35
- require "chef/node"
36
- require "chef/platform"
37
- require "chef/resource/resource_notification"
38
- require "chef/provider_resolver"
39
- require "chef/resource_resolver"
40
- require "chef/provider"
41
- require "set"
42
-
43
- require "chef/mixin/deprecation"
44
- require "chef/mixin/properties"
45
- require "chef/mixin/provides"
46
- require "chef/dsl/universal"
47
-
48
- class Chef
49
- class Resource
50
-
51
- #
52
- # Generic User DSL (not resource-specific)
53
- #
54
-
55
- include Chef::DSL::DeclareResource
56
- include Chef::DSL::DataQuery
57
- include Chef::DSL::RegistryHelper
58
- include Chef::DSL::RebootPending
59
- extend Chef::Mixin::Provides
60
-
61
- include Chef::DSL::Universal
62
-
63
- # Bring in `property` and `property_type`
64
- include Chef::Mixin::Properties
65
-
66
- #
67
- # The name of this particular resource.
68
- #
69
- # This special resource attribute is set automatically from the declaration
70
- # of the resource, e.g.
71
- #
72
- # execute 'Vitruvius' do
73
- # command 'ls'
74
- # end
75
- #
76
- # Will set the name to "Vitruvius".
77
- #
78
- # This is also used in to_s to show the resource name, e.g. `execute[Vitruvius]`.
79
- #
80
- # This is also used for resource notifications and subscribes in the same manner.
81
- #
82
- # This will coerce any object into a string via #to_s. Arrays are a special case
83
- # so that `package ["foo", "bar"]` becomes package[foo, bar] instead of the more
84
- # awkward `package[["foo", "bar"]]` that #to_s would produce.
85
- #
86
- # @param name [Object] The name to set, typically a String or Array
87
- # @return [String] The name of this Resource.
88
- #
89
- property :name, String, coerce: proc { |v| v.is_a?(Array) ? v.join(", ") : v.to_s }, desired_state: false, required: true
90
-
91
- #
92
- # The node the current Chef run is using.
93
- #
94
- # Corresponds to `run_context.node`.
95
- #
96
- # @return [Chef::Node] The node the current Chef run is using.
97
- #
98
- def node
99
- run_context && run_context.node
100
- end
101
-
102
- #
103
- # Resource User Interface (for users)
104
- #
105
-
106
- #
107
- # Create a new Resource.
108
- #
109
- # @param name The name of this resource (corresponds to the #name attribute,
110
- # used for notifications to this resource).
111
- # @param run_context The context of the Chef run. Corresponds to #run_context.
112
- #
113
- def initialize(name, run_context = nil)
114
- name(name) unless name.nil?
115
- @run_context = run_context
116
-
117
- @logger = if run_context
118
- run_context.logger.with_child({ name: name, resource: resource_name })
119
- else
120
- Chef::Log.with_child({ name: name, resource: resource_name })
121
- end
122
-
123
- @before = nil
124
- @params = Hash.new
125
- @provider = nil
126
- @allowed_actions = self.class.allowed_actions.to_a
127
- @action = self.class.default_action
128
- @updated = false
129
- @updated_by_last_action = false
130
- @not_if = []
131
- @only_if = []
132
- @source_line = nil
133
- @deprecated = false
134
- @skip_docs = false
135
- # We would like to raise an error when the user gives us a guard
136
- # interpreter and a ruby_block to the guard. In order to achieve this
137
- # we need to understand when the user overrides the default guard
138
- # interpreter. Therefore we store the default separately in a different
139
- # attribute.
140
- @guard_interpreter = nil
141
- @default_guard_interpreter = :default
142
- @elapsed_time = 0
143
- end
144
-
145
- #
146
- # The action or actions that will be taken when this resource is run.
147
- #
148
- # @param arg [Array[Symbol], Symbol] A list of actions (e.g. `:create`)
149
- # @return [Array[Symbol]] the list of actions.
150
- #
151
- def action(arg = nil)
152
- if arg
153
- arg = Array(arg).map(&:to_sym)
154
- arg.each do |action|
155
- validate(
156
- { action: action },
157
- { action: { kind_of: Symbol, equal_to: allowed_actions } }
158
- )
159
- end
160
- @action = arg
161
- else
162
- @action
163
- end
164
- end
165
-
166
- # Alias for normal assigment syntax.
167
- alias_method :action=, :action
168
-
169
- #
170
- # Force a delayed notification into this resource's run_context.
171
- #
172
- # This should most likely be paired with action :nothing
173
- #
174
- # @param arg [Array[Symbol], Symbol] A list of actions (e.g. `:create`)
175
- #
176
- def delayed_action(arg)
177
- arg = Array(arg).map(&:to_sym)
178
- arg.map do |action|
179
- validate(
180
- { action: action },
181
- { action: { kind_of: Symbol, equal_to: allowed_actions } }
182
- )
183
- # the resource effectively sends a delayed notification to itself
184
- run_context.add_delayed_action(Notification.new(self, action, self, run_context.unified_mode))
185
- end
186
- end
187
-
188
- #
189
- # Sets up a notification that will run a particular action on another resource
190
- # if and when *this* resource is updated by an action.
191
- #
192
- # If the action does not update this resource, the notification never triggers.
193
- #
194
- # Only one resource may be specified per notification.
195
- #
196
- # `delayed` notifications will only *ever* happen once per resource, so if
197
- # multiple resources all notify a single resource to perform the same action,
198
- # the action will only happen once. However, if they ask for different
199
- # actions, each action will happen once, in the order they were updated.
200
- #
201
- # `immediate` notifications will cause the action to be triggered once per
202
- # notification, regardless of how many other resources have triggered the
203
- # notification as well.
204
- #
205
- # @param action The action to run on the other resource.
206
- # @param resource_spec [String, Hash, Chef::Resource] The resource to run.
207
- # @param timing [String, Symbol] When to notify. Has these values:
208
- # - `delayed`: Will run the action on the other resource after all other
209
- # actions have been run. This is the default.
210
- # - `immediate`, `immediately`: Will run the action on the other resource
211
- # immediately (before any other action is run).
212
- # - `before`: Will run the action on the other resource
213
- # immediately *before* the action is actually run.
214
- #
215
- # @example Resource by string
216
- # file '/foo.txt' do
217
- # content 'hi'
218
- # notifies :create, 'file[/bar.txt]'
219
- # end
220
- # file '/bar.txt' do
221
- # action :nothing
222
- # content 'hi'
223
- # end
224
- # @example Resource by hash
225
- # file '/foo.txt' do
226
- # content 'hi'
227
- # notifies :create, file: '/bar.txt'
228
- # end
229
- # file '/bar.txt' do
230
- # action :nothing
231
- # content 'hi'
232
- # end
233
- # @example Direct Resource
234
- # bar = file '/bar.txt' do
235
- # action :nothing
236
- # content 'hi'
237
- # end
238
- # file '/foo.txt' do
239
- # content 'hi'
240
- # notifies :create, bar
241
- # end
242
- #
243
- def notifies(action, resource_spec, timing = :delayed)
244
- # when using old-style resources(:template => "/foo.txt") style, you
245
- # could end up with multiple resources.
246
- validate_resource_spec!(resource_spec)
247
-
248
- resources = [ resource_spec ].flatten
249
- resources.each do |resource|
250
-
251
- case timing.to_s
252
- when "delayed"
253
- notifies_delayed(action, resource)
254
- when "immediate", "immediately"
255
- notifies_immediately(action, resource)
256
- when "before"
257
- notifies_before(action, resource)
258
- else
259
- raise ArgumentError, "invalid timing: #{timing} for notifies(#{action}, #{resources.inspect}, #{timing}) resource #{self} "\
260
- "Valid timings are: :delayed, :immediate, :immediately, :before"
261
- end
262
- end
263
-
264
- true
265
- end
266
-
267
- #
268
- # Token class to hold an unresolved subscribes call with an associated
269
- # run context.
270
- #
271
- # @api private
272
- # @see Resource#subscribes
273
- class UnresolvedSubscribes < self
274
- # The full key ise given as the name in {Resource#subscribes}
275
- alias_method :to_s, :name
276
- alias_method :declared_key, :name
277
- end
278
-
279
- #
280
- # Subscribes to updates from other resources, causing a particular action to
281
- # run on *this* resource when the other resource is updated.
282
- #
283
- # If multiple resources are specified, this resource action will be run if
284
- # *any* of them change.
285
- #
286
- # This notification will only trigger *once*, no matter how many other
287
- # resources are updated (or how many actions are run by a particular resource).
288
- #
289
- # @param action The action to run on the other resource.
290
- # @param resources [String, Resource, Array[String, Resource]] The resources to subscribe to.
291
- # @param timing [String, Symbol] When to notify. Has these values:
292
- # - `delayed`: An update will cause the action to run after all other
293
- # actions have been run. This is the default.
294
- # - `immediate`, `immediately`: The action will run immediately following
295
- # the other resource being updated.
296
- # - `before`: The action will run immediately before the
297
- # other resource is updated.
298
- #
299
- # @example Resources by string
300
- # file '/foo.txt' do
301
- # content 'hi'
302
- # action :nothing
303
- # subscribes :create, 'file[/bar.txt]'
304
- # end
305
- # file '/bar.txt' do
306
- # content 'hi'
307
- # end
308
- # @example Direct resource
309
- # bar = file '/bar.txt' do
310
- # content 'hi'
311
- # end
312
- # file '/foo.txt' do
313
- # content 'hi'
314
- # action :nothing
315
- # subscribes :create, '/bar.txt'
316
- # end
317
- # @example Multiple resources by string
318
- # file '/foo.txt' do
319
- # content 'hi'
320
- # action :nothing
321
- # subscribes :create, [ 'file[/bar.txt]', 'file[/baz.txt]' ]
322
- # end
323
- # file '/bar.txt' do
324
- # content 'hi'
325
- # end
326
- # file '/baz.txt' do
327
- # content 'hi'
328
- # end
329
- # @example Multiple resources
330
- # bar = file '/bar.txt' do
331
- # content 'hi'
332
- # end
333
- # baz = file '/bar.txt' do
334
- # content 'hi'
335
- # end
336
- # file '/foo.txt' do
337
- # content 'hi'
338
- # action :nothing
339
- # subscribes :create, [ bar, baz ]
340
- # end
341
- #
342
- def subscribes(action, resources, timing = :delayed)
343
- resources = [resources].flatten
344
- resources.each do |resource|
345
- if resource.is_a?(String)
346
- resource = UnresolvedSubscribes.new(resource, run_context)
347
- end
348
- if resource.run_context.nil?
349
- resource.run_context = run_context
350
- end
351
- resource.notifies(action, self, timing)
352
- end
353
- true
354
- end
355
-
356
- #
357
- # A command or block that indicates whether to actually run this resource.
358
- # The command or block is run just before the action actually executes, and
359
- # the action will be skipped if the block returns false.
360
- #
361
- # If a block is specified, it must return `true` in order for the Resource
362
- # to be executed.
363
- #
364
- # If a command is specified, the resource's #guard_interpreter will run the
365
- # command and interpret the results according to `opts`. For example, the
366
- # default `execute` resource will be treated as `false` if the command
367
- # returns a non-zero exit code, and `true` if it returns 0. Thus, in the
368
- # default case:
369
- #
370
- # - `only_if "your command"` will perform the action only if `your command`
371
- # returns 0.
372
- # - `only_if "your command", valid_exit_codes: [ 1, 2, 3 ]` will perform the
373
- # action only if `your command` returns 1, 2, or 3.
374
- #
375
- # @param command [String] A string to execute.
376
- # @param opts [Hash] Options control the execution of the command
377
- # @param block [Proc] A ruby block to run. Ignored if a command is given.
378
- #
379
- def only_if(command = nil, opts = {}, &block)
380
- if command || block_given?
381
- @only_if << Conditional.only_if(self, command, opts, &block)
382
- end
383
- @only_if
384
- end
385
-
386
- #
387
- # A command or block that indicates whether to actually run this resource.
388
- # The command or block is run just before the action actually executes, and
389
- # the action will be skipped if the block returns true.
390
- #
391
- # If a block is specified, it must return `false` in order for the Resource
392
- # to be executed.
393
- #
394
- # If a command is specified, the resource's #guard_interpreter will run the
395
- # command and interpret the results according to `opts`. For example, the
396
- # default `execute` resource will be treated as `false` if the command
397
- # returns a non-zero exit code, and `true` if it returns 0. Thus, in the
398
- # default case:
399
- #
400
- # - `not_if "your command"` will perform the action only if `your command`
401
- # returns a non-zero code.
402
- # - `only_if "your command", valid_exit_codes: [ 1, 2, 3 ]` will perform the
403
- # action only if `your command` returns something other than 1, 2, or 3.
404
- #
405
- # @param command [String] A string to execute.
406
- # @param opts [Hash] Options control the execution of the command
407
- # @param block [Proc] A ruby block to run. Ignored if a command is given.
408
- #
409
- def not_if(command = nil, opts = {}, &block)
410
- if command || block_given?
411
- @not_if << Conditional.not_if(self, command, opts, &block)
412
- end
413
- @not_if
414
- end
415
-
416
- #
417
- # The number of times to retry this resource if it fails by throwing an
418
- # exception while running an action. Default: 0
419
- #
420
- # When the retries have run out, the Resource will throw the last
421
- # exception.
422
- #
423
- # @param arg [Integer] The number of retries.
424
- # @return [Integer] The number of retries.
425
- #
426
- property :retries, Integer, default: 0, desired_state: false
427
-
428
- #
429
- # The number of seconds to wait between retries. Default: 2.
430
- #
431
- # @param arg [Integer] The number of seconds to wait between retries.
432
- # @return [Integer] The number of seconds to wait between retries.
433
- #
434
- property :retry_delay, Integer, default: 2, desired_state: false
435
-
436
- #
437
- # Whether to treat this resource's data as sensitive. If set, no resource
438
- # data will be displayed in log output.
439
- #
440
- # @param arg [Boolean] Whether this resource is sensitive or not.
441
- # @return [Boolean] Whether this resource is sensitive or not.
442
- #
443
- property :sensitive, [ TrueClass, FalseClass ], default: false, desired_state: false
444
-
445
- #
446
- # The time it took (in seconds) to run the most recently-run action. Not
447
- # cumulative across actions. This is set to 0 as soon as a new action starts
448
- # running, and set to the elapsed time at the end of the action.
449
- #
450
- # @return [Integer] The time (in seconds) it took to process the most recent
451
- # action. Not cumulative.
452
- #
453
- attr_reader :elapsed_time
454
-
455
- #
456
- # The guard interpreter that will be used to process `only_if` and `not_if`
457
- # statements. If left unset, the #default_guard_interpreter will be used.
458
- #
459
- # Must be a resource class like `Chef::Resource::Execute`, or
460
- # a corresponding to the name of a resource. The resource must descend from
461
- # `Chef::Resource::Execute`.
462
- #
463
- # TODO this needs to be coerced on input so that retrieval is consistent.
464
- #
465
- # @param arg [Class, Symbol, String] The Guard interpreter resource class/
466
- # symbol/name.
467
- # @return [Class, Symbol, String] The Guard interpreter resource.
468
- #
469
- def guard_interpreter(arg = nil)
470
- if arg.nil?
471
- @guard_interpreter || @default_guard_interpreter
472
- else
473
- set_or_return(:guard_interpreter, arg, kind_of: Symbol)
474
- end
475
- end
476
-
477
- #
478
- # Get the value of the state attributes in this resource as a hash.
479
- #
480
- # Does not include properties that are not set (unless they are identity
481
- # properties).
482
- #
483
- # @return [Hash{Symbol => Object}] A Hash of attribute => value for the
484
- # Resource class's `state_attrs`.
485
- #
486
- def state_for_resource_reporter
487
- state = {}
488
- state_properties = self.class.state_properties
489
- state_properties.each do |property|
490
- if property.identity? || property.is_set?(self)
491
- state[property.name] = property.sensitive? ? "*sensitive value suppressed*" : send(property.name)
492
- end
493
- end
494
- state
495
- end
496
-
497
- #
498
- # The value of the identity of this resource.
499
- #
500
- # - If there are no identity properties on the resource, `name` is returned.
501
- # - If there is exactly one identity property on the resource, it is returned.
502
- # - If there are more than one, they are returned in a hash.
503
- #
504
- # @return [Object,Hash<Symbol,Object>] The identity of this resource.
505
- #
506
- def identity
507
- result = {}
508
- identity_properties = self.class.identity_properties
509
- identity_properties.each do |property|
510
- result[property.name] = send(property.name)
511
- end
512
- return result.values.first if identity_properties.size == 1
513
- result
514
- end
515
-
516
- #
517
- # Whether to ignore failures. If set to `true`, and this resource when an
518
- # action is run, the resource will be marked as failed but no exception will
519
- # be thrown (and no error will be output). Defaults to `false`. If set to
520
- # `:quiet` or `'quiet'`, the normal error trace will be suppressed.
521
- #
522
- # TODO ignore_failure and retries seem to be mutually exclusive; I doubt
523
- # that was intended.
524
- #
525
- # @param arg [Boolean, String, Symbol] Whether to ignore failures.
526
- # @return Whether this resource will ignore failures.
527
- #
528
- property :ignore_failure, [ true, false, :quiet, "quiet" ], default: false, desired_state: false
529
-
530
- #
531
- # Make this resource into an exact (shallow) copy of the other resource.
532
- #
533
- # @param resource [Chef::Resource] The resource to copy from.
534
- #
535
- def load_from(resource)
536
- resource.instance_variables.each do |iv|
537
- unless iv == :@source_line || iv == :@action || iv == :@not_if || iv == :@only_if
538
- instance_variable_set(iv, resource.instance_variable_get(iv))
539
- end
540
- end
541
- end
542
-
543
- #
544
- # Runs the given action on this resource, immediately.
545
- #
546
- # @param action The action to run (e.g. `:create`)
547
- # @param notification_type The notification type that triggered this (if any)
548
- # @param notifying_resource The resource that triggered this notification (if any)
549
- #
550
- # @raise Any error that occurs during the actual action.
551
- #
552
- def run_action(action, notification_type = nil, notifying_resource = nil)
553
- # reset state in case of multiple actions on the same resource.
554
- @elapsed_time = 0
555
- start_time = Time.now
556
- events.resource_action_start(self, action, notification_type, notifying_resource)
557
- # Try to resolve lazy/forward references in notifications again to handle
558
- # the case where the resource was defined lazily (ie. in a ruby_block)
559
- resolve_notification_references
560
- validate_action(action)
561
-
562
- if Chef::Config[:verbose_logging] || logger.level == :debug
563
- # This can be noisy
564
- logger.info("Processing #{self} action #{action} (#{defined_at})")
565
- end
566
-
567
- # ensure that we don't leave @updated_by_last_action set to true
568
- # on accident
569
- updated_by_last_action(false)
570
-
571
- # Don't modify @retries directly and keep it intact, so that the
572
- # recipe_snippet from ResourceFailureInspector can print the value
573
- # that was set in the resource block initially.
574
- remaining_retries = retries
575
-
576
- begin
577
- return if should_skip?(action)
578
- provider_for_action(action).run_action
579
- rescue StandardError => e
580
- if ignore_failure
581
- logger.error("#{custom_exception_message(e)}; ignore_failure is set, continuing")
582
- events.resource_failed(self, action, e)
583
- elsif remaining_retries > 0
584
- events.resource_failed_retriable(self, action, remaining_retries, e)
585
- remaining_retries -= 1
586
- logger.info("Retrying execution of #{self}, #{remaining_retries} attempt#{"s" if remaining_retries > 1} left")
587
- sleep retry_delay
588
- retry
589
- else
590
- events.resource_failed(self, action, e)
591
- raise customize_exception(e)
592
- end
593
- end
594
- ensure
595
- @elapsed_time = Time.now - start_time
596
- # Reporting endpoint doesn't accept a negative resource duration so set it to 0.
597
- # A negative value can occur when a resource changes the system time backwards
598
- @elapsed_time = 0 if @elapsed_time < 0
599
- events.resource_completed(self)
600
- end
601
-
602
- #
603
- # If we are currently initializing the resource, this will be true.
604
- #
605
- # Do NOT use this. It may be removed. It is for internal purposes only.
606
- # @api private
607
- attr_reader :resource_initializing
608
- def resource_initializing=(value)
609
- if value
610
- @resource_initializing = true
611
- else
612
- remove_instance_variable(:@resource_initializing)
613
- end
614
- end
615
-
616
- #
617
- # Generic Ruby and Data Structure Stuff (for user)
618
- #
619
-
620
- def to_s
621
- "#{resource_name}[#{name}]"
622
- end
623
-
624
- def to_text
625
- return "suppressed sensitive resource output" if sensitive
626
- text = "# Declared in #{@source_line}\n\n"
627
- text << "#{resource_name}(\"#{name}\") do\n"
628
-
629
- all_props = {}
630
- self.class.state_properties.map do |p|
631
- begin
632
- all_props[p.name.to_s] = p.sensitive? ? '"*sensitive value suppressed*"' : value_to_text(p.get(self))
633
- rescue Chef::Exceptions::ValidationFailed
634
- # This space left intentionally blank, the property was probably required or had an invalid default.
635
- end
636
- end
637
-
638
- ivars = instance_variables.map { |ivar| ivar.to_sym } - HIDDEN_IVARS
639
- ivars.each do |ivar|
640
- iv = ivar.to_s.sub(/^@/, "")
641
- if all_props.keys.include?(iv)
642
- text << " #{iv} #{all_props[iv]}\n"
643
- elsif (value = instance_variable_get(ivar)) && !(value.respond_to?(:empty?) && value.empty?)
644
- text << " #{iv} #{value_to_text(value)}\n"
645
- end
646
- end
647
-
648
- [@not_if, @only_if].flatten.each do |conditional|
649
- text << " #{conditional.to_text}\n"
650
- end
651
- text << "end\n"
652
- end
653
-
654
- def value_to_text(value)
655
- value.respond_to?(:to_text) ? value.to_text : value.inspect
656
- end
657
-
658
- def inspect
659
- ivars = instance_variables.map { |ivar| ivar.to_sym } - FORBIDDEN_IVARS
660
- ivars.inject("<#{self}") do |str, ivar|
661
- str << " #{ivar}: #{instance_variable_get(ivar).inspect}"
662
- end << ">"
663
- end
664
-
665
- # as_json does most of the to_json heavy lifted. It exists here in case activesupport
666
- # is loaded. activesupport will call as_json and skip over to_json. This ensure
667
- # json is encoded as expected
668
- def as_json(*a)
669
- safe_ivars = instance_variables.map { |ivar| ivar.to_sym } - FORBIDDEN_IVARS
670
- instance_vars = Hash.new
671
- safe_ivars.each do |iv|
672
- instance_vars[iv.to_s.sub(/^@/, "")] = instance_variable_get(iv)
673
- end
674
- {
675
- "json_class" => self.class.name,
676
- "instance_vars" => instance_vars,
677
- }
678
- end
679
-
680
- # Serialize this object as a hash
681
- def to_json(*a)
682
- results = as_json
683
- Chef::JSONCompat.to_json(results, *a)
684
- end
685
-
686
- def to_h
687
- # Grab all current state, then any other ivars (backcompat)
688
- result = {}
689
- self.class.state_properties.each do |p|
690
- result[p.name] = p.get(self)
691
- end
692
- safe_ivars = instance_variables.map { |ivar| ivar.to_sym } - FORBIDDEN_IVARS
693
- safe_ivars.each do |iv|
694
- key = iv.to_s.sub(/^@/, "").to_sym
695
- next if result.key?(key)
696
- result[key] = instance_variable_get(iv)
697
- end
698
- result
699
- end
700
-
701
- alias_method :to_hash, :to_h
702
-
703
- def self.from_hash(o)
704
- resource = new(o["instance_vars"]["@name"])
705
- o["instance_vars"].each do |k, v|
706
- resource.instance_variable_set("@#{k}".to_sym, v)
707
- end
708
- resource
709
- end
710
-
711
- def self.json_create(o)
712
- from_hash(o)
713
- end
714
-
715
- def self.from_json(j)
716
- from_hash(Chef::JSONCompat.parse(j))
717
- end
718
-
719
- #
720
- # Resource Definition Interface (for resource developers)
721
- #
722
-
723
- include Chef::Mixin::Deprecation
724
-
725
- #
726
- # The provider class for this resource.
727
- #
728
- # If `action :x do ... end` has been declared on this resource or its
729
- # superclasses, this will return the `action_class`.
730
- #
731
- # If this is not set, `provider_for_action` will dynamically determine the
732
- # provider.
733
- #
734
- # @param arg [String, Symbol, Class] Sets the provider class for this resource.
735
- # If passed a String or Symbol, e.g. `:file` or `"file"`, looks up the
736
- # provider based on the name.
737
- #
738
- # @return The provider class for this resource.
739
- #
740
- # @see Chef::Resource.action_class
741
- #
742
- def provider(arg = nil)
743
- klass = if arg.kind_of?(String) || arg.kind_of?(Symbol)
744
- lookup_provider_constant(arg)
745
- else
746
- arg
747
- end
748
- set_or_return(:provider, klass, kind_of: [ Class ])
749
- end
750
-
751
- def provider=(arg)
752
- provider(arg)
753
- end
754
-
755
- #
756
- # Set or return the list of "state properties" implemented by the Resource
757
- # subclass.
758
- #
759
- # Equivalent to calling #state_properties and getting `state_properties.keys`.
760
- #
761
- # @deprecated Use state_properties.keys instead. Note that when you declare
762
- # properties with `property`: properties are added to state_properties by
763
- # default, and can be turned off with `desired_state: false`
764
- #
765
- # ```ruby
766
- # property :x # part of desired state
767
- # property :y, desired_state: false # not part of desired state
768
- # ```
769
- #
770
- # @param names [Array<Symbol>] A list of property names to set as desired
771
- # state.
772
- #
773
- # @return [Array<Symbol>] All property names with desired state.
774
- #
775
- def self.state_attrs(*names)
776
- state_properties(*names).map { |property| property.name }
777
- end
778
-
779
- #
780
- # Set the identity of this resource to a particular property.
781
- #
782
- # This drives #identity, which returns data that uniquely refers to a given
783
- # resource on the given node (in such a way that it can be correlated
784
- # across Chef runs).
785
- #
786
- # This method is unnecessary when declaring properties with `property`;
787
- # properties can be added to identity during declaration with
788
- # `identity: true`.
789
- #
790
- # ```ruby
791
- # property :x, identity: true # part of identity
792
- # property :y # not part of identity
793
- # ```
794
- #
795
- # @param name [Symbol] A list of property names to set as the identity.
796
- #
797
- # @return [Symbol] The identity property if there is only one; or `nil` if
798
- # there are more than one.
799
- #
800
- # @raise [ArgumentError] If no arguments are passed and the resource has
801
- # more than one identity property.
802
- #
803
- def self.identity_property(name = nil)
804
- result = identity_properties(*Array(name))
805
- if result.size > 1
806
- raise Chef::Exceptions::MultipleIdentityError, "identity_property cannot be called on an object with more than one identity property (#{result.map { |r| r.name }.join(", ")})."
807
- end
808
- result.first
809
- end
810
-
811
- #
812
- # Set a property as the "identity attribute" for this resource.
813
- #
814
- # Identical to calling #identity_property.first.key.
815
- #
816
- # @param name [Symbol] The name of the property to set.
817
- #
818
- # @return [Symbol]
819
- #
820
- # @deprecated `identity_property` should be used instead.
821
- #
822
- # @raise [ArgumentError] If no arguments are passed and the resource has
823
- # more than one identity property.
824
- #
825
- def self.identity_attr(name = nil)
826
- property = identity_property(name)
827
- return nil if !property
828
- property.name
829
- end
830
-
831
- #
832
- # The guard interpreter that will be used to process `only_if` and `not_if`
833
- # statements by default. If left unset, or set to `:default`, the guard
834
- # interpreter used will be Chef::GuardInterpreter::DefaultGuardInterpreter.
835
- #
836
- # Must be a resource class like `Chef::Resource::Execute`, or
837
- # a corresponding to the name of a resource. The resource must descend from
838
- # `Chef::Resource::Execute`.
839
- #
840
- # TODO this needs to be coerced on input so that retrieval is consistent.
841
- #
842
- # @return [Class, Symbol, String] the default Guard interpreter resource.
843
- #
844
- attr_reader :default_guard_interpreter
845
-
846
- #
847
- # The list of actions this Resource is allowed to have. Setting `action`
848
- # will fail unless it is in this list. Default: [ :nothing ]
849
- #
850
- # @return [Array<Symbol>] The list of actions this Resource is allowed to
851
- # have.
852
- #
853
- attr_writer :allowed_actions
854
- def allowed_actions(value = NOT_PASSED)
855
- if value != NOT_PASSED
856
- self.allowed_actions = value
857
- end
858
- @allowed_actions
859
- end
860
-
861
- #
862
- # Whether or not this resource was updated during an action. If multiple
863
- # actions are set on the resource, this will be `true` if *any* action
864
- # caused an update to happen.
865
- #
866
- # @return [Boolean] Whether the resource was updated during an action.
867
- #
868
- attr_reader :updated
869
-
870
- #
871
- # Whether or not this resource was updated during an action. If multiple
872
- # actions are set on the resource, this will be `true` if *any* action
873
- # caused an update to happen.
874
- #
875
- # @return [Boolean] Whether the resource was updated during an action.
876
- #
877
- def updated?
878
- updated
879
- end
880
-
881
- #
882
- # Whether or not this resource was updated during the most recent action.
883
- # This is set to `false` at the beginning of each action.
884
- #
885
- # @param true_or_false [Boolean] Whether the resource was updated during the
886
- # current / most recent action.
887
- # @return [Boolean] Whether the resource was updated during the most recent action.
888
- #
889
- def updated_by_last_action(true_or_false)
890
- @updated ||= true_or_false
891
- @updated_by_last_action = true_or_false
892
- end
893
-
894
- #
895
- # Whether or not this resource was updated during the most recent action.
896
- # This is set to `false` at the beginning of each action.
897
- #
898
- # @return [Boolean] Whether the resource was updated during the most recent action.
899
- #
900
- def updated_by_last_action?
901
- @updated_by_last_action
902
- end
903
-
904
- #
905
- # The display name of this resource type, for printing purposes.
906
- #
907
- # Will be used to print out the resource in messages, e.g. resource_name[name]
908
- #
909
- # @return [Symbol] The name of this resource type (e.g. `:execute`).
910
- #
911
- def resource_name
912
- @resource_name || self.class.resource_name
913
- end
914
-
915
- #
916
- # A hook called after a resource is created. Meant to be overriden by
917
- # subclasses.
918
- #
919
- def after_created
920
- nil
921
- end
922
-
923
- #
924
- # The display name of this resource type, for printing purposes.
925
- #
926
- # This also automatically calls "provides" to provide DSL with the given
927
- # name.
928
- #
929
- # resource_name defaults to your class name.
930
- #
931
- # Call `resource_name nil` to remove the resource name (and any
932
- # corresponding DSL).
933
- #
934
- # @param value [Symbol] The desired name of this resource type (e.g.
935
- # `execute`), or `nil` if this class is abstract and has no resource_name.
936
- #
937
- # @return [Symbol] The name of this resource type (e.g. `:execute`).
938
- #
939
- def self.resource_name(name = NOT_PASSED)
940
- # Setter
941
- if name != NOT_PASSED
942
- remove_canonical_dsl
943
-
944
- # Set the resource_name and call provides
945
- if name
946
- name = name.to_sym
947
- # If our class is not already providing this name, provide it.
948
- if !Chef::ResourceResolver.includes_handler?(name, self)
949
- provides name, canonical: true
950
- end
951
- @resource_name = name
952
- else
953
- @resource_name = nil
954
- end
955
- end
956
- @resource_name
957
- end
958
-
959
- def self.resource_name=(name)
960
- resource_name(name)
961
- end
962
-
963
- #
964
- # Use the class name as the resource name.
965
- #
966
- # Munges the last part of the class name from camel case to snake case,
967
- # and sets the resource_name to that:
968
- #
969
- # A::B::BlahDBlah -> blah_d_blah
970
- #
971
- def self.use_automatic_resource_name
972
- automatic_name = convert_to_snake_case(name.split("::")[-1])
973
- resource_name automatic_name
974
- end
975
-
976
- # If the resource's action should run in separated compile/converge mode.
977
- #
978
- # @param flag [Boolean] value to set unified_mode to
979
- # @return [Boolean] unified_mode value
980
- def self.unified_mode(flag = nil)
981
- @unified_mode = Chef::Config[:resource_unified_mode_default] if @unified_mode.nil?
982
- @unified_mode = flag unless flag.nil?
983
- !!@unified_mode
984
- end
985
-
986
- #
987
- # The list of allowed actions for the resource.
988
- #
989
- # @param actions [Array<Symbol>] The list of actions to add to allowed_actions.
990
- #
991
- # @return [Array<Symbol>] The list of actions, as symbols.
992
- #
993
- def self.allowed_actions(*actions)
994
- @allowed_actions ||=
995
- if superclass.respond_to?(:allowed_actions)
996
- superclass.allowed_actions.dup
997
- else
998
- [ :nothing ]
999
- end
1000
- @allowed_actions |= actions.flatten
1001
- end
1002
-
1003
- def self.allowed_actions=(value)
1004
- @allowed_actions = value.uniq
1005
- end
1006
-
1007
- #
1008
- # The action that will be run if no other action is specified.
1009
- #
1010
- # Setting default_action will automatially add the action to
1011
- # allowed_actions, if it isn't already there.
1012
- #
1013
- # Defaults to [:nothing].
1014
- #
1015
- # @param action_name [Symbol,Array<Symbol>] The default action (or series
1016
- # of actions) to use.
1017
- #
1018
- # @return [Array<Symbol>] The default actions for the resource.
1019
- #
1020
- def self.default_action(action_name = NOT_PASSED)
1021
- unless action_name.equal?(NOT_PASSED)
1022
- @default_action = Array(action_name).map(&:to_sym)
1023
- self.allowed_actions |= @default_action
1024
- end
1025
-
1026
- if @default_action
1027
- @default_action
1028
- elsif superclass.respond_to?(:default_action)
1029
- superclass.default_action
1030
- else
1031
- [:nothing]
1032
- end
1033
- end
1034
-
1035
- def self.default_action=(action_name)
1036
- default_action action_name
1037
- end
1038
-
1039
- # Define an action on this resource.
1040
- #
1041
- # The action is defined as a *recipe* block that will be compiled and then
1042
- # converged when the action is taken (when Resource is converged). The recipe
1043
- # has access to the resource's attributes and methods, as well as the Chef
1044
- # recipe DSL.
1045
- #
1046
- # Resources in the action recipe may notify and subscribe to other resources
1047
- # within the action recipe, but cannot notify or subscribe to resources
1048
- # in the main Chef run.
1049
- #
1050
- # Resource actions are *inheritable*: if resource A defines `action :create`
1051
- # and B is a subclass of A, B gets all of A's actions. Additionally,
1052
- # resource B can define `action :create` and call `super()` to invoke A's
1053
- # action code.
1054
- #
1055
- # The first action defined (besides `:nothing`) will become the default
1056
- # action for the resource.
1057
- #
1058
- # @param name [Symbol] The action name to define.
1059
- # @param recipe_block The recipe to run when the action is taken. This block
1060
- # takes no parameters, and will be evaluated in a new context containing:
1061
- #
1062
- # - The resource's public and protected methods (including attributes)
1063
- # - The Chef Recipe DSL (file, etc.)
1064
- # - super() referring to the parent version of the action (if any)
1065
- #
1066
- # @return The Action class implementing the action
1067
- #
1068
- def self.action(action, &recipe_block)
1069
- action = action.to_sym
1070
- declare_action_class
1071
- action_class.action(action, &recipe_block)
1072
- self.allowed_actions += [ action ]
1073
- default_action action if Array(default_action) == [:nothing]
1074
- end
1075
-
1076
- # Define a method to load up this resource's properties with the current
1077
- # actual values.
1078
- #
1079
- # @param load_block The block to load. Will be run in the context of a newly
1080
- # created resource with its identity values filled in.
1081
- #
1082
- def self.load_current_value(&load_block)
1083
- define_method(:load_current_value!, &load_block)
1084
- end
1085
-
1086
- # Call this in `load_current_value` to indicate that the value does not
1087
- # exist and that `current_resource` should therefore be `nil`.
1088
- #
1089
- # @raise Chef::Exceptions::CurrentValueDoesNotExist
1090
- #
1091
- def current_value_does_not_exist!
1092
- raise Chef::Exceptions::CurrentValueDoesNotExist
1093
- end
1094
-
1095
- # Get the current actual value of this resource.
1096
- #
1097
- # This does not cache--a new value will be returned each time.
1098
- #
1099
- # @return A new copy of the resource, with values filled in from the actual
1100
- # current value.
1101
- #
1102
- def current_value
1103
- provider = provider_for_action(Array(action).first)
1104
- if provider.whyrun_mode? && !provider.whyrun_supported?
1105
- raise "Cannot retrieve #{self.class.current_resource} in why-run mode: #{provider} does not support why-run"
1106
- end
1107
- provider.load_current_resource
1108
- provider.current_resource
1109
- end
1110
-
1111
- #
1112
- # The action class is a `Chef::Provider` which is created at Resource
1113
- # class evaluation time when the Custom Resource is being constructed.
1114
- #
1115
- # This happens the first time the ruby parser hits an `action` or an
1116
- # `action_class` method, the presence of either indiates that this is
1117
- # going to be a Chef-12.5 custom resource. If we never see one of these
1118
- # directives then we are constructing an old-style Resource+Provider or
1119
- # LWRP or whatevs.
1120
- #
1121
- # If a block is passed, the action_class is always created and the block is
1122
- # run inside it.
1123
- #
1124
- def self.action_class(&block)
1125
- @action_class ||= declare_action_class
1126
- @action_class.class_eval(&block) if block
1127
- @action_class
1128
- end
1129
-
1130
- # Returns true or false based on if the resource is a custom resource. The
1131
- # top-level Chef::Resource is not a chef resource. This value is inherited.
1132
- #
1133
- # @return [Boolean] if the resource is a custom_resource
1134
- def self.custom_resource?
1135
- false
1136
- end
1137
-
1138
- # This sets the resource to being a custom resource, and does so in a way
1139
- # that automatically inherits to all subclasses via defining a method on
1140
- # the class (class variables and class instance variables don't have the
1141
- # correct semantics here, this is a poor man's activesupport class_attribute)
1142
- #
1143
- # @api private
1144
- def self.is_custom_resource!
1145
- define_singleton_method :custom_resource? do
1146
- true
1147
- end
1148
- end
1149
-
1150
- # Ensure the action class actually gets created. This is called
1151
- # when the user does `action :x do ... end`.
1152
- #
1153
- # @api private
1154
- def self.declare_action_class
1155
- @action_class ||=
1156
- begin
1157
- is_custom_resource!
1158
- base_provider =
1159
- if superclass.custom_resource?
1160
- superclass.action_class
1161
- else
1162
- ActionClass
1163
- end
1164
-
1165
- resource_class = self
1166
- Class.new(base_provider) do
1167
- self.resource_class = resource_class
1168
- end
1169
- end
1170
- end
1171
-
1172
- # Set or return if this resource is in preview mode.
1173
- #
1174
- # This only has value in the resource_inspector to mark a resource as being new-to-chef-core.
1175
- # Its meaning is probably more equivalent to "experimental" in that the API might change even
1176
- # in minor versions due to bugfixing and is NOT considered "stable" yet.
1177
- #
1178
- # @param value [nil, Boolean] If nil, get the current value. If not nil, set
1179
- # the value of the flag.
1180
- # @return [Boolean]
1181
- def self.preview_resource(value = nil)
1182
- @preview_resource = false unless defined?(@preview_resource)
1183
- @preview_resource = value unless value.nil?
1184
- @preview_resource
1185
- end
1186
-
1187
- #
1188
- # Internal Resource Interface (for Chef)
1189
- #
1190
-
1191
- FORBIDDEN_IVARS = [:@run_context, :@logger, :@not_if, :@only_if, :@enclosing_provider, :@description, :@introduced, :@examples, :@validation_message, :@deprecated, :@default_description, :@skip_docs].freeze
1192
- HIDDEN_IVARS = [:@allowed_actions, :@resource_name, :@source_line, :@run_context, :@logger, :@name, :@not_if, :@only_if, :@elapsed_time, :@enclosing_provider, :@description, :@introduced, :@examples, :@validation_message, :@deprecated, :@default_description, :@skip_docs].freeze
1193
-
1194
- include Chef::Mixin::ConvertToClassName
1195
- extend Chef::Mixin::ConvertToClassName
1196
-
1197
- # XXX: this is required for definition params inside of the scope of a
1198
- # subresource to work correctly.
1199
- attr_accessor :params
1200
-
1201
- # @return [Chef::RunContext] The run context for this Resource. This is
1202
- # where the context for the current Chef run is stored, including the node
1203
- # and the resource collection.
1204
- #
1205
- attr_accessor :run_context
1206
-
1207
- # @return [Mixlib::Log::Child] The logger for this resources. This is a child
1208
- # of the run context's logger, if one exists.
1209
- #
1210
- attr_reader :logger
1211
-
1212
- # @return [String] The cookbook this resource was declared in.
1213
- #
1214
- attr_accessor :cookbook_name
1215
-
1216
- # @return [String] The recipe this resource was declared in.
1217
- #
1218
- attr_accessor :recipe_name
1219
-
1220
- # @return [Chef::Provider] The provider this resource was declared in (if
1221
- # it was declared in an LWRP). When you call methods that do not exist
1222
- # on this Resource, Chef will try to call the method on the provider
1223
- # as well before giving up.
1224
- #
1225
- attr_accessor :enclosing_provider
1226
-
1227
- # @return [String] The source line where this resource was declared.
1228
- # Expected to come from caller() or a stack trace, it usually follows one
1229
- # of these formats:
1230
- # /some/path/to/file.rb:80:in `wombat_tears'
1231
- # C:/some/path/to/file.rb:80 in 1`wombat_tears'
1232
- #
1233
- attr_accessor :source_line
1234
-
1235
- # @return [String] The actual name that was used to create this resource.
1236
- # Sometimes, when you say something like `package 'blah'`, the system will
1237
- # create a different resource (i.e. `YumPackage`). When this happens, the
1238
- # user will expect to see the thing they wrote, not the type that was
1239
- # returned. May be `nil`, in which case callers should read #resource_name.
1240
- # See #declared_key.
1241
- #
1242
- attr_accessor :declared_type
1243
-
1244
- # Iterates over all immediate and delayed notifications, calling
1245
- # resolve_resource_reference on each in turn, causing them to
1246
- # resolve lazy/forward references.
1247
- #
1248
- def resolve_notification_references(always_raise = false)
1249
- run_context.before_notifications(self).each do |n|
1250
- n.resolve_resource_reference(run_context.resource_collection, true)
1251
- end
1252
-
1253
- run_context.immediate_notifications(self).each do |n|
1254
- n.resolve_resource_reference(run_context.resource_collection, always_raise)
1255
- end
1256
-
1257
- run_context.delayed_notifications(self).each do |n|
1258
- n.resolve_resource_reference(run_context.resource_collection, always_raise)
1259
- end
1260
- end
1261
-
1262
- # Helper for #notifies
1263
- def notifies_before(action, resource_spec)
1264
- run_context.notifies_before(Notification.new(resource_spec, action, self, run_context.unified_mode))
1265
- end
1266
-
1267
- # Helper for #notifies
1268
- def notifies_immediately(action, resource_spec)
1269
- run_context.notifies_immediately(Notification.new(resource_spec, action, self, run_context.unified_mode))
1270
- end
1271
-
1272
- # Helper for #notifies
1273
- def notifies_delayed(action, resource_spec)
1274
- run_context.notifies_delayed(Notification.new(resource_spec, action, self, run_context.unified_mode))
1275
- end
1276
-
1277
- class << self
1278
- # back-compat
1279
- # NOTE: that we do not support unregistering classes as descendants like
1280
- # we used to for LWRP unloading because that was horrible and removed in
1281
- # Chef-12.
1282
- # @deprecated
1283
- # @api private
1284
- alias :resource_classes :descendants
1285
- # @deprecated
1286
- # @api private
1287
- alias :find_subclass_by_name :find_descendants_by_name
1288
- end
1289
-
1290
- # @deprecated
1291
- # @api private
1292
- # We memoize a sorted version of descendants so that resource lookups don't
1293
- # have to sort all the things, all the time.
1294
- # This was causing performance issues in test runs, and probably in real
1295
- # life as well.
1296
- @@sorted_descendants = nil
1297
- def self.sorted_descendants
1298
- @@sorted_descendants ||= descendants.sort_by { |x| x.to_s }
1299
- end
1300
-
1301
- def self.inherited(child)
1302
- super
1303
- @@sorted_descendants = nil
1304
- # set resource_name automatically if it's not set
1305
- if child.name && !child.resource_name
1306
- if child.name =~ /^Chef::Resource::(\w+)$/
1307
- child.resource_name(convert_to_snake_case($1))
1308
- end
1309
- end
1310
- end
1311
-
1312
- # If an unknown method is invoked, determine whether the enclosing Provider's
1313
- # lexical scope can fulfill the request. E.g. This happens when the Resource's
1314
- # block invokes new_resource.
1315
- def method_missing(method_symbol, *args, &block)
1316
- if enclosing_provider && enclosing_provider.respond_to?(method_symbol)
1317
- enclosing_provider.send(method_symbol, *args, &block)
1318
- else
1319
- raise NoMethodError, "undefined method `#{method_symbol}' for #{self.class}"
1320
- end
1321
- end
1322
-
1323
- # This API can be used for backcompat to do:
1324
- #
1325
- # chef_version_for_provides "< 14.0" if defined?(:chef_version_for_provides)
1326
- #
1327
- # For core chef versions that do not support chef_version: in provides lines.
1328
- #
1329
- # Since resource_name calls provides the generally correct way of doing this is
1330
- # to do `chef_version_for_provides` first, then `resource_name` and then
1331
- # any additional options `provides` lines. Calling `resource_name` is somewhat
1332
- # important to have the canonical_dsl removed or else that'll stick around
1333
- # and chef_version won't get applied to it.
1334
- #
1335
- # Once we no longer care about supporting chef < 14.4 then we can deprecate
1336
- # this API.
1337
- #
1338
- # @param arg [String] version constrant to match against (e.g. "> 14")
1339
- #
1340
- def self.chef_version_for_provides(constraint)
1341
- @chef_version_for_provides = constraint
1342
- end
1343
-
1344
- # Mark this resource as providing particular DSL.
1345
- #
1346
- # Resources have an automatic DSL based on their resource_name, equivalent to
1347
- # `provides :resource_name` (providing the resource on all OS's). If you
1348
- # declare a `provides` with the given resource_name, it *replaces* that
1349
- # provides (so that you can provide your resource DSL only on certain OS's).
1350
- #
1351
- def self.provides(name, **options, &block)
1352
- name = name.to_sym
1353
-
1354
- # `provides :resource_name, os: 'linux'`) needs to remove the old
1355
- # canonical DSL before adding the new one.
1356
- if @resource_name && name == @resource_name
1357
- remove_canonical_dsl
1358
- end
1359
-
1360
- if @chef_version_for_provides && !options.include?(:chef_version)
1361
- options[:chef_version] = @chef_version_for_provides
1362
- end
1363
-
1364
- result = Chef.resource_handler_map.set(name, self, options, &block)
1365
- Chef::DSL::Resources.add_resource_dsl(name)
1366
- result
1367
- end
1368
-
1369
- def self.provides?(node, resource_name)
1370
- Chef::ResourceResolver.new(node, resource_name).provided_by?(self)
1371
- end
1372
-
1373
- # Helper for #notifies
1374
- def validate_resource_spec!(resource_spec)
1375
- run_context.resource_collection.validate_lookup_spec!(resource_spec)
1376
- end
1377
-
1378
- # We usually want to store and reference resources by their declared type and not the actual type that
1379
- # was looked up by the Resolver (IE, "package" becomes YumPackage class). If we have not been provided
1380
- # the declared key we want to fall back on the old to_s key.
1381
- def declared_key
1382
- return to_s if declared_type.nil?
1383
- "#{declared_type}[#{@name}]"
1384
- end
1385
-
1386
- def before_notifications
1387
- run_context.before_notifications(self)
1388
- end
1389
-
1390
- def immediate_notifications
1391
- run_context.immediate_notifications(self)
1392
- end
1393
-
1394
- def delayed_notifications
1395
- run_context.delayed_notifications(self)
1396
- end
1397
-
1398
- def source_line_file
1399
- if source_line
1400
- source_line.match(/(.*):(\d+):?.*$/).to_a[1]
1401
- else
1402
- nil
1403
- end
1404
- end
1405
-
1406
- def source_line_number
1407
- if source_line
1408
- source_line.match(/(.*):(\d+):?.*$/).to_a[2]
1409
- else
1410
- nil
1411
- end
1412
- end
1413
-
1414
- def defined_at
1415
- # The following regexp should match these two sourceline formats:
1416
- # /some/path/to/file.rb:80:in `wombat_tears'
1417
- # C:/some/path/to/file.rb:80 in 1`wombat_tears'
1418
- # extracting the path to the source file and the line number.
1419
- if cookbook_name && recipe_name && source_line
1420
- "#{cookbook_name}::#{recipe_name} line #{source_line_number}"
1421
- elsif source_line
1422
- "#{source_line_file} line #{source_line_number}"
1423
- else
1424
- "dynamically defined"
1425
- end
1426
- end
1427
-
1428
- def self.description(description = "NOT_PASSED")
1429
- if description != "NOT_PASSED"
1430
- @description = description
1431
- end
1432
- @description
1433
- end
1434
-
1435
- def self.introduced(introduced = "NOT_PASSED")
1436
- if introduced != "NOT_PASSED"
1437
- @introduced = introduced
1438
- end
1439
- @introduced
1440
- end
1441
-
1442
- def self.examples(examples = "NOT_PASSED")
1443
- if examples != "NOT_PASSED"
1444
- @examples = examples
1445
- end
1446
- @examples
1447
- end
1448
-
1449
- def self.deprecated(deprecated = "NOT_PASSED")
1450
- if deprecated != "NOT_PASSED"
1451
- @deprecated = true
1452
- @deprecated_message = deprecated
1453
- end
1454
- @deprecated
1455
- end
1456
-
1457
- def self.skip_docs(skip_docs = "NOT_PASSED")
1458
- if skip_docs != "NOT_PASSED"
1459
- @skip_docs = skip_docs
1460
- end
1461
- @skip_docs
1462
- end
1463
-
1464
- def self.default_description(default_description = "NOT_PASSED")
1465
- if default_description != "NOT_PASSED"
1466
- @default_description = default_description
1467
- end
1468
- @default_description
1469
- end
1470
-
1471
- # The cookbook in which this Resource was defined (if any).
1472
- #
1473
- # @return Chef::CookbookVersion The cookbook in which this Resource was defined.
1474
- #
1475
- def cookbook_version
1476
- if cookbook_name
1477
- run_context.cookbook_collection[cookbook_name]
1478
- end
1479
- end
1480
-
1481
- def events
1482
- run_context.events
1483
- end
1484
-
1485
- def validate_action(action)
1486
- raise ArgumentError, "nil is not a valid action for resource #{self}" if action.nil?
1487
- end
1488
-
1489
- def provider_for_action(action)
1490
- provider_class = Chef::ProviderResolver.new(node, self, action).resolve
1491
- provider = provider_class.new(self, run_context)
1492
- provider.action = action
1493
- provider
1494
- end
1495
-
1496
- # Preface an exception message with generic Resource information.
1497
- #
1498
- # @param e [StandardError] An exception with `e.message`
1499
- # @return [String] An exception message customized with class name.
1500
- #
1501
- def custom_exception_message(e)
1502
- "#{self} (#{defined_at}) had an error: #{e.class.name}: #{e.message}"
1503
- end
1504
-
1505
- def customize_exception(e)
1506
- new_exception = e.exception(custom_exception_message(e))
1507
- new_exception.set_backtrace(e.backtrace)
1508
- new_exception
1509
- end
1510
-
1511
- # Evaluates not_if and only_if conditionals. Returns a falsey value if any
1512
- # of the conditionals indicate that this resource should be skipped, i.e.,
1513
- # if an only_if evaluates to false or a not_if evaluates to true.
1514
- #
1515
- # If this resource should be skipped, returns the first conditional that
1516
- # "fails" its check. Subsequent conditionals are not evaluated, so in
1517
- # general it's not a good idea to rely on side effects from not_if or
1518
- # only_if commands/blocks being evaluated.
1519
- #
1520
- # Also skips conditional checking when the action is :nothing
1521
- def should_skip?(action)
1522
- conditional_action = ConditionalActionNotNothing.new(action)
1523
-
1524
- conditionals = [ conditional_action ] + only_if + not_if
1525
- conditionals.find do |conditional|
1526
- if conditional.continue?
1527
- false
1528
- else
1529
- events.resource_skipped(self, action, conditional)
1530
- logger.debug("Skipping #{self} due to #{conditional.description}")
1531
- true
1532
- end
1533
- end
1534
- end
1535
-
1536
- # Returns a resource based on a short_name and node
1537
- #
1538
- # ==== Parameters
1539
- # short_name<Symbol>:: short_name of the resource (ie :directory)
1540
- # node<Chef::Node>:: Node object to look up platform and version in
1541
- #
1542
- # === Returns
1543
- # <Chef::Resource>:: returns the proper Chef::Resource class
1544
- def self.resource_for_node(short_name, node)
1545
- klass = Chef::ResourceResolver.resolve(short_name, node: node)
1546
- raise Chef::Exceptions::NoSuchResourceType.new(short_name, node) if klass.nil?
1547
- klass
1548
- end
1549
-
1550
- # Returns the class with the given resource_name.
1551
- #
1552
- # NOTE: Chef::Resource.resource_matching_short_name(:package) returns
1553
- # Chef::Resource::Package, while on rhel the API call
1554
- # Chef::Resource.resource_for_node(:package, node) will return
1555
- # Chef::Resource::YumPackage -- which is probably what you really
1556
- # want. This API should most likely be removed or changed to call
1557
- # resource_for_node.
1558
- #
1559
- # ==== Parameters
1560
- # short_name<Symbol>:: short_name of the resource (ie :directory)
1561
- #
1562
- # === Returns
1563
- # <Chef::Resource>:: returns the proper Chef::Resource class
1564
- #
1565
- def self.resource_matching_short_name(short_name)
1566
- Chef::ResourceResolver.resolve(short_name, canonical: true)
1567
- end
1568
-
1569
- # @api private
1570
- def lookup_provider_constant(name, action = :nothing)
1571
- # XXX: "name" is probably a poor choice of name here, ideally this would be nil, but we need to
1572
- # fix resources so that nil or empty names work (also solving the apt_update "doesn't matter one bit"
1573
- # problem). WARNING: this string is not a public API and should not be referenced (e.g. in provides blocks)
1574
- # and may change at any time. If you've found this comment you're also probably very lost and should maybe
1575
- # consider using `declare_resource :whatever` instead of trying to set `provider :whatever` on a resource, or in some
1576
- # other way reconsider what you're trying to do, since you're likely trying to force a bad design that we
1577
- # can't/won't support.
1578
- self.class.resource_for_node(name, node).new("name", run_context).provider_for_action(action).class
1579
- end
1580
-
1581
- def self.remove_canonical_dsl
1582
- if @resource_name
1583
- remaining = Chef.resource_handler_map.delete_canonical(@resource_name, self)
1584
- if !remaining
1585
- Chef::DSL::Resources.remove_resource_dsl(@resource_name)
1586
- end
1587
- end
1588
- end
1589
- end
1590
- end
1591
-
1592
- # Requiring things at the bottom breaks cycles
1593
- require "chef/chef_class"
1
+ #
2
+ # Author:: Adam Jacob (<adam@chef.io>)
3
+ # Author:: Christopher Walters (<cw@chef.io>)
4
+ # Author:: John Keiser (<jkeiser@chef.io)
5
+ # Copyright:: Copyright 2008-2016, Chef, Inc.
6
+ # License:: Apache License, Version 2.0
7
+ #
8
+ # Licensed under the Apache License, Version 2.0 (the "License");
9
+ # you may not use this file except in compliance with the License.
10
+ # You may obtain a copy of the License at
11
+ #
12
+ # http://www.apache.org/licenses/LICENSE-2.0
13
+ #
14
+ # Unless required by applicable law or agreed to in writing, software
15
+ # distributed under the License is distributed on an "AS IS" BASIS,
16
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
+ # See the License for the specific language governing permissions and
18
+ # limitations under the License.
19
+ #
20
+
21
+ require_relative "exceptions"
22
+ require_relative "dsl/data_query"
23
+ require_relative "dsl/registry_helper"
24
+ require_relative "dsl/reboot_pending"
25
+ require_relative "dsl/resources"
26
+ require_relative "dsl/declare_resource"
27
+ require_relative "json_compat"
28
+ require_relative "mixin/convert_to_class_name"
29
+ require_relative "guard_interpreter/resource_guard_interpreter"
30
+ require_relative "resource/conditional"
31
+ require_relative "resource/conditional_action_not_nothing"
32
+ require_relative "resource/action_class"
33
+ require_relative "resource_collection"
34
+ require_relative "node_map"
35
+ require_relative "node"
36
+ require_relative "platform"
37
+ require_relative "resource/resource_notification"
38
+ require_relative "provider_resolver"
39
+ require_relative "resource_resolver"
40
+ require_relative "provider"
41
+ require "set"
42
+
43
+ require_relative "mixin/deprecation"
44
+ require_relative "mixin/properties"
45
+ require_relative "mixin/provides"
46
+ require_relative "dsl/universal"
47
+
48
+ class Chef
49
+ class Resource
50
+
51
+ #
52
+ # Generic User DSL (not resource-specific)
53
+ #
54
+
55
+ include Chef::DSL::DeclareResource
56
+ include Chef::DSL::DataQuery
57
+ include Chef::DSL::RegistryHelper
58
+ include Chef::DSL::RebootPending
59
+ extend Chef::Mixin::Provides
60
+
61
+ include Chef::DSL::Universal
62
+
63
+ # Bring in `property` and `property_type`
64
+ include Chef::Mixin::Properties
65
+
66
+ #
67
+ # The name of this particular resource.
68
+ #
69
+ # This special resource attribute is set automatically from the declaration
70
+ # of the resource, e.g.
71
+ #
72
+ # execute 'Vitruvius' do
73
+ # command 'ls'
74
+ # end
75
+ #
76
+ # Will set the name to "Vitruvius".
77
+ #
78
+ # This is also used in to_s to show the resource name, e.g. `execute[Vitruvius]`.
79
+ #
80
+ # This is also used for resource notifications and subscribes in the same manner.
81
+ #
82
+ # This will coerce any object into a string via #to_s. Arrays are a special case
83
+ # so that `package ["foo", "bar"]` becomes package[foo, bar] instead of the more
84
+ # awkward `package[["foo", "bar"]]` that #to_s would produce.
85
+ #
86
+ # @param name [Object] The name to set, typically a String or Array
87
+ # @return [String] The name of this Resource.
88
+ #
89
+ property :name, String, coerce: proc { |v| v.is_a?(Array) ? v.join(", ") : v.to_s }, desired_state: false, required: true
90
+
91
+ #
92
+ # The node the current Chef run is using.
93
+ #
94
+ # Corresponds to `run_context.node`.
95
+ #
96
+ # @return [Chef::Node] The node the current Chef run is using.
97
+ #
98
+ def node
99
+ run_context && run_context.node
100
+ end
101
+
102
+ #
103
+ # Resource User Interface (for users)
104
+ #
105
+
106
+ #
107
+ # Create a new Resource.
108
+ #
109
+ # @param name The name of this resource (corresponds to the #name attribute,
110
+ # used for notifications to this resource).
111
+ # @param run_context The context of the Chef run. Corresponds to #run_context.
112
+ #
113
+ def initialize(name, run_context = nil)
114
+ name(name) unless name.nil?
115
+ @run_context = run_context
116
+
117
+ @logger = if run_context
118
+ run_context.logger.with_child({ name: name, resource: resource_name })
119
+ else
120
+ Chef::Log.with_child({ name: name, resource: resource_name })
121
+ end
122
+
123
+ @before = nil
124
+ @params = Hash.new
125
+ @provider = nil
126
+ @allowed_actions = self.class.allowed_actions.to_a
127
+ @action = self.class.default_action
128
+ @updated = false
129
+ @updated_by_last_action = false
130
+ @not_if = []
131
+ @only_if = []
132
+ @source_line = nil
133
+ @deprecated = false
134
+ @skip_docs = false
135
+ # We would like to raise an error when the user gives us a guard
136
+ # interpreter and a ruby_block to the guard. In order to achieve this
137
+ # we need to understand when the user overrides the default guard
138
+ # interpreter. Therefore we store the default separately in a different
139
+ # attribute.
140
+ @guard_interpreter = nil
141
+ @default_guard_interpreter = :default
142
+ @elapsed_time = 0
143
+ @executed_by_runner = false
144
+ end
145
+
146
+ #
147
+ # The action or actions that will be taken when this resource is run.
148
+ #
149
+ # @param arg [Array[Symbol], Symbol] A list of actions (e.g. `:create`)
150
+ # @return [Array[Symbol]] the list of actions.
151
+ #
152
+ def action(arg = nil)
153
+ if arg
154
+ arg = Array(arg).map(&:to_sym)
155
+ arg.each do |action|
156
+ validate(
157
+ { action: action },
158
+ { action: { kind_of: Symbol, equal_to: allowed_actions } }
159
+ )
160
+ end
161
+ @action = arg
162
+ else
163
+ @action
164
+ end
165
+ end
166
+
167
+ # Alias for normal assigment syntax.
168
+ alias_method :action=, :action
169
+
170
+ #
171
+ # Force a delayed notification into this resource's run_context.
172
+ #
173
+ # This should most likely be paired with action :nothing
174
+ #
175
+ # @param arg [Array[Symbol], Symbol] A list of actions (e.g. `:create`)
176
+ #
177
+ def delayed_action(arg)
178
+ arg = Array(arg).map(&:to_sym)
179
+ arg.map do |action|
180
+ validate(
181
+ { action: action },
182
+ { action: { kind_of: Symbol, equal_to: allowed_actions } }
183
+ )
184
+ # the resource effectively sends a delayed notification to itself
185
+ run_context.add_delayed_action(Notification.new(self, action, self))
186
+ end
187
+ end
188
+
189
+ #
190
+ # Sets up a notification that will run a particular action on another resource
191
+ # if and when *this* resource is updated by an action.
192
+ #
193
+ # If the action does not update this resource, the notification never triggers.
194
+ #
195
+ # Only one resource may be specified per notification.
196
+ #
197
+ # `delayed` notifications will only *ever* happen once per resource, so if
198
+ # multiple resources all notify a single resource to perform the same action,
199
+ # the action will only happen once. However, if they ask for different
200
+ # actions, each action will happen once, in the order they were updated.
201
+ #
202
+ # `immediate` notifications will cause the action to be triggered once per
203
+ # notification, regardless of how many other resources have triggered the
204
+ # notification as well.
205
+ #
206
+ # @param action The action to run on the other resource.
207
+ # @param resource_spec [String, Hash, Chef::Resource] The resource to run.
208
+ # @param timing [String, Symbol] When to notify. Has these values:
209
+ # - `delayed`: Will run the action on the other resource after all other
210
+ # actions have been run. This is the default.
211
+ # - `immediate`, `immediately`: Will run the action on the other resource
212
+ # immediately (before any other action is run).
213
+ # - `before`: Will run the action on the other resource
214
+ # immediately *before* the action is actually run.
215
+ #
216
+ # @example Resource by string
217
+ # file '/foo.txt' do
218
+ # content 'hi'
219
+ # notifies :create, 'file[/bar.txt]'
220
+ # end
221
+ # file '/bar.txt' do
222
+ # action :nothing
223
+ # content 'hi'
224
+ # end
225
+ # @example Resource by hash
226
+ # file '/foo.txt' do
227
+ # content 'hi'
228
+ # notifies :create, file: '/bar.txt'
229
+ # end
230
+ # file '/bar.txt' do
231
+ # action :nothing
232
+ # content 'hi'
233
+ # end
234
+ # @example Direct Resource
235
+ # bar = file '/bar.txt' do
236
+ # action :nothing
237
+ # content 'hi'
238
+ # end
239
+ # file '/foo.txt' do
240
+ # content 'hi'
241
+ # notifies :create, bar
242
+ # end
243
+ #
244
+ def notifies(action, resource_spec, timing = :delayed)
245
+ # when using old-style resources(:template => "/foo.txt") style, you
246
+ # could end up with multiple resources.
247
+ validate_resource_spec!(resource_spec)
248
+
249
+ resources = [ resource_spec ].flatten
250
+ resources.each do |resource|
251
+
252
+ case timing.to_s
253
+ when "delayed"
254
+ notifies_delayed(action, resource)
255
+ when "immediate", "immediately"
256
+ notifies_immediately(action, resource)
257
+ when "before"
258
+ notifies_before(action, resource)
259
+ else
260
+ raise ArgumentError, "invalid timing: #{timing} for notifies(#{action}, #{resources.inspect}, #{timing}) resource #{self} "\
261
+ "Valid timings are: :delayed, :immediate, :immediately, :before"
262
+ end
263
+ end
264
+
265
+ true
266
+ end
267
+
268
+ #
269
+ # Token class to hold an unresolved subscribes call with an associated
270
+ # run context.
271
+ #
272
+ # @api private
273
+ # @see Resource#subscribes
274
+ class UnresolvedSubscribes < self
275
+ # The full key ise given as the name in {Resource#subscribes}
276
+ alias_method :to_s, :name
277
+ alias_method :declared_key, :name
278
+ end
279
+
280
+ #
281
+ # Subscribes to updates from other resources, causing a particular action to
282
+ # run on *this* resource when the other resource is updated.
283
+ #
284
+ # If multiple resources are specified, this resource action will be run if
285
+ # *any* of them change.
286
+ #
287
+ # This notification will only trigger *once*, no matter how many other
288
+ # resources are updated (or how many actions are run by a particular resource).
289
+ #
290
+ # @param action The action to run on the other resource.
291
+ # @param resources [String, Resource, Array[String, Resource]] The resources to subscribe to.
292
+ # @param timing [String, Symbol] When to notify. Has these values:
293
+ # - `delayed`: An update will cause the action to run after all other
294
+ # actions have been run. This is the default.
295
+ # - `immediate`, `immediately`: The action will run immediately following
296
+ # the other resource being updated.
297
+ # - `before`: The action will run immediately before the
298
+ # other resource is updated.
299
+ #
300
+ # @example Resources by string
301
+ # file '/foo.txt' do
302
+ # content 'hi'
303
+ # action :nothing
304
+ # subscribes :create, 'file[/bar.txt]'
305
+ # end
306
+ # file '/bar.txt' do
307
+ # content 'hi'
308
+ # end
309
+ # @example Direct resource
310
+ # bar = file '/bar.txt' do
311
+ # content 'hi'
312
+ # end
313
+ # file '/foo.txt' do
314
+ # content 'hi'
315
+ # action :nothing
316
+ # subscribes :create, '/bar.txt'
317
+ # end
318
+ # @example Multiple resources by string
319
+ # file '/foo.txt' do
320
+ # content 'hi'
321
+ # action :nothing
322
+ # subscribes :create, [ 'file[/bar.txt]', 'file[/baz.txt]' ]
323
+ # end
324
+ # file '/bar.txt' do
325
+ # content 'hi'
326
+ # end
327
+ # file '/baz.txt' do
328
+ # content 'hi'
329
+ # end
330
+ # @example Multiple resources
331
+ # bar = file '/bar.txt' do
332
+ # content 'hi'
333
+ # end
334
+ # baz = file '/bar.txt' do
335
+ # content 'hi'
336
+ # end
337
+ # file '/foo.txt' do
338
+ # content 'hi'
339
+ # action :nothing
340
+ # subscribes :create, [ bar, baz ]
341
+ # end
342
+ #
343
+ def subscribes(action, resources, timing = :delayed)
344
+ resources = [resources].flatten
345
+ resources.each do |resource|
346
+ if resource.is_a?(String)
347
+ resource = UnresolvedSubscribes.new(resource, run_context)
348
+ end
349
+ if resource.run_context.nil?
350
+ resource.run_context = run_context
351
+ end
352
+ resource.notifies(action, self, timing)
353
+ end
354
+ true
355
+ end
356
+
357
+ #
358
+ # A command or block that indicates whether to actually run this resource.
359
+ # The command or block is run just before the action actually executes, and
360
+ # the action will be skipped if the block returns false.
361
+ #
362
+ # If a block is specified, it must return `true` in order for the Resource
363
+ # to be executed.
364
+ #
365
+ # If a command is specified, the resource's #guard_interpreter will run the
366
+ # command and interpret the results according to `opts`. For example, the
367
+ # default `execute` resource will be treated as `false` if the command
368
+ # returns a non-zero exit code, and `true` if it returns 0. Thus, in the
369
+ # default case:
370
+ #
371
+ # - `only_if "your command"` will perform the action only if `your command`
372
+ # returns 0.
373
+ # - `only_if "your command", valid_exit_codes: [ 1, 2, 3 ]` will perform the
374
+ # action only if `your command` returns 1, 2, or 3.
375
+ #
376
+ # @param command [String] A string to execute.
377
+ # @param opts [Hash] Options control the execution of the command
378
+ # @param block [Proc] A ruby block to run. Ignored if a command is given.
379
+ #
380
+ def only_if(command = nil, opts = {}, &block)
381
+ if command || block_given?
382
+ @only_if << Conditional.only_if(self, command, opts, &block)
383
+ end
384
+ @only_if
385
+ end
386
+
387
+ #
388
+ # A command or block that indicates whether to actually run this resource.
389
+ # The command or block is run just before the action actually executes, and
390
+ # the action will be skipped if the block returns true.
391
+ #
392
+ # If a block is specified, it must return `false` in order for the Resource
393
+ # to be executed.
394
+ #
395
+ # If a command is specified, the resource's #guard_interpreter will run the
396
+ # command and interpret the results according to `opts`. For example, the
397
+ # default `execute` resource will be treated as `false` if the command
398
+ # returns a non-zero exit code, and `true` if it returns 0. Thus, in the
399
+ # default case:
400
+ #
401
+ # - `not_if "your command"` will perform the action only if `your command`
402
+ # returns a non-zero code.
403
+ # - `only_if "your command", valid_exit_codes: [ 1, 2, 3 ]` will perform the
404
+ # action only if `your command` returns something other than 1, 2, or 3.
405
+ #
406
+ # @param command [String] A string to execute.
407
+ # @param opts [Hash] Options control the execution of the command
408
+ # @param block [Proc] A ruby block to run. Ignored if a command is given.
409
+ #
410
+ def not_if(command = nil, opts = {}, &block)
411
+ if command || block_given?
412
+ @not_if << Conditional.not_if(self, command, opts, &block)
413
+ end
414
+ @not_if
415
+ end
416
+
417
+ #
418
+ # The number of times to retry this resource if it fails by throwing an
419
+ # exception while running an action. Default: 0
420
+ #
421
+ # When the retries have run out, the Resource will throw the last
422
+ # exception.
423
+ #
424
+ # @param arg [Integer] The number of retries.
425
+ # @return [Integer] The number of retries.
426
+ #
427
+ property :retries, Integer, default: 0, desired_state: false
428
+
429
+ #
430
+ # The number of seconds to wait between retries. Default: 2.
431
+ #
432
+ # @param arg [Integer] The number of seconds to wait between retries.
433
+ # @return [Integer] The number of seconds to wait between retries.
434
+ #
435
+ property :retry_delay, Integer, default: 2, desired_state: false
436
+
437
+ #
438
+ # Whether to treat this resource's data as sensitive. If set, no resource
439
+ # data will be displayed in log output.
440
+ #
441
+ # @param arg [Boolean] Whether this resource is sensitive or not.
442
+ # @return [Boolean] Whether this resource is sensitive or not.
443
+ #
444
+ property :sensitive, [ TrueClass, FalseClass ], default: false, desired_state: false
445
+
446
+ #
447
+ # The time it took (in seconds) to run the most recently-run action. Not
448
+ # cumulative across actions. This is set to 0 as soon as a new action starts
449
+ # running, and set to the elapsed time at the end of the action.
450
+ #
451
+ # @return [Integer] The time (in seconds) it took to process the most recent
452
+ # action. Not cumulative.
453
+ #
454
+ attr_reader :elapsed_time
455
+
456
+ #
457
+ # @return [Boolean] If the resource was executed by the runner
458
+ #
459
+ attr_accessor :executed_by_runner
460
+
461
+ #
462
+ # The guard interpreter that will be used to process `only_if` and `not_if`
463
+ # statements. If left unset, the #default_guard_interpreter will be used.
464
+ #
465
+ # Must be a resource class like `Chef::Resource::Execute`, or
466
+ # a corresponding to the name of a resource. The resource must descend from
467
+ # `Chef::Resource::Execute`.
468
+ #
469
+ # TODO this needs to be coerced on input so that retrieval is consistent.
470
+ #
471
+ # @param arg [Class, Symbol, String] The Guard interpreter resource class/
472
+ # symbol/name.
473
+ # @return [Class, Symbol, String] The Guard interpreter resource.
474
+ #
475
+ def guard_interpreter(arg = nil)
476
+ if arg.nil?
477
+ @guard_interpreter || @default_guard_interpreter
478
+ else
479
+ set_or_return(:guard_interpreter, arg, kind_of: Symbol)
480
+ end
481
+ end
482
+
483
+ #
484
+ # Get the value of the state attributes in this resource as a hash.
485
+ #
486
+ # Does not include properties that are not set (unless they are identity
487
+ # properties).
488
+ #
489
+ # @return [Hash{Symbol => Object}] A Hash of attribute => value for the
490
+ # Resource class's `state_attrs`.
491
+ #
492
+ def state_for_resource_reporter
493
+ state = {}
494
+ state_properties = self.class.state_properties
495
+ state_properties.each do |property|
496
+ if property.identity? || property.is_set?(self)
497
+ state[property.name] = property.sensitive? ? "*sensitive value suppressed*" : send(property.name)
498
+ end
499
+ end
500
+ state
501
+ end
502
+
503
+ #
504
+ # The value of the identity of this resource.
505
+ #
506
+ # - If there are no identity properties on the resource, `name` is returned.
507
+ # - If there is exactly one identity property on the resource, it is returned.
508
+ # - If there are more than one, they are returned in a hash.
509
+ #
510
+ # @return [Object,Hash<Symbol,Object>] The identity of this resource.
511
+ #
512
+ def identity
513
+ result = {}
514
+ identity_properties = self.class.identity_properties
515
+ identity_properties.each do |property|
516
+ result[property.name] = send(property.name)
517
+ end
518
+ return result.values.first if identity_properties.size == 1
519
+ result
520
+ end
521
+
522
+ #
523
+ # Whether to ignore failures. If set to `true`, and this resource when an
524
+ # action is run, the resource will be marked as failed but no exception will
525
+ # be thrown (and no error will be output). Defaults to `false`. If set to
526
+ # `:quiet` or `'quiet'`, the normal error trace will be suppressed.
527
+ #
528
+ # TODO ignore_failure and retries seem to be mutually exclusive; I doubt
529
+ # that was intended.
530
+ #
531
+ # @param arg [Boolean, String, Symbol] Whether to ignore failures.
532
+ # @return Whether this resource will ignore failures.
533
+ #
534
+ property :ignore_failure, [ true, false, :quiet, "quiet" ], default: false, desired_state: false
535
+
536
+ #
537
+ # Make this resource into an exact (shallow) copy of the other resource.
538
+ #
539
+ # @param resource [Chef::Resource] The resource to copy from.
540
+ #
541
+ def load_from(resource)
542
+ resource.instance_variables.each do |iv|
543
+ unless iv == :@source_line || iv == :@action || iv == :@not_if || iv == :@only_if
544
+ instance_variable_set(iv, resource.instance_variable_get(iv))
545
+ end
546
+ end
547
+ end
548
+
549
+ #
550
+ # Runs the given action on this resource, immediately.
551
+ #
552
+ # @param action The action to run (e.g. `:create`)
553
+ # @param notification_type The notification type that triggered this (if any)
554
+ # @param notifying_resource The resource that triggered this notification (if any)
555
+ #
556
+ # @raise Any error that occurs during the actual action.
557
+ #
558
+ def run_action(action, notification_type = nil, notifying_resource = nil)
559
+ # reset state in case of multiple actions on the same resource.
560
+ @elapsed_time = 0
561
+ start_time = Time.now
562
+ events.resource_action_start(self, action, notification_type, notifying_resource)
563
+ # Try to resolve lazy/forward references in notifications again to handle
564
+ # the case where the resource was defined lazily (ie. in a ruby_block)
565
+ resolve_notification_references
566
+ validate_action(action)
567
+
568
+ if Chef::Config[:verbose_logging] || logger.level == :debug
569
+ # This can be noisy
570
+ logger.info("Processing #{self} action #{action} (#{defined_at})")
571
+ end
572
+
573
+ # ensure that we don't leave @updated_by_last_action set to true
574
+ # on accident
575
+ updated_by_last_action(false)
576
+
577
+ # Don't modify @retries directly and keep it intact, so that the
578
+ # recipe_snippet from ResourceFailureInspector can print the value
579
+ # that was set in the resource block initially.
580
+ remaining_retries = retries
581
+
582
+ begin
583
+ return if should_skip?(action)
584
+ provider_for_action(action).run_action
585
+ rescue StandardError => e
586
+ if ignore_failure
587
+ logger.error("#{custom_exception_message(e)}; ignore_failure is set, continuing")
588
+ events.resource_failed(self, action, e)
589
+ elsif remaining_retries > 0
590
+ events.resource_failed_retriable(self, action, remaining_retries, e)
591
+ remaining_retries -= 1
592
+ logger.info("Retrying execution of #{self}, #{remaining_retries} attempt#{"s" if remaining_retries > 1} left")
593
+ sleep retry_delay
594
+ retry
595
+ else
596
+ events.resource_failed(self, action, e)
597
+ raise customize_exception(e)
598
+ end
599
+ end
600
+ ensure
601
+ @elapsed_time = Time.now - start_time
602
+ # Reporting endpoint doesn't accept a negative resource duration so set it to 0.
603
+ # A negative value can occur when a resource changes the system time backwards
604
+ @elapsed_time = 0 if @elapsed_time < 0
605
+ events.resource_completed(self)
606
+ end
607
+
608
+ #
609
+ # If we are currently initializing the resource, this will be true.
610
+ #
611
+ # Do NOT use this. It may be removed. It is for internal purposes only.
612
+ # @api private
613
+ attr_reader :resource_initializing
614
+ def resource_initializing=(value)
615
+ if value
616
+ @resource_initializing = true
617
+ else
618
+ remove_instance_variable(:@resource_initializing)
619
+ end
620
+ end
621
+
622
+ #
623
+ # Generic Ruby and Data Structure Stuff (for user)
624
+ #
625
+
626
+ def to_s
627
+ "#{resource_name}[#{name}]"
628
+ end
629
+
630
+ def to_text
631
+ return "suppressed sensitive resource output" if sensitive
632
+ text = "# Declared in #{@source_line}\n\n"
633
+ text << "#{resource_name}(\"#{name}\") do\n"
634
+
635
+ all_props = {}
636
+ self.class.state_properties.map do |p|
637
+ begin
638
+ all_props[p.name.to_s] = p.sensitive? ? '"*sensitive value suppressed*"' : value_to_text(p.get(self))
639
+ rescue Chef::Exceptions::ValidationFailed
640
+ # This space left intentionally blank, the property was probably required or had an invalid default.
641
+ end
642
+ end
643
+
644
+ ivars = instance_variables.map { |ivar| ivar.to_sym } - HIDDEN_IVARS
645
+ ivars.each do |ivar|
646
+ iv = ivar.to_s.sub(/^@/, "")
647
+ if all_props.keys.include?(iv)
648
+ text << " #{iv} #{all_props[iv]}\n"
649
+ elsif (value = instance_variable_get(ivar)) && !(value.respond_to?(:empty?) && value.empty?)
650
+ text << " #{iv} #{value_to_text(value)}\n"
651
+ end
652
+ end
653
+
654
+ [@not_if, @only_if].flatten.each do |conditional|
655
+ text << " #{conditional.to_text}\n"
656
+ end
657
+ text << "end\n"
658
+ end
659
+
660
+ def value_to_text(value)
661
+ value.respond_to?(:to_text) ? value.to_text : value.inspect
662
+ end
663
+
664
+ def inspect
665
+ ivars = instance_variables.map { |ivar| ivar.to_sym } - FORBIDDEN_IVARS
666
+ ivars.inject("<#{self}") do |str, ivar|
667
+ str << " #{ivar}: #{instance_variable_get(ivar).inspect}"
668
+ end << ">"
669
+ end
670
+
671
+ # as_json does most of the to_json heavy lifted. It exists here in case activesupport
672
+ # is loaded. activesupport will call as_json and skip over to_json. This ensure
673
+ # json is encoded as expected
674
+ def as_json(*a)
675
+ safe_ivars = instance_variables.map { |ivar| ivar.to_sym } - FORBIDDEN_IVARS
676
+ instance_vars = Hash.new
677
+ safe_ivars.each do |iv|
678
+ instance_vars[iv.to_s.sub(/^@/, "")] = instance_variable_get(iv)
679
+ end
680
+ {
681
+ "json_class" => self.class.name,
682
+ "instance_vars" => instance_vars,
683
+ }
684
+ end
685
+
686
+ # Serialize this object as a hash
687
+ def to_json(*a)
688
+ results = as_json
689
+ Chef::JSONCompat.to_json(results, *a)
690
+ end
691
+
692
+ def to_h
693
+ # Grab all current state, then any other ivars (backcompat)
694
+ result = {}
695
+ self.class.state_properties.each do |p|
696
+ result[p.name] = p.get(self)
697
+ end
698
+ safe_ivars = instance_variables.map { |ivar| ivar.to_sym } - FORBIDDEN_IVARS
699
+ safe_ivars.each do |iv|
700
+ key = iv.to_s.sub(/^@/, "").to_sym
701
+ next if result.key?(key)
702
+ result[key] = instance_variable_get(iv)
703
+ end
704
+ result
705
+ end
706
+
707
+ alias_method :to_hash, :to_h
708
+
709
+ def self.from_hash(o)
710
+ resource = new(o["instance_vars"]["@name"])
711
+ o["instance_vars"].each do |k, v|
712
+ resource.instance_variable_set("@#{k}".to_sym, v)
713
+ end
714
+ resource
715
+ end
716
+
717
+ def self.json_create(o)
718
+ from_hash(o)
719
+ end
720
+
721
+ def self.from_json(j)
722
+ from_hash(Chef::JSONCompat.parse(j))
723
+ end
724
+
725
+ #
726
+ # Resource Definition Interface (for resource developers)
727
+ #
728
+
729
+ include Chef::Mixin::Deprecation
730
+
731
+ #
732
+ # The provider class for this resource.
733
+ #
734
+ # If `action :x do ... end` has been declared on this resource or its
735
+ # superclasses, this will return the `action_class`.
736
+ #
737
+ # If this is not set, `provider_for_action` will dynamically determine the
738
+ # provider.
739
+ #
740
+ # @param arg [String, Symbol, Class] Sets the provider class for this resource.
741
+ # If passed a String or Symbol, e.g. `:file` or `"file"`, looks up the
742
+ # provider based on the name.
743
+ #
744
+ # @return The provider class for this resource.
745
+ #
746
+ # @see Chef::Resource.action_class
747
+ #
748
+ def provider(arg = nil)
749
+ klass = if arg.kind_of?(String) || arg.kind_of?(Symbol)
750
+ lookup_provider_constant(arg)
751
+ else
752
+ arg
753
+ end
754
+ set_or_return(:provider, klass, kind_of: [ Class ])
755
+ end
756
+
757
+ def provider=(arg)
758
+ provider(arg)
759
+ end
760
+
761
+ #
762
+ # Set or return the list of "state properties" implemented by the Resource
763
+ # subclass.
764
+ #
765
+ # Equivalent to calling #state_properties and getting `state_properties.keys`.
766
+ #
767
+ # @deprecated Use state_properties.keys instead. Note that when you declare
768
+ # properties with `property`: properties are added to state_properties by
769
+ # default, and can be turned off with `desired_state: false`
770
+ #
771
+ # ```ruby
772
+ # property :x # part of desired state
773
+ # property :y, desired_state: false # not part of desired state
774
+ # ```
775
+ #
776
+ # @param names [Array<Symbol>] A list of property names to set as desired
777
+ # state.
778
+ #
779
+ # @return [Array<Symbol>] All property names with desired state.
780
+ #
781
+ def self.state_attrs(*names)
782
+ state_properties(*names).map { |property| property.name }
783
+ end
784
+
785
+ #
786
+ # Set the identity of this resource to a particular property.
787
+ #
788
+ # This drives #identity, which returns data that uniquely refers to a given
789
+ # resource on the given node (in such a way that it can be correlated
790
+ # across Chef runs).
791
+ #
792
+ # This method is unnecessary when declaring properties with `property`;
793
+ # properties can be added to identity during declaration with
794
+ # `identity: true`.
795
+ #
796
+ # ```ruby
797
+ # property :x, identity: true # part of identity
798
+ # property :y # not part of identity
799
+ # ```
800
+ #
801
+ # @param name [Symbol] A list of property names to set as the identity.
802
+ #
803
+ # @return [Symbol] The identity property if there is only one; or `nil` if
804
+ # there are more than one.
805
+ #
806
+ # @raise [ArgumentError] If no arguments are passed and the resource has
807
+ # more than one identity property.
808
+ #
809
+ def self.identity_property(name = nil)
810
+ result = identity_properties(*Array(name))
811
+ if result.size > 1
812
+ raise Chef::Exceptions::MultipleIdentityError, "identity_property cannot be called on an object with more than one identity property (#{result.map { |r| r.name }.join(", ")})."
813
+ end
814
+ result.first
815
+ end
816
+
817
+ #
818
+ # Set a property as the "identity attribute" for this resource.
819
+ #
820
+ # Identical to calling #identity_property.first.key.
821
+ #
822
+ # @param name [Symbol] The name of the property to set.
823
+ #
824
+ # @return [Symbol]
825
+ #
826
+ # @deprecated `identity_property` should be used instead.
827
+ #
828
+ # @raise [ArgumentError] If no arguments are passed and the resource has
829
+ # more than one identity property.
830
+ #
831
+ def self.identity_attr(name = nil)
832
+ property = identity_property(name)
833
+ return nil if !property
834
+ property.name
835
+ end
836
+
837
+ #
838
+ # The guard interpreter that will be used to process `only_if` and `not_if`
839
+ # statements by default. If left unset, or set to `:default`, the guard
840
+ # interpreter used will be Chef::GuardInterpreter::DefaultGuardInterpreter.
841
+ #
842
+ # Must be a resource class like `Chef::Resource::Execute`, or
843
+ # a corresponding to the name of a resource. The resource must descend from
844
+ # `Chef::Resource::Execute`.
845
+ #
846
+ # TODO this needs to be coerced on input so that retrieval is consistent.
847
+ #
848
+ # @return [Class, Symbol, String] the default Guard interpreter resource.
849
+ #
850
+ attr_reader :default_guard_interpreter
851
+
852
+ #
853
+ # The list of actions this Resource is allowed to have. Setting `action`
854
+ # will fail unless it is in this list. Default: [ :nothing ]
855
+ #
856
+ # @return [Array<Symbol>] The list of actions this Resource is allowed to
857
+ # have.
858
+ #
859
+ attr_writer :allowed_actions
860
+ def allowed_actions(value = NOT_PASSED)
861
+ if value != NOT_PASSED
862
+ self.allowed_actions = value
863
+ end
864
+ @allowed_actions
865
+ end
866
+
867
+ #
868
+ # Whether or not this resource was updated during an action. If multiple
869
+ # actions are set on the resource, this will be `true` if *any* action
870
+ # caused an update to happen.
871
+ #
872
+ # @return [Boolean] Whether the resource was updated during an action.
873
+ #
874
+ attr_reader :updated
875
+
876
+ #
877
+ # Whether or not this resource was updated during an action. If multiple
878
+ # actions are set on the resource, this will be `true` if *any* action
879
+ # caused an update to happen.
880
+ #
881
+ # @return [Boolean] Whether the resource was updated during an action.
882
+ #
883
+ def updated?
884
+ updated
885
+ end
886
+
887
+ #
888
+ # Whether or not this resource was updated during the most recent action.
889
+ # This is set to `false` at the beginning of each action.
890
+ #
891
+ # @param true_or_false [Boolean] Whether the resource was updated during the
892
+ # current / most recent action.
893
+ # @return [Boolean] Whether the resource was updated during the most recent action.
894
+ #
895
+ def updated_by_last_action(true_or_false)
896
+ @updated ||= true_or_false
897
+ @updated_by_last_action = true_or_false
898
+ end
899
+
900
+ #
901
+ # Whether or not this resource was updated during the most recent action.
902
+ # This is set to `false` at the beginning of each action.
903
+ #
904
+ # @return [Boolean] Whether the resource was updated during the most recent action.
905
+ #
906
+ def updated_by_last_action?
907
+ @updated_by_last_action
908
+ end
909
+
910
+ #
911
+ # The display name of this resource type, for printing purposes.
912
+ #
913
+ # Will be used to print out the resource in messages, e.g. resource_name[name]
914
+ #
915
+ # @return [Symbol] The name of this resource type (e.g. `:execute`).
916
+ #
917
+ def resource_name
918
+ @resource_name || self.class.resource_name
919
+ end
920
+
921
+ #
922
+ # A hook called after a resource is created. Meant to be overriden by
923
+ # subclasses.
924
+ #
925
+ def after_created
926
+ nil
927
+ end
928
+
929
+ #
930
+ # The display name of this resource type, for printing purposes.
931
+ #
932
+ # This also automatically calls "provides" to provide DSL with the given
933
+ # name.
934
+ #
935
+ # resource_name defaults to your class name.
936
+ #
937
+ # Call `resource_name nil` to remove the resource name (and any
938
+ # corresponding DSL).
939
+ #
940
+ # @param value [Symbol] The desired name of this resource type (e.g.
941
+ # `execute`), or `nil` if this class is abstract and has no resource_name.
942
+ #
943
+ # @return [Symbol] The name of this resource type (e.g. `:execute`).
944
+ #
945
+ def self.resource_name(name = NOT_PASSED)
946
+ # Setter
947
+ if name != NOT_PASSED
948
+ remove_canonical_dsl
949
+
950
+ # Set the resource_name and call provides
951
+ if name
952
+ name = name.to_sym
953
+ # If our class is not already providing this name, provide it.
954
+ if !Chef::ResourceResolver.includes_handler?(name, self)
955
+ provides name, canonical: true
956
+ end
957
+ @resource_name = name
958
+ else
959
+ @resource_name = nil
960
+ end
961
+ end
962
+ @resource_name
963
+ end
964
+
965
+ def self.resource_name=(name)
966
+ resource_name(name)
967
+ end
968
+
969
+ #
970
+ # Use the class name as the resource name.
971
+ #
972
+ # Munges the last part of the class name from camel case to snake case,
973
+ # and sets the resource_name to that:
974
+ #
975
+ # A::B::BlahDBlah -> blah_d_blah
976
+ #
977
+ def self.use_automatic_resource_name
978
+ automatic_name = convert_to_snake_case(name.split("::")[-1])
979
+ resource_name automatic_name
980
+ end
981
+
982
+ #
983
+ # The list of allowed actions for the resource.
984
+ #
985
+ # @param actions [Array<Symbol>] The list of actions to add to allowed_actions.
986
+ #
987
+ # @return [Array<Symbol>] The list of actions, as symbols.
988
+ #
989
+ def self.allowed_actions(*actions)
990
+ @allowed_actions ||=
991
+ if superclass.respond_to?(:allowed_actions)
992
+ superclass.allowed_actions.dup
993
+ else
994
+ [ :nothing ]
995
+ end
996
+ @allowed_actions |= actions.flatten
997
+ end
998
+
999
+ def self.allowed_actions=(value)
1000
+ @allowed_actions = value.uniq
1001
+ end
1002
+
1003
+ #
1004
+ # The action that will be run if no other action is specified.
1005
+ #
1006
+ # Setting default_action will automatially add the action to
1007
+ # allowed_actions, if it isn't already there.
1008
+ #
1009
+ # Defaults to [:nothing].
1010
+ #
1011
+ # @param action_name [Symbol,Array<Symbol>] The default action (or series
1012
+ # of actions) to use.
1013
+ #
1014
+ # @return [Array<Symbol>] The default actions for the resource.
1015
+ #
1016
+ def self.default_action(action_name = NOT_PASSED)
1017
+ unless action_name.equal?(NOT_PASSED)
1018
+ @default_action = Array(action_name).map(&:to_sym)
1019
+ self.allowed_actions |= @default_action
1020
+ end
1021
+
1022
+ if @default_action
1023
+ @default_action
1024
+ elsif superclass.respond_to?(:default_action)
1025
+ superclass.default_action
1026
+ else
1027
+ [:nothing]
1028
+ end
1029
+ end
1030
+
1031
+ def self.default_action=(action_name)
1032
+ default_action action_name
1033
+ end
1034
+
1035
+ #
1036
+ # Define an action on this resource.
1037
+ #
1038
+ # The action is defined as a *recipe* block that will be compiled and then
1039
+ # converged when the action is taken (when Resource is converged). The recipe
1040
+ # has access to the resource's attributes and methods, as well as the Chef
1041
+ # recipe DSL.
1042
+ #
1043
+ # Resources in the action recipe may notify and subscribe to other resources
1044
+ # within the action recipe, but cannot notify or subscribe to resources
1045
+ # in the main Chef run.
1046
+ #
1047
+ # Resource actions are *inheritable*: if resource A defines `action :create`
1048
+ # and B is a subclass of A, B gets all of A's actions. Additionally,
1049
+ # resource B can define `action :create` and call `super()` to invoke A's
1050
+ # action code.
1051
+ #
1052
+ # The first action defined (besides `:nothing`) will become the default
1053
+ # action for the resource.
1054
+ #
1055
+ # @param name [Symbol] The action name to define.
1056
+ # @param recipe_block The recipe to run when the action is taken. This block
1057
+ # takes no parameters, and will be evaluated in a new context containing:
1058
+ #
1059
+ # - The resource's public and protected methods (including attributes)
1060
+ # - The Chef Recipe DSL (file, etc.)
1061
+ # - super() referring to the parent version of the action (if any)
1062
+ #
1063
+ # @return The Action class implementing the action
1064
+ #
1065
+ def self.action(action, &recipe_block)
1066
+ action = action.to_sym
1067
+ declare_action_class
1068
+ action_class.action(action, &recipe_block)
1069
+ self.allowed_actions += [ action ]
1070
+ default_action action if Array(default_action) == [:nothing]
1071
+ end
1072
+
1073
+ #
1074
+ # Define a method to load up this resource's properties with the current
1075
+ # actual values.
1076
+ #
1077
+ # @param load_block The block to load. Will be run in the context of a newly
1078
+ # created resource with its identity values filled in.
1079
+ #
1080
+ def self.load_current_value(&load_block)
1081
+ define_method(:load_current_value!, &load_block)
1082
+ end
1083
+
1084
+ #
1085
+ # Call this in `load_current_value` to indicate that the value does not
1086
+ # exist and that `current_resource` should therefore be `nil`.
1087
+ #
1088
+ # @raise Chef::Exceptions::CurrentValueDoesNotExist
1089
+ #
1090
+ def current_value_does_not_exist!
1091
+ raise Chef::Exceptions::CurrentValueDoesNotExist
1092
+ end
1093
+
1094
+ #
1095
+ # Get the current actual value of this resource.
1096
+ #
1097
+ # This does not cache--a new value will be returned each time.
1098
+ #
1099
+ # @return A new copy of the resource, with values filled in from the actual
1100
+ # current value.
1101
+ #
1102
+ def current_value
1103
+ provider = provider_for_action(Array(action).first)
1104
+ if provider.whyrun_mode? && !provider.whyrun_supported?
1105
+ raise "Cannot retrieve #{self.class.current_resource} in why-run mode: #{provider} does not support why-run"
1106
+ end
1107
+ provider.load_current_resource
1108
+ provider.current_resource
1109
+ end
1110
+
1111
+ #
1112
+ # The action class is a `Chef::Provider` which is created at Resource
1113
+ # class evaluation time when the Custom Resource is being constructed.
1114
+ #
1115
+ # This happens the first time the ruby parser hits an `action` or an
1116
+ # `action_class` method, the presence of either indiates that this is
1117
+ # going to be a Chef-12.5 custom resource. If we never see one of these
1118
+ # directives then we are constructing an old-style Resource+Provider or
1119
+ # LWRP or whatevs.
1120
+ #
1121
+ # If a block is passed, the action_class is always created and the block is
1122
+ # run inside it.
1123
+ #
1124
+ def self.action_class(&block)
1125
+ @action_class ||= declare_action_class
1126
+ @action_class.class_eval(&block) if block
1127
+ @action_class
1128
+ end
1129
+
1130
+ # Returns true or false based on if the resource is a custom resource. The
1131
+ # top-level Chef::Resource is not a chef resource. This value is inherited.
1132
+ #
1133
+ # @return [Boolean] if the resource is a custom_resource
1134
+ def self.custom_resource?
1135
+ false
1136
+ end
1137
+
1138
+ # This sets the resource to being a custom resource, and does so in a way
1139
+ # that automatically inherits to all subclasses via defining a method on
1140
+ # the class (class variables and class instance variables don't have the
1141
+ # correct semantics here, this is a poor man's activesupport class_attribute)
1142
+ #
1143
+ # @api private
1144
+ def self.is_custom_resource!
1145
+ define_singleton_method :custom_resource? do
1146
+ true
1147
+ end
1148
+ end
1149
+
1150
+ #
1151
+ # Ensure the action class actually gets created. This is called
1152
+ # when the user does `action :x do ... end`.
1153
+ #
1154
+ # @api private
1155
+ def self.declare_action_class
1156
+ @action_class ||=
1157
+ begin
1158
+ is_custom_resource!
1159
+ base_provider =
1160
+ if superclass.custom_resource?
1161
+ superclass.action_class
1162
+ else
1163
+ ActionClass
1164
+ end
1165
+
1166
+ resource_class = self
1167
+ Class.new(base_provider) do
1168
+ self.resource_class = resource_class
1169
+ end
1170
+ end
1171
+ end
1172
+
1173
+ # Set or return if this resource is in preview mode.
1174
+ #
1175
+ # This only has value in the resource_inspector to mark a resource as being new-to-chef-core.
1176
+ # Its meaning is probably more equivalent to "experimental" in that the API might change even
1177
+ # in minor versions due to bugfixing and is NOT considered "stable" yet.
1178
+ #
1179
+ # @param value [nil, Boolean] If nil, get the current value. If not nil, set
1180
+ # the value of the flag.
1181
+ # @return [Boolean]
1182
+ def self.preview_resource(value = nil)
1183
+ @preview_resource = false unless defined?(@preview_resource)
1184
+ @preview_resource = value unless value.nil?
1185
+ @preview_resource
1186
+ end
1187
+
1188
+ #
1189
+ # Internal Resource Interface (for Chef)
1190
+ #
1191
+
1192
+ # FORBIDDEN_IVARS do not show up when the resource is converted to JSON (ie. hidden from data_collector and sending to the chef server via #to_json/to_h/as_json/inspect)
1193
+ FORBIDDEN_IVARS = [:@run_context, :@logger, :@not_if, :@only_if, :@enclosing_provider, :@description, :@introduced, :@examples, :@validation_message, :@deprecated, :@default_description, :@skip_docs, :@executed_by_runner].freeze
1194
+ # HIDDEN_IVARS do not show up when the resource is displayed to the user as text (ie. in the error inspector output via #to_text)
1195
+ HIDDEN_IVARS = [:@allowed_actions, :@resource_name, :@source_line, :@run_context, :@logger, :@name, :@not_if, :@only_if, :@elapsed_time, :@enclosing_provider, :@description, :@introduced, :@examples, :@validation_message, :@deprecated, :@default_description, :@skip_docs, :@executed_by_runner].freeze
1196
+
1197
+ include Chef::Mixin::ConvertToClassName
1198
+ extend Chef::Mixin::ConvertToClassName
1199
+
1200
+ # XXX: this is required for definition params inside of the scope of a
1201
+ # subresource to work correctly.
1202
+ attr_accessor :params
1203
+
1204
+ # @return [Chef::RunContext] The run context for this Resource. This is
1205
+ # where the context for the current Chef run is stored, including the node
1206
+ # and the resource collection.
1207
+ attr_accessor :run_context
1208
+
1209
+ # @return [Mixlib::Log::Child] The logger for this resources. This is a child
1210
+ # of the run context's logger, if one exists.
1211
+ attr_reader :logger
1212
+
1213
+ # @return [String] The cookbook this resource was declared in.
1214
+ attr_accessor :cookbook_name
1215
+
1216
+ # @return [String] The recipe this resource was declared in.
1217
+ attr_accessor :recipe_name
1218
+
1219
+ # @return [Chef::Provider] The provider this resource was declared in (if
1220
+ # it was declared in an LWRP). When you call methods that do not exist
1221
+ # on this Resource, Chef will try to call the method on the provider
1222
+ # as well before giving up.
1223
+ attr_accessor :enclosing_provider
1224
+
1225
+ # @return [String] The source line where this resource was declared.
1226
+ # Expected to come from caller() or a stack trace, it usually follows one
1227
+ # of these formats:
1228
+ # /some/path/to/file.rb:80:in `wombat_tears'
1229
+ # C:/some/path/to/file.rb:80 in 1`wombat_tears'
1230
+ attr_accessor :source_line
1231
+
1232
+ # @return [String] The actual name that was used to create this resource.
1233
+ # Sometimes, when you say something like `package 'blah'`, the system will
1234
+ # create a different resource (i.e. `YumPackage`). When this happens, the
1235
+ # user will expect to see the thing they wrote, not the type that was
1236
+ # returned. May be `nil`, in which case callers should read #resource_name.
1237
+ # See #declared_key.
1238
+ attr_accessor :declared_type
1239
+
1240
+ #
1241
+ # Iterates over all immediate and delayed notifications, calling
1242
+ # resolve_resource_reference on each in turn, causing them to
1243
+ # resolve lazy/forward references.
1244
+ def resolve_notification_references
1245
+ run_context.before_notifications(self).each do |n|
1246
+ n.resolve_resource_reference(run_context.resource_collection)
1247
+ end
1248
+ run_context.immediate_notifications(self).each do |n|
1249
+ n.resolve_resource_reference(run_context.resource_collection)
1250
+ end
1251
+ run_context.delayed_notifications(self).each do |n|
1252
+ n.resolve_resource_reference(run_context.resource_collection)
1253
+ end
1254
+ end
1255
+
1256
+ # Helper for #notifies
1257
+ def notifies_before(action, resource_spec)
1258
+ run_context.notifies_before(Notification.new(resource_spec, action, self))
1259
+ end
1260
+
1261
+ # Helper for #notifies
1262
+ def notifies_immediately(action, resource_spec)
1263
+ run_context.notifies_immediately(Notification.new(resource_spec, action, self))
1264
+ end
1265
+
1266
+ # Helper for #notifies
1267
+ def notifies_delayed(action, resource_spec)
1268
+ run_context.notifies_delayed(Notification.new(resource_spec, action, self))
1269
+ end
1270
+
1271
+ class << self
1272
+ # back-compat
1273
+ # NOTE: that we do not support unregistering classes as descendants like
1274
+ # we used to for LWRP unloading because that was horrible and removed in
1275
+ # Chef-12.
1276
+ # @deprecated
1277
+ # @api private
1278
+ alias :resource_classes :descendants
1279
+ # @deprecated
1280
+ # @api private
1281
+ alias :find_subclass_by_name :find_descendants_by_name
1282
+ end
1283
+
1284
+ # @deprecated
1285
+ # @api private
1286
+ # We memoize a sorted version of descendants so that resource lookups don't
1287
+ # have to sort all the things, all the time.
1288
+ # This was causing performance issues in test runs, and probably in real
1289
+ # life as well.
1290
+ @@sorted_descendants = nil
1291
+ def self.sorted_descendants
1292
+ @@sorted_descendants ||= descendants.sort_by { |x| x.to_s }
1293
+ end
1294
+
1295
+ def self.inherited(child)
1296
+ super
1297
+ @@sorted_descendants = nil
1298
+ # set resource_name automatically if it's not set
1299
+ if child.name && !child.resource_name
1300
+ if child.name =~ /^Chef::Resource::(\w+)$/
1301
+ child.resource_name(convert_to_snake_case($1))
1302
+ end
1303
+ end
1304
+ end
1305
+
1306
+ # If an unknown method is invoked, determine whether the enclosing Provider's
1307
+ # lexical scope can fulfill the request. E.g. This happens when the Resource's
1308
+ # block invokes new_resource.
1309
+ def method_missing(method_symbol, *args, &block)
1310
+ if enclosing_provider && enclosing_provider.respond_to?(method_symbol)
1311
+ enclosing_provider.send(method_symbol, *args, &block)
1312
+ else
1313
+ raise NoMethodError, "undefined method `#{method_symbol}' for #{self.class}"
1314
+ end
1315
+ end
1316
+
1317
+ #
1318
+ # This API can be used for backcompat to do:
1319
+ #
1320
+ # chef_version_for_provides "< 14.0" if defined?(:chef_version_for_provides)
1321
+ #
1322
+ # For core chef versions that do not support chef_version: in provides lines.
1323
+ #
1324
+ # Since resource_name calls provides the generally correct way of doing this is
1325
+ # to do `chef_version_for_provides` first, then `resource_name` and then
1326
+ # any additional options `provides` lines. Calling `resource_name` is somewhat
1327
+ # important to have the canonical_dsl removed or else that'll stick around
1328
+ # and chef_version won't get applied to it.
1329
+ #
1330
+ # Once we no longer care about supporting chef < 14.4 then we can deprecate
1331
+ # this API.
1332
+ #
1333
+ # @param arg [String] version constrant to match against (e.g. "> 14")
1334
+ #
1335
+ def self.chef_version_for_provides(constraint)
1336
+ @chef_version_for_provides = constraint
1337
+ end
1338
+
1339
+ #
1340
+ # Mark this resource as providing particular DSL.
1341
+ #
1342
+ # Resources have an automatic DSL based on their resource_name, equivalent to
1343
+ # `provides :resource_name` (providing the resource on all OS's). If you
1344
+ # declare a `provides` with the given resource_name, it *replaces* that
1345
+ # provides (so that you can provide your resource DSL only on certain OS's).
1346
+ #
1347
+ def self.provides(name, **options, &block)
1348
+ name = name.to_sym
1349
+
1350
+ # `provides :resource_name, os: 'linux'`) needs to remove the old
1351
+ # canonical DSL before adding the new one.
1352
+ if @resource_name && name == @resource_name
1353
+ remove_canonical_dsl
1354
+ end
1355
+
1356
+ if @chef_version_for_provides && !options.include?(:chef_version)
1357
+ options[:chef_version] = @chef_version_for_provides
1358
+ end
1359
+
1360
+ result = Chef.resource_handler_map.set(name, self, options, &block)
1361
+ Chef::DSL::Resources.add_resource_dsl(name)
1362
+ result
1363
+ end
1364
+
1365
+ def self.provides?(node, resource_name)
1366
+ Chef::ResourceResolver.new(node, resource_name).provided_by?(self)
1367
+ end
1368
+
1369
+ # Helper for #notifies
1370
+ def validate_resource_spec!(resource_spec)
1371
+ run_context.resource_collection.validate_lookup_spec!(resource_spec)
1372
+ end
1373
+
1374
+ # We usually want to store and reference resources by their declared type and not the actual type that
1375
+ # was looked up by the Resolver (IE, "package" becomes YumPackage class). If we have not been provided
1376
+ # the declared key we want to fall back on the old to_s key.
1377
+ def declared_key
1378
+ return to_s if declared_type.nil?
1379
+ "#{declared_type}[#{@name}]"
1380
+ end
1381
+
1382
+ def before_notifications
1383
+ run_context.before_notifications(self)
1384
+ end
1385
+
1386
+ def immediate_notifications
1387
+ run_context.immediate_notifications(self)
1388
+ end
1389
+
1390
+ def delayed_notifications
1391
+ run_context.delayed_notifications(self)
1392
+ end
1393
+
1394
+ def source_line_file
1395
+ if source_line
1396
+ source_line.match(/(.*):(\d+):?.*$/).to_a[1]
1397
+ else
1398
+ nil
1399
+ end
1400
+ end
1401
+
1402
+ def source_line_number
1403
+ if source_line
1404
+ source_line.match(/(.*):(\d+):?.*$/).to_a[2]
1405
+ else
1406
+ nil
1407
+ end
1408
+ end
1409
+
1410
+ def defined_at
1411
+ # The following regexp should match these two sourceline formats:
1412
+ # /some/path/to/file.rb:80:in `wombat_tears'
1413
+ # C:/some/path/to/file.rb:80 in 1`wombat_tears'
1414
+ # extracting the path to the source file and the line number.
1415
+ if cookbook_name && recipe_name && source_line
1416
+ "#{cookbook_name}::#{recipe_name} line #{source_line_number}"
1417
+ elsif source_line
1418
+ "#{source_line_file} line #{source_line_number}"
1419
+ else
1420
+ "dynamically defined"
1421
+ end
1422
+ end
1423
+
1424
+ def self.description(description = "NOT_PASSED")
1425
+ if description != "NOT_PASSED"
1426
+ @description = description
1427
+ end
1428
+ @description
1429
+ end
1430
+
1431
+ def self.introduced(introduced = "NOT_PASSED")
1432
+ if introduced != "NOT_PASSED"
1433
+ @introduced = introduced
1434
+ end
1435
+ @introduced
1436
+ end
1437
+
1438
+ def self.examples(examples = "NOT_PASSED")
1439
+ if examples != "NOT_PASSED"
1440
+ @examples = examples
1441
+ end
1442
+ @examples
1443
+ end
1444
+
1445
+ def self.deprecated(deprecated = "NOT_PASSED")
1446
+ if deprecated != "NOT_PASSED"
1447
+ @deprecated = true
1448
+ @deprecated_message = deprecated
1449
+ end
1450
+ @deprecated
1451
+ end
1452
+
1453
+ def self.skip_docs(skip_docs = "NOT_PASSED")
1454
+ if skip_docs != "NOT_PASSED"
1455
+ @skip_docs = skip_docs
1456
+ end
1457
+ @skip_docs
1458
+ end
1459
+
1460
+ def self.default_description(default_description = "NOT_PASSED")
1461
+ if default_description != "NOT_PASSED"
1462
+ @default_description = default_description
1463
+ end
1464
+ @default_description
1465
+ end
1466
+
1467
+ #
1468
+ # The cookbook in which this Resource was defined (if any).
1469
+ #
1470
+ # @return Chef::CookbookVersion The cookbook in which this Resource was defined.
1471
+ #
1472
+ def cookbook_version
1473
+ if cookbook_name
1474
+ run_context.cookbook_collection[cookbook_name]
1475
+ end
1476
+ end
1477
+
1478
+ def events
1479
+ run_context.events
1480
+ end
1481
+
1482
+ def validate_action(action)
1483
+ raise ArgumentError, "nil is not a valid action for resource #{self}" if action.nil?
1484
+ end
1485
+
1486
+ def provider_for_action(action)
1487
+ provider_class = Chef::ProviderResolver.new(node, self, action).resolve
1488
+ provider = provider_class.new(self, run_context)
1489
+ provider.action = action
1490
+ provider
1491
+ end
1492
+
1493
+ #
1494
+ # Preface an exception message with generic Resource information.
1495
+ #
1496
+ # @param e [StandardError] An exception with `e.message`
1497
+ # @return [String] An exception message customized with class name.
1498
+ #
1499
+ def custom_exception_message(e)
1500
+ "#{self} (#{defined_at}) had an error: #{e.class.name}: #{e.message}"
1501
+ end
1502
+
1503
+ def customize_exception(e)
1504
+ new_exception = e.exception(custom_exception_message(e))
1505
+ new_exception.set_backtrace(e.backtrace)
1506
+ new_exception
1507
+ end
1508
+
1509
+ # Evaluates not_if and only_if conditionals. Returns a falsey value if any
1510
+ # of the conditionals indicate that this resource should be skipped, i.e.,
1511
+ # if an only_if evaluates to false or a not_if evaluates to true.
1512
+ #
1513
+ # If this resource should be skipped, returns the first conditional that
1514
+ # "fails" its check. Subsequent conditionals are not evaluated, so in
1515
+ # general it's not a good idea to rely on side effects from not_if or
1516
+ # only_if commands/blocks being evaluated.
1517
+ #
1518
+ # Also skips conditional checking when the action is :nothing
1519
+ def should_skip?(action)
1520
+ conditional_action = ConditionalActionNotNothing.new(action)
1521
+
1522
+ conditionals = [ conditional_action ] + only_if + not_if
1523
+ conditionals.find do |conditional|
1524
+ if conditional.continue?
1525
+ false
1526
+ else
1527
+ events.resource_skipped(self, action, conditional)
1528
+ logger.debug("Skipping #{self} due to #{conditional.description}")
1529
+ true
1530
+ end
1531
+ end
1532
+ end
1533
+
1534
+ # Returns a resource based on a short_name and node
1535
+ #
1536
+ # ==== Parameters
1537
+ # short_name<Symbol>:: short_name of the resource (ie :directory)
1538
+ # node<Chef::Node>:: Node object to look up platform and version in
1539
+ #
1540
+ # === Returns
1541
+ # <Chef::Resource>:: returns the proper Chef::Resource class
1542
+ def self.resource_for_node(short_name, node)
1543
+ klass = Chef::ResourceResolver.resolve(short_name, node: node)
1544
+ raise Chef::Exceptions::NoSuchResourceType.new(short_name, node) if klass.nil?
1545
+ klass
1546
+ end
1547
+
1548
+ #
1549
+ # Returns the class with the given resource_name.
1550
+ #
1551
+ # NOTE: Chef::Resource.resource_matching_short_name(:package) returns
1552
+ # Chef::Resource::Package, while on rhel the API call
1553
+ # Chef::Resource.resource_for_node(:package, node) will return
1554
+ # Chef::Resource::YumPackage -- which is probably what you really
1555
+ # want. This API should most likely be removed or changed to call
1556
+ # resource_for_node.
1557
+ #
1558
+ # ==== Parameters
1559
+ # short_name<Symbol>:: short_name of the resource (ie :directory)
1560
+ #
1561
+ # === Returns
1562
+ # <Chef::Resource>:: returns the proper Chef::Resource class
1563
+ #
1564
+ def self.resource_matching_short_name(short_name)
1565
+ Chef::ResourceResolver.resolve(short_name, canonical: true)
1566
+ end
1567
+
1568
+ # @api private
1569
+ def lookup_provider_constant(name, action = :nothing)
1570
+ # XXX: "name" is probably a poor choice of name here, ideally this would be nil, but we need to
1571
+ # fix resources so that nil or empty names work (also solving the apt_update "doesn't matter one bit"
1572
+ # problem). WARNING: this string is not a public API and should not be referenced (e.g. in provides blocks)
1573
+ # and may change at any time. If you've found this comment you're also probably very lost and should maybe
1574
+ # consider using `declare_resource :whatever` instead of trying to set `provider :whatever` on a resource, or in some
1575
+ # other way reconsider what you're trying to do, since you're likely trying to force a bad design that we
1576
+ # can't/won't support.
1577
+ self.class.resource_for_node(name, node).new("name", run_context).provider_for_action(action).class
1578
+ end
1579
+
1580
+ def self.remove_canonical_dsl
1581
+ if @resource_name
1582
+ remaining = Chef.resource_handler_map.delete_canonical(@resource_name, self)
1583
+ if !remaining
1584
+ Chef::DSL::Resources.remove_resource_dsl(@resource_name)
1585
+ end
1586
+ end
1587
+ end
1588
+ end
1589
+ end
1590
+
1591
+ # Requiring things at the bottom breaks cycles
1592
+ require_relative "chef_class"