chef 14.0.190-universal-mingw32 → 14.0.202-universal-mingw32

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