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,207 +1,207 @@
1
- #
2
- # Author:: Lamont Granquist (<lamont@chef.io>)
3
- # Copyright:: Copyright 2014-2018, Chef Software Inc.
4
- # License:: Apache License, Version 2.0
5
- #
6
- # Licensed under the Apache License, Version 2.0 (the "License");
7
- # you may not use this file except in compliance with the License.
8
- # You may obtain a copy of the License at
9
- #
10
- # http://www.apache.org/licenses/LICENSE-2.0
11
- #
12
- # Unless required by applicable law or agreed to in writing, software
13
- # distributed under the License is distributed on an "AS IS" BASIS,
14
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- # See the License for the specific language governing permissions and
16
- # limitations under the License.
17
- #
18
-
19
- require "spec_helper"
20
- require "chef/node_map"
21
-
22
- class Foo; end
23
- class Bar; end
24
-
25
- describe Chef::NodeMap do
26
-
27
- let(:node_map) { Chef::NodeMap.new }
28
-
29
- let(:node) { Chef::Node.new }
30
-
31
- describe "with a bad filter name" do
32
- it "should raise an error" do
33
- expect { node_map.set(node, :thing, on_platform_family: "rhel") }.to raise_error(ArgumentError)
34
- end
35
- end
36
-
37
- describe "when no matchers are set at all" do
38
- before do
39
- node_map.set(:thing, :foo)
40
- end
41
-
42
- it "returns the value" do
43
- expect(node_map.get(node, :thing)).to eql(:foo)
44
- end
45
-
46
- it "returns nil for keys that do not exist" do
47
- expect(node_map.get(node, :other_thing)).to eql(nil)
48
- end
49
- end
50
-
51
- describe "filtering by os" do
52
- before do
53
- node_map.set(:thing, :foo, os: ["windows"])
54
- node_map.set(:thing, :bar, os: "linux")
55
- end
56
- it "returns the correct value for windows" do
57
- allow(node).to receive(:[]).with(:os).and_return("windows")
58
- expect(node_map.get(node, :thing)).to eql(:foo)
59
- end
60
- it "returns the correct value for linux" do
61
- allow(node).to receive(:[]).with(:os).and_return("linux")
62
- expect(node_map.get(node, :thing)).to eql(:bar)
63
- end
64
- it "returns nil for a non-matching os" do
65
- allow(node).to receive(:[]).with(:os).and_return("freebsd")
66
- expect(node_map.get(node, :thing)).to eql(nil)
67
- end
68
- end
69
-
70
- describe "rejecting an os" do
71
- before do
72
- node_map.set(:thing, :foo, os: "!windows")
73
- end
74
- it "returns nil for windows" do
75
- allow(node).to receive(:[]).with(:os).and_return("windows")
76
- expect(node_map.get(node, :thing)).to eql(nil)
77
- end
78
- it "returns the correct value for linux" do
79
- allow(node).to receive(:[]).with(:os).and_return("linux")
80
- expect(node_map.get(node, :thing)).to eql(:foo)
81
- end
82
- end
83
-
84
- describe "filtering by os and platform_family" do
85
- before do
86
- node_map.set(:thing, :bar, os: "linux", platform_family: "rhel")
87
- end
88
-
89
- it "returns the correct value when both match" do
90
- allow(node).to receive(:[]).with(:os).and_return("linux")
91
- allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
92
- expect(node_map.get(node, :thing)).to eql(:bar)
93
- end
94
-
95
- it "returns nil for a non-matching os" do
96
- allow(node).to receive(:[]).with(:os).and_return("freebsd")
97
- expect(node_map.get(node, :thing)).to eql(nil)
98
- end
99
-
100
- it "returns nil when the platform_family does not match" do
101
- allow(node).to receive(:[]).with(:os).and_return("linux")
102
- allow(node).to receive(:[]).with(:platform_family).and_return("debian")
103
- expect(node_map.get(node, :thing)).to eql(nil)
104
- end
105
- end
106
-
107
- describe "platform version checks" do
108
- before do
109
- node_map.set(:thing, :foo, platform_family: "rhel", platform_version: ">= 7")
110
- end
111
-
112
- it "handles non-x.y.z platform versions without throwing an exception" do
113
- allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
114
- allow(node).to receive(:[]).with(:platform_version).and_return("7.19.2.2F")
115
- expect(node_map.get(node, :thing)).to eql(:foo)
116
- end
117
-
118
- it "handles non-x.y.z platform versions without throwing an exception when the match fails" do
119
- allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
120
- allow(node).to receive(:[]).with(:platform_version).and_return("4.19.2.2F")
121
- expect(node_map.get(node, :thing)).to eql(nil)
122
- end
123
- end
124
-
125
- describe "ordering classes" do
126
- it "last writer wins when its reverse alphabetic order" do
127
- node_map.set(:thing, Foo)
128
- node_map.set(:thing, Bar)
129
- expect(node_map.get(node, :thing)).to eql(Bar)
130
- end
131
-
132
- it "last writer wins when its alphabetic order" do
133
- node_map.set(:thing, Bar)
134
- node_map.set(:thing, Foo)
135
- expect(node_map.get(node, :thing)).to eql(Foo)
136
- end
137
- end
138
-
139
- describe "deleting classes" do
140
- it "deletes a class and removes the mapping completely" do
141
- node_map.set(:thing, Bar)
142
- expect( node_map.delete_class(Bar) ).to eql({ :thing => [{ :klass => Bar }] })
143
- expect( node_map.get(node, :thing) ).to eql(nil)
144
- end
145
-
146
- it "deletes a class and leaves the mapping that still has an entry" do
147
- node_map.set(:thing, Bar)
148
- node_map.set(:thing, Foo)
149
- expect( node_map.delete_class(Bar) ).to eql({ :thing => [{ :klass => Bar }] })
150
- expect( node_map.get(node, :thing) ).to eql(Foo)
151
- end
152
-
153
- it "handles deleting classes from multiple keys" do
154
- node_map.set(:thing1, Bar)
155
- node_map.set(:thing2, Bar)
156
- node_map.set(:thing2, Foo)
157
- expect( node_map.delete_class(Bar) ).to eql({ :thing1 => [{ :klass => Bar }], :thing2 => [{ :klass => Bar }] })
158
- expect( node_map.get(node, :thing1) ).to eql(nil)
159
- expect( node_map.get(node, :thing2) ).to eql(Foo)
160
- end
161
- end
162
-
163
- describe "with a block doing platform_version checks" do
164
- before do
165
- node_map.set(:thing, :foo, platform_family: "rhel") do |node|
166
- node[:platform_version].to_i >= 7
167
- end
168
- end
169
-
170
- it "returns the value when the node matches" do
171
- allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
172
- allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
173
- expect(node_map.get(node, :thing)).to eql(:foo)
174
- end
175
-
176
- it "returns nil when the block does not match" do
177
- allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
178
- allow(node).to receive(:[]).with(:platform_version).and_return("6.4")
179
- expect(node_map.get(node, :thing)).to eql(nil)
180
- end
181
-
182
- it "returns nil when the platform_family filter does not match" do
183
- allow(node).to receive(:[]).with(:platform_family).and_return("debian")
184
- allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
185
- expect(node_map.get(node, :thing)).to eql(nil)
186
- end
187
-
188
- it "returns nil when both do not match" do
189
- allow(node).to receive(:[]).with(:platform_family).and_return("debian")
190
- allow(node).to receive(:[]).with(:platform_version).and_return("6.0")
191
- expect(node_map.get(node, :thing)).to eql(nil)
192
- end
193
-
194
- context "when there is a less specific definition" do
195
- before do
196
- node_map.set(:thing, :bar, platform_family: "rhel")
197
- end
198
-
199
- it "returns the value when the node matches" do
200
- allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
201
- allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
202
- expect(node_map.get(node, :thing)).to eql(:foo)
203
- end
204
- end
205
- end
206
-
207
- end
1
+ #
2
+ # Author:: Lamont Granquist (<lamont@chef.io>)
3
+ # Copyright:: Copyright 2014-2018, Chef Software Inc.
4
+ # License:: Apache License, Version 2.0
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+ #
18
+
19
+ require "spec_helper"
20
+ require "chef/node_map"
21
+
22
+ class Foo; end
23
+ class Bar; end
24
+
25
+ describe Chef::NodeMap do
26
+
27
+ let(:node_map) { Chef::NodeMap.new }
28
+
29
+ let(:node) { Chef::Node.new }
30
+
31
+ describe "with a bad filter name" do
32
+ it "should raise an error" do
33
+ expect { node_map.set(node, :thing, on_platform_family: "rhel") }.to raise_error(ArgumentError)
34
+ end
35
+ end
36
+
37
+ describe "when no matchers are set at all" do
38
+ before do
39
+ node_map.set(:thing, :foo)
40
+ end
41
+
42
+ it "returns the value" do
43
+ expect(node_map.get(node, :thing)).to eql(:foo)
44
+ end
45
+
46
+ it "returns nil for keys that do not exist" do
47
+ expect(node_map.get(node, :other_thing)).to eql(nil)
48
+ end
49
+ end
50
+
51
+ describe "filtering by os" do
52
+ before do
53
+ node_map.set(:thing, :foo, os: ["windows"])
54
+ node_map.set(:thing, :bar, os: "linux")
55
+ end
56
+ it "returns the correct value for windows" do
57
+ allow(node).to receive(:[]).with(:os).and_return("windows")
58
+ expect(node_map.get(node, :thing)).to eql(:foo)
59
+ end
60
+ it "returns the correct value for linux" do
61
+ allow(node).to receive(:[]).with(:os).and_return("linux")
62
+ expect(node_map.get(node, :thing)).to eql(:bar)
63
+ end
64
+ it "returns nil for a non-matching os" do
65
+ allow(node).to receive(:[]).with(:os).and_return("freebsd")
66
+ expect(node_map.get(node, :thing)).to eql(nil)
67
+ end
68
+ end
69
+
70
+ describe "rejecting an os" do
71
+ before do
72
+ node_map.set(:thing, :foo, os: "!windows")
73
+ end
74
+ it "returns nil for windows" do
75
+ allow(node).to receive(:[]).with(:os).and_return("windows")
76
+ expect(node_map.get(node, :thing)).to eql(nil)
77
+ end
78
+ it "returns the correct value for linux" do
79
+ allow(node).to receive(:[]).with(:os).and_return("linux")
80
+ expect(node_map.get(node, :thing)).to eql(:foo)
81
+ end
82
+ end
83
+
84
+ describe "filtering by os and platform_family" do
85
+ before do
86
+ node_map.set(:thing, :bar, os: "linux", platform_family: "rhel")
87
+ end
88
+
89
+ it "returns the correct value when both match" do
90
+ allow(node).to receive(:[]).with(:os).and_return("linux")
91
+ allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
92
+ expect(node_map.get(node, :thing)).to eql(:bar)
93
+ end
94
+
95
+ it "returns nil for a non-matching os" do
96
+ allow(node).to receive(:[]).with(:os).and_return("freebsd")
97
+ expect(node_map.get(node, :thing)).to eql(nil)
98
+ end
99
+
100
+ it "returns nil when the platform_family does not match" do
101
+ allow(node).to receive(:[]).with(:os).and_return("linux")
102
+ allow(node).to receive(:[]).with(:platform_family).and_return("debian")
103
+ expect(node_map.get(node, :thing)).to eql(nil)
104
+ end
105
+ end
106
+
107
+ describe "platform version checks" do
108
+ before do
109
+ node_map.set(:thing, :foo, platform_family: "rhel", platform_version: ">= 7")
110
+ end
111
+
112
+ it "handles non-x.y.z platform versions without throwing an exception" do
113
+ allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
114
+ allow(node).to receive(:[]).with(:platform_version).and_return("7.19.2.2F")
115
+ expect(node_map.get(node, :thing)).to eql(:foo)
116
+ end
117
+
118
+ it "handles non-x.y.z platform versions without throwing an exception when the match fails" do
119
+ allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
120
+ allow(node).to receive(:[]).with(:platform_version).and_return("4.19.2.2F")
121
+ expect(node_map.get(node, :thing)).to eql(nil)
122
+ end
123
+ end
124
+
125
+ describe "ordering classes" do
126
+ it "last writer wins when its reverse alphabetic order" do
127
+ node_map.set(:thing, Foo)
128
+ node_map.set(:thing, Bar)
129
+ expect(node_map.get(node, :thing)).to eql(Bar)
130
+ end
131
+
132
+ it "last writer wins when its alphabetic order" do
133
+ node_map.set(:thing, Bar)
134
+ node_map.set(:thing, Foo)
135
+ expect(node_map.get(node, :thing)).to eql(Foo)
136
+ end
137
+ end
138
+
139
+ describe "deleting classes" do
140
+ it "deletes a class and removes the mapping completely" do
141
+ node_map.set(:thing, Bar)
142
+ expect( node_map.delete_class(Bar) ).to eql({ :thing => [{ :klass => Bar }] })
143
+ expect( node_map.get(node, :thing) ).to eql(nil)
144
+ end
145
+
146
+ it "deletes a class and leaves the mapping that still has an entry" do
147
+ node_map.set(:thing, Bar)
148
+ node_map.set(:thing, Foo)
149
+ expect( node_map.delete_class(Bar) ).to eql({ :thing => [{ :klass => Bar }] })
150
+ expect( node_map.get(node, :thing) ).to eql(Foo)
151
+ end
152
+
153
+ it "handles deleting classes from multiple keys" do
154
+ node_map.set(:thing1, Bar)
155
+ node_map.set(:thing2, Bar)
156
+ node_map.set(:thing2, Foo)
157
+ expect( node_map.delete_class(Bar) ).to eql({ :thing1 => [{ :klass => Bar }], :thing2 => [{ :klass => Bar }] })
158
+ expect( node_map.get(node, :thing1) ).to eql(nil)
159
+ expect( node_map.get(node, :thing2) ).to eql(Foo)
160
+ end
161
+ end
162
+
163
+ describe "with a block doing platform_version checks" do
164
+ before do
165
+ node_map.set(:thing, :foo, platform_family: "rhel") do |node|
166
+ node[:platform_version].to_i >= 7
167
+ end
168
+ end
169
+
170
+ it "returns the value when the node matches" do
171
+ allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
172
+ allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
173
+ expect(node_map.get(node, :thing)).to eql(:foo)
174
+ end
175
+
176
+ it "returns nil when the block does not match" do
177
+ allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
178
+ allow(node).to receive(:[]).with(:platform_version).and_return("6.4")
179
+ expect(node_map.get(node, :thing)).to eql(nil)
180
+ end
181
+
182
+ it "returns nil when the platform_family filter does not match" do
183
+ allow(node).to receive(:[]).with(:platform_family).and_return("debian")
184
+ allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
185
+ expect(node_map.get(node, :thing)).to eql(nil)
186
+ end
187
+
188
+ it "returns nil when both do not match" do
189
+ allow(node).to receive(:[]).with(:platform_family).and_return("debian")
190
+ allow(node).to receive(:[]).with(:platform_version).and_return("6.0")
191
+ expect(node_map.get(node, :thing)).to eql(nil)
192
+ end
193
+
194
+ context "when there is a less specific definition" do
195
+ before do
196
+ node_map.set(:thing, :bar, platform_family: "rhel")
197
+ end
198
+
199
+ it "returns the value when the node matches" do
200
+ allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
201
+ allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
202
+ expect(node_map.get(node, :thing)).to eql(:foo)
203
+ end
204
+ end
205
+ end
206
+
207
+ end
@@ -1,1821 +1,1821 @@
1
- #
2
- # Author:: Adam Jacob (<adam@chef.io>)
3
- # Copyright:: Copyright 2008-2018, Chef Software Inc.
4
- # License:: Apache License, Version 2.0
5
- #
6
- # Licensed under the Apache License, Version 2.0 (the "License");
7
- # you may not use this file except in compliance with the License.
8
- # You may obtain a copy of the License at
9
- #
10
- # http://www.apache.org/licenses/LICENSE-2.0
11
- #
12
- # Unless required by applicable law or agreed to in writing, software
13
- # distributed under the License is distributed on an "AS IS" BASIS,
14
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- # See the License for the specific language governing permissions and
16
- # limitations under the License.
17
- #
18
-
19
- require "spec_helper"
20
- require "ostruct"
21
-
22
- describe Chef::Node do
23
-
24
- let(:node) { Chef::Node.new() }
25
- let(:platform_introspector) { node }
26
-
27
- it_behaves_like "a platform introspector"
28
-
29
- it "creates a node and assigns it a name" do
30
- node = Chef::Node.build("solo-node")
31
- expect(node.name).to eq("solo-node")
32
- end
33
-
34
- it "should validate the name of the node" do
35
- expect { Chef::Node.build("solo node") }.to raise_error(Chef::Exceptions::ValidationFailed)
36
- end
37
-
38
- it "should be sortable" do
39
- n1 = Chef::Node.build("alpha")
40
- n2 = Chef::Node.build("beta")
41
- n3 = Chef::Node.build("omega")
42
- expect([n3, n1, n2].sort).to eq([n1, n2, n3])
43
- end
44
-
45
- it "should share identity only with others of the same name" do
46
- n1 = Chef::Node.build("foo")
47
- n2 = Chef::Node.build("foo")
48
- n3 = Chef::Node.build("bar")
49
- expect(n1).to eq(n2)
50
- expect(n1).not_to eq(n3)
51
- end
52
-
53
- describe "when the node does not exist on the server" do
54
- before do
55
- response = OpenStruct.new(:code => "404")
56
- exception = Net::HTTPServerException.new("404 not found", response)
57
- allow(Chef::Node).to receive(:load).and_raise(exception)
58
- node.name("created-node")
59
- end
60
-
61
- it "creates a new node for find_or_create" do
62
- allow(Chef::Node).to receive(:new).and_return(node)
63
- expect(node).to receive(:create).and_return(node)
64
- node = Chef::Node.find_or_create("created-node")
65
- expect(node.name).to eq("created-node")
66
- expect(node).to equal(node)
67
- end
68
- end
69
-
70
- describe "when the node exists on the server" do
71
- before do
72
- node.name("existing-node")
73
- allow(Chef::Node).to receive(:load).and_return(node)
74
- end
75
-
76
- it "loads the node via the REST API for find_or_create" do
77
- expect(Chef::Node.find_or_create("existing-node")).to equal(node)
78
- end
79
- end
80
-
81
- describe "run_state" do
82
- it "is an empty hash" do
83
- expect(node.run_state).to respond_to(:keys)
84
- expect(node.run_state).to be_empty
85
- end
86
- end
87
-
88
- describe "initialize" do
89
- it "should default to the '_default' chef_environment" do
90
- n = Chef::Node.new
91
- expect(n.chef_environment).to eq("_default")
92
- end
93
- end
94
-
95
- describe "name" do
96
- it "should allow you to set a name with name(something)" do
97
- expect { node.name("latte") }.not_to raise_error
98
- end
99
-
100
- it "should return the name with name()" do
101
- node.name("latte")
102
- expect(node.name).to eql("latte")
103
- end
104
-
105
- it "should always have a string for name" do
106
- expect { node.name(Hash.new) }.to raise_error(ArgumentError)
107
- end
108
-
109
- it "cannot be blank" do
110
- expect { node.name("") }.to raise_error(Chef::Exceptions::ValidationFailed)
111
- end
112
-
113
- it "should not accept name doesn't match /^[\-[:alnum:]_:.]+$/" do
114
- expect { node.name("space in it") }.to raise_error(Chef::Exceptions::ValidationFailed)
115
- end
116
- end
117
-
118
- describe "chef_environment" do
119
- it "should set an environment with chef_environment(something)" do
120
- expect { node.chef_environment("latte") }.not_to raise_error
121
- end
122
-
123
- it "should return the chef_environment with chef_environment()" do
124
- node.chef_environment("latte")
125
- expect(node.chef_environment).to eq("latte")
126
- end
127
-
128
- it "should disallow non-strings" do
129
- expect { node.chef_environment(Hash.new) }.to raise_error(ArgumentError)
130
- expect { node.chef_environment(42) }.to raise_error(ArgumentError)
131
- end
132
-
133
- it "cannot be blank" do
134
- expect { node.chef_environment("") }.to raise_error(Chef::Exceptions::ValidationFailed)
135
- end
136
- end
137
-
138
- describe "policy_name" do
139
-
140
- it "defaults to nil" do
141
- expect(node.policy_name).to be_nil
142
- end
143
-
144
- it "sets policy_name with a regular setter" do
145
- node.policy_name = "example-policy"
146
- expect(node.policy_name).to eq("example-policy")
147
- end
148
-
149
- it "allows policy_name with every valid character" do
150
- expect { node.policy_name = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqurstuvwxyz0123456789-_:." }.to_not raise_error
151
- end
152
-
153
- it "sets policy_name when given an argument" do
154
- node.policy_name("example-policy")
155
- expect(node.policy_name).to eq("example-policy")
156
- end
157
-
158
- it "sets policy_name to nil when given nil" do
159
- node.policy_name = "example-policy"
160
- node.policy_name = nil
161
- expect(node.policy_name).to be_nil
162
- end
163
-
164
- it "disallows non-strings" do
165
- expect { node.policy_name(Hash.new) }.to raise_error(Chef::Exceptions::ValidationFailed)
166
- expect { node.policy_name(42) }.to raise_error(Chef::Exceptions::ValidationFailed)
167
- end
168
-
169
- it "cannot be blank" do
170
- expect { node.policy_name("") }.to raise_error(Chef::Exceptions::ValidationFailed)
171
- end
172
- end
173
-
174
- describe "policy_group" do
175
-
176
- it "defaults to nil" do
177
- expect(node.policy_group).to be_nil
178
- end
179
-
180
- it "sets policy_group with a regular setter" do
181
- node.policy_group = "staging"
182
- expect(node.policy_group).to eq("staging")
183
- end
184
-
185
- it "allows policy_group with every valid character" do
186
- expect { node.policy_group = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqurstuvwxyz0123456789-_:." }.to_not raise_error
187
- end
188
-
189
- it "sets a policy_group with policy_group(something)" do
190
- node.policy_group("staging")
191
- expect(node.policy_group).to eq("staging")
192
- end
193
-
194
- it "sets policy_group to nil when given nil" do
195
- node.policy_group = "staging"
196
- node.policy_group = nil
197
- expect(node.policy_group).to be_nil
198
- end
199
-
200
- it "disallows non-strings" do
201
- expect { node.policy_group(Hash.new) }.to raise_error(Chef::Exceptions::ValidationFailed)
202
- expect { node.policy_group(42) }.to raise_error(Chef::Exceptions::ValidationFailed)
203
- end
204
-
205
- it "cannot be blank" do
206
- expect { node.policy_group("") }.to raise_error(Chef::Exceptions::ValidationFailed)
207
- end
208
- end
209
-
210
- describe "attributes" do
211
- it "should have attributes" do
212
- expect(node.attribute).to be_a_kind_of(Hash)
213
- end
214
-
215
- it "should allow attributes to be accessed by name or symbol directly on node[]" do
216
- node.default["locust"] = "something"
217
- expect(node[:locust]).to eql("something")
218
- expect(node["locust"]).to eql("something")
219
- end
220
-
221
- it "should return nil if it cannot find an attribute with node[]" do
222
- expect(node["secret"]).to eql(nil)
223
- end
224
-
225
- it "does not allow you to set an attribute via node[]=" do
226
- expect { node["secret"] = "shush" }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
227
- end
228
-
229
- it "should allow you to query whether an attribute exists with attribute?" do
230
- node.default["locust"] = "something"
231
- expect(node.attribute?("locust")).to eql(true)
232
- expect(node.attribute?("no dice")).to eql(false)
233
- end
234
-
235
- it "should let you go deep with attribute?" do
236
- node.normal["battles"]["people"]["wonkey"] = true
237
- expect(node["battles"]["people"].attribute?("wonkey")).to eq(true)
238
- expect(node["battles"]["people"].attribute?("snozzberry")).to eq(false)
239
- end
240
-
241
- it "does not allow modification of node attributes via hash methods" do
242
- node.default["h4sh"] = { foo: "bar" }
243
- expect { node["h4sh"].delete("foo") }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
244
- end
245
-
246
- it "does not allow modification of node attributes via array methods" do
247
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
248
- node.default["array"] = []
249
- expect { node["array"] << "boom" }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
250
- end
251
-
252
- it "returns merged immutable attributes for arrays" do
253
- node.default["array"] = []
254
- expect( node["array"].class ).to eql(Chef::Node::ImmutableArray)
255
- end
256
-
257
- it "returns merged immutable attributes for hashes" do
258
- node.default["h4sh"] = {}
259
- expect( node["h4sh"].class ).to eql(Chef::Node::ImmutableMash)
260
- end
261
-
262
- describe "normal attributes" do
263
- it "should allow you to set an attribute with set, without pre-declaring a hash" do
264
- node.normal[:snoopy][:is_a_puppy] = true
265
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
266
- end
267
-
268
- it "should allow you to set an attribute with set_unless" do
269
- node.normal_unless[:snoopy][:is_a_puppy] = false
270
- expect(node[:snoopy][:is_a_puppy]).to eq(false)
271
- end
272
-
273
- it "should not allow you to set an attribute with set_unless if it already exists" do
274
- node.normal[:snoopy][:is_a_puppy] = true
275
- node.normal_unless[:snoopy][:is_a_puppy] = false
276
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
277
- end
278
-
279
- it "should allow you to set an attribute with set_unless if is a nil value" do
280
- node.attributes.normal = { snoopy: { is_a_puppy: nil } }
281
- node.normal_unless[:snoopy][:is_a_puppy] = false
282
- expect(node[:snoopy][:is_a_puppy]).to eq(false)
283
- end
284
-
285
- it "should allow you to set a value after a set_unless" do
286
- # this tests for set_unless_present state bleeding between statements CHEF-3806
287
- node.normal_unless[:snoopy][:is_a_puppy] = false
288
- node.normal[:snoopy][:is_a_puppy] = true
289
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
290
- end
291
-
292
- it "should let you set a value after a 'dangling' set_unless" do
293
- # this tests for set_unless_present state bleeding between statements CHEF-3806
294
- node.normal[:snoopy][:is_a_puppy] = "what"
295
- node.normal_unless[:snoopy][:is_a_puppy]
296
- node.normal[:snoopy][:is_a_puppy] = true
297
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
298
- end
299
-
300
- it "should let you use tag as a convience method for the tags attribute" do
301
- node.normal["tags"] = %w{one two}
302
- node.tag("three", "four")
303
- expect(node["tags"]).to eq(%w{one two three four})
304
- end
305
-
306
- it "normal_unless sets a value even if default or override attrs are set" do
307
- node.default[:decontamination] = true
308
- node.override[:decontamination] = false
309
- node.normal_unless[:decontamination] = "foo"
310
- expect(node.normal[:decontamination]).to eql("foo")
311
- end
312
-
313
- it "default_unless sets a value even if normal or override attrs are set" do
314
- node.normal[:decontamination] = true
315
- node.override[:decontamination] = false
316
- node.default_unless[:decontamination] = "foo"
317
- expect(node.default[:decontamination]).to eql("foo")
318
- end
319
-
320
- it "override_unless sets a value even if default or normal attrs are set" do
321
- node.default[:decontamination] = true
322
- node.normal[:decontamination] = false
323
- node.override_unless[:decontamination] = "foo"
324
- expect(node.override[:decontamination]).to eql("foo")
325
- end
326
-
327
- it "consume_attributes does not exhibit chef/chef/issues/6302 bug" do
328
- node.normal["a"]["r1"] = nil
329
- node.consume_attributes({ "a" => { "r2" => nil } })
330
- expect(node["a"]["r1"]).to be_nil
331
- expect(node["a"]["r2"]).to be_nil
332
- end
333
- end
334
-
335
- describe "default attributes" do
336
- it "should be set with default, without pre-declaring a hash" do
337
- node.default[:snoopy][:is_a_puppy] = true
338
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
339
- end
340
-
341
- it "should allow you to set with default_unless without pre-declaring a hash" do
342
- node.default_unless[:snoopy][:is_a_puppy] = false
343
- expect(node[:snoopy][:is_a_puppy]).to eq(false)
344
- end
345
-
346
- it "should not allow you to set an attribute with default_unless if it already exists" do
347
- node.default[:snoopy][:is_a_puppy] = true
348
- node.default_unless[:snoopy][:is_a_puppy] = false
349
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
350
- end
351
-
352
- it "should allow you to set a value after a default_unless" do
353
- # this tests for set_unless_present state bleeding between statements CHEF-3806
354
- node.default_unless[:snoopy][:is_a_puppy] = false
355
- node.default[:snoopy][:is_a_puppy] = true
356
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
357
- end
358
-
359
- it "should allow you to set a value after a 'dangling' default_unless" do
360
- # this tests for set_unless_present state bleeding between statements CHEF-3806
361
- node.default[:snoopy][:is_a_puppy] = "what"
362
- node.default_unless[:snoopy][:is_a_puppy]
363
- node.default[:snoopy][:is_a_puppy] = true
364
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
365
- end
366
-
367
- it "does not exhibit chef/chef/issues/5005 bug" do
368
- node.env_default["a"]["r1"]["g"]["u"] = "u1"
369
- node.default_unless["a"]["r1"]["g"]["r"] = "r"
370
- expect(node["a"]["r1"]["g"]["u"]).to eql("u1")
371
- end
372
-
373
- it "default_unless correctly resets the deep merge cache" do
374
- node.normal["tags"] = [] # this sets our top-level breadcrumb
375
- node.default_unless["foo"]["bar"] = "NK-19V"
376
- expect(node["foo"]["bar"]).to eql("NK-19V")
377
- node.default_unless["foo"]["baz"] = "NK-33"
378
- expect(node["foo"]["baz"]).to eql("NK-33")
379
- end
380
-
381
- it "normal_unless correctly resets the deep merge cache" do
382
- node.normal["tags"] = [] # this sets our top-level breadcrumb
383
- node.normal_unless["foo"]["bar"] = "NK-19V"
384
- expect(node["foo"]["bar"]).to eql("NK-19V")
385
- node.normal_unless["foo"]["baz"] = "NK-33"
386
- expect(node["foo"]["baz"]).to eql("NK-33")
387
- end
388
-
389
- it "override_unless correctly resets the deep merge cache" do
390
- node.normal["tags"] = [] # this sets our top-level breadcrumb
391
- node.override_unless["foo"]["bar"] = "NK-19V"
392
- expect(node["foo"]["bar"]).to eql("NK-19V")
393
- node.override_unless["foo"]["baz"] = "NK-33"
394
- expect(node["foo"]["baz"]).to eql("NK-33")
395
- end
396
- end
397
-
398
- describe "override attributes" do
399
- it "should be set with override, without pre-declaring a hash" do
400
- node.override[:snoopy][:is_a_puppy] = true
401
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
402
- end
403
-
404
- it "should allow you to set with override_unless without pre-declaring a hash" do
405
- node.override_unless[:snoopy][:is_a_puppy] = false
406
- expect(node[:snoopy][:is_a_puppy]).to eq(false)
407
- end
408
-
409
- it "should not allow you to set an attribute with override_unless if it already exists" do
410
- node.override[:snoopy][:is_a_puppy] = true
411
- node.override_unless[:snoopy][:is_a_puppy] = false
412
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
413
- end
414
-
415
- it "should allow you to set a value after an override_unless" do
416
- # this tests for set_unless_present state bleeding between statements CHEF-3806
417
- node.override_unless[:snoopy][:is_a_puppy] = false
418
- node.override[:snoopy][:is_a_puppy] = true
419
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
420
- end
421
-
422
- it "should allow you to set a value after a 'dangling' override_unless" do
423
- # this tests for set_unless_present state bleeding between statements CHEF-3806
424
- node.override_unless[:snoopy][:is_a_puppy] = "what"
425
- node.override_unless[:snoopy][:is_a_puppy]
426
- node.override[:snoopy][:is_a_puppy] = true
427
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
428
- end
429
- end
430
-
431
- describe "globally deleting attributes" do
432
- context "with hash values" do
433
- before do
434
- node.role_default["mysql"]["server"]["port"] = 1234
435
- node.normal["mysql"]["server"]["port"] = 2345
436
- node.override["mysql"]["server"]["port"] = 3456
437
- end
438
-
439
- it "deletes all the values and returns the value with the highest precidence" do
440
- expect( node.rm("mysql", "server", "port") ).to eql(3456)
441
- expect( node["mysql"]["server"]["port"] ).to be_nil
442
- expect( node["mysql"]["server"] ).to eql({})
443
- end
444
-
445
- it "deletes nested things correctly" do
446
- node.default["mysql"]["client"]["client_setting"] = "foo"
447
- expect( node.rm("mysql", "server") ).to eql( { "port" => 3456 } )
448
- expect( node["mysql"] ).to eql( { "client" => { "client_setting" => "foo" } } )
449
- end
450
-
451
- it "returns nil if the node attribute does not exist" do
452
- expect( node.rm("no", "such", "thing") ).to be_nil
453
- end
454
-
455
- it "can delete the entire tree" do
456
- expect( node.rm("mysql") ).to eql({ "server" => { "port" => 3456 } })
457
- end
458
- end
459
-
460
- context "when trying to delete through a thing that isn't an array-like or hash-like object" do
461
- before do
462
- node.default["mysql"] = true
463
- end
464
-
465
- it "returns nil when you're two levels deeper" do
466
- expect( node.rm("mysql", "server", "port") ).to eql(nil)
467
- end
468
-
469
- it "returns nil when you're one level deeper" do
470
- expect( node.rm("mysql", "server") ).to eql(nil)
471
- end
472
-
473
- it "correctly deletes at the top level" do
474
- expect( node.rm("mysql") ).to eql(true)
475
- end
476
- end
477
-
478
- context "with array indexes" do
479
- before do
480
- node.role_default["mysql"]["server"][0]["port"] = 1234
481
- node.normal["mysql"]["server"][0]["port"] = 2345
482
- node.override["mysql"]["server"][0]["port"] = 3456
483
- node.override["mysql"]["server"][1]["port"] = 3456
484
- end
485
-
486
- it "deletes the array element" do
487
- expect( node.rm("mysql", "server", 0, "port") ).to eql(3456)
488
- expect( node["mysql"]["server"][0]["port"] ).to be_nil
489
- expect( node["mysql"]["server"][1]["port"] ).to eql(3456)
490
- end
491
- end
492
-
493
- context "with real arrays" do
494
- before do
495
- node.role_default["mysql"]["server"] = [ {
496
- "port" => 1234,
497
- } ]
498
- node.normal["mysql"]["server"] = [ {
499
- "port" => 2345,
500
- } ]
501
- node.override["mysql"]["server"] = [ {
502
- "port" => 3456,
503
- } ]
504
- end
505
-
506
- it "deletes the array element" do
507
- expect( node.rm("mysql", "server", 0, "port") ).to eql(3456)
508
- expect( node["mysql"]["server"][0]["port"] ).to be_nil
509
- end
510
-
511
- it "when mistaking arrays for hashes, it considers the value removed and does nothing" do
512
- node.rm("mysql", "server", "port")
513
- expect(node["mysql"]["server"][0]["port"]).to eql(3456)
514
- end
515
- end
516
- end
517
-
518
- describe "granular deleting attributes" do
519
- context "when only defaults exist" do
520
- before do
521
- node.role_default["mysql"]["server"]["port"] = 1234
522
- node.default["mysql"]["server"]["port"] = 2345
523
- node.force_default["mysql"]["server"]["port"] = 3456
524
- end
525
-
526
- it "returns the deleted values" do
527
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
528
- end
529
-
530
- it "returns nil for the combined attribues" do
531
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
532
- expect( node["mysql"]["server"]["port"] ).to eql(nil)
533
- end
534
-
535
- it "returns an empty hash for the default attrs" do
536
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
537
- # this auto-vivifies, should it?
538
- expect( node.default_attrs["mysql"]["server"]["port"] ).to eql({})
539
- end
540
-
541
- it "returns an empty hash after the last key is deleted" do
542
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
543
- expect( node["mysql"]["server"] ).to eql({})
544
- end
545
- end
546
-
547
- context "when trying to delete through a thing that isn't an array-like or hash-like object" do
548
- before do
549
- node.default["mysql"] = true
550
- end
551
-
552
- it "returns nil when you're two levels deeper" do
553
- expect( node.rm_default("mysql", "server", "port") ).to eql(nil)
554
- end
555
-
556
- it "returns nil when you're one level deeper" do
557
- expect( node.rm_default("mysql", "server") ).to eql(nil)
558
- end
559
-
560
- it "correctly deletes at the top level" do
561
- expect( node.rm_default("mysql") ).to eql(true)
562
- end
563
- end
564
-
565
- context "when a higher precedence exists" do
566
- before do
567
- node.role_default["mysql"]["server"]["port"] = 1234
568
- node.default["mysql"]["server"]["port"] = 2345
569
- node.force_default["mysql"]["server"]["port"] = 3456
570
-
571
- node.override["mysql"]["server"]["port"] = 9999
572
- end
573
-
574
- it "returns the deleted values" do
575
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
576
- end
577
-
578
- it "returns the higher precedence values after the delete" do
579
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
580
- expect( node["mysql"]["server"]["port"] ).to eql(9999)
581
- end
582
-
583
- it "returns an empty has for the default attrs" do
584
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
585
- # this auto-vivifies, should it?
586
- expect( node.default_attrs["mysql"]["server"]["port"] ).to eql({})
587
- end
588
- end
589
-
590
- context "when a lower precedence exists" do
591
- before do
592
- node.default["mysql"]["server"]["port"] = 2345
593
- node.override["mysql"]["server"]["port"] = 9999
594
- node.role_override["mysql"]["server"]["port"] = 9876
595
- node.force_override["mysql"]["server"]["port"] = 6669
596
- end
597
-
598
- it "returns the deleted values" do
599
- expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
600
- end
601
-
602
- it "returns the lower precedence levels after the delete" do
603
- expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
604
- expect( node["mysql"]["server"]["port"] ).to eql(2345)
605
- end
606
-
607
- it "returns an empty has for the override attrs" do
608
- expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
609
- # this auto-vivifies, should it?
610
- expect( node.override_attrs["mysql"]["server"]["port"] ).to eql({})
611
- end
612
- end
613
-
614
- it "rm_default returns nil on deleting non-existent values" do
615
- expect( node.rm_default("no", "such", "thing") ).to be_nil
616
- end
617
-
618
- it "rm_normal returns nil on deleting non-existent values" do
619
- expect( node.rm_normal("no", "such", "thing") ).to be_nil
620
- end
621
-
622
- it "rm_override returns nil on deleting non-existent values" do
623
- expect( node.rm_override("no", "such", "thing") ).to be_nil
624
- end
625
- end
626
-
627
- describe "granular replacing attributes" do
628
- it "removes everything at the level of the last key" do
629
- node.default["mysql"]["server"]["port"] = 2345
630
-
631
- node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
632
-
633
- expect( node["mysql"]["server"] ).to eql({ "data_dir" => "/my_raid_volume/lib/mysql" })
634
- end
635
-
636
- it "replaces a value at the cookbook sub-level of the atributes only" do
637
- node.default["mysql"]["server"]["port"] = 2345
638
- node.default["mysql"]["server"]["service_name"] = "fancypants-sql"
639
- node.role_default["mysql"]["server"]["port"] = 1234
640
- node.force_default["mysql"]["server"]["port"] = 3456
641
-
642
- node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
643
-
644
- expect( node["mysql"]["server"]["port"] ).to eql(3456)
645
- expect( node["mysql"]["server"]["service_name"] ).to be_nil
646
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
647
- expect( node["mysql"]["server"] ).to eql({ "port" => 3456, "data_dir" => "/my_raid_volume/lib/mysql" })
648
- end
649
-
650
- it "higher precedence values aren't removed" do
651
- node.role_default["mysql"]["server"]["port"] = 1234
652
- node.default["mysql"]["server"]["port"] = 2345
653
- node.force_default["mysql"]["server"]["port"] = 3456
654
- node.override["mysql"]["server"]["service_name"] = "fancypants-sql"
655
-
656
- node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
657
-
658
- expect( node["mysql"]["server"]["port"] ).to eql(3456)
659
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
660
- expect( node["mysql"]["server"] ).to eql({ "service_name" => "fancypants-sql", "port" => 3456, "data_dir" => "/my_raid_volume/lib/mysql" })
661
- end
662
- end
663
-
664
- describe "granular force replacing attributes" do
665
- it "removes everything at the level of the last key" do
666
- node.force_default["mysql"]["server"]["port"] = 2345
667
-
668
- node.force_default!["mysql"]["server"] = {
669
- "data_dir" => "/my_raid_volume/lib/mysql",
670
- }
671
-
672
- expect( node["mysql"]["server"] ).to eql({
673
- "data_dir" => "/my_raid_volume/lib/mysql",
674
- })
675
- end
676
-
677
- it "removes all values from the precedence level when setting" do
678
- node.role_default["mysql"]["server"]["port"] = 1234
679
- node.default["mysql"]["server"]["port"] = 2345
680
- node.force_default["mysql"]["server"]["port"] = 3456
681
-
682
- node.force_default!["mysql"]["server"] = {
683
- "data_dir" => "/my_raid_volume/lib/mysql",
684
- }
685
-
686
- expect( node["mysql"]["server"]["port"] ).to be_nil
687
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
688
- expect( node["mysql"]["server"] ).to eql({
689
- "data_dir" => "/my_raid_volume/lib/mysql",
690
- })
691
- end
692
-
693
- it "higher precedence levels are not removed" do
694
- node.role_default["mysql"]["server"]["port"] = 1234
695
- node.default["mysql"]["server"]["port"] = 2345
696
- node.force_default["mysql"]["server"]["port"] = 3456
697
- node.override["mysql"]["server"]["service_name"] = "fancypants-sql"
698
-
699
- node.force_default!["mysql"]["server"] = {
700
- "data_dir" => "/my_raid_volume/lib/mysql",
701
- }
702
-
703
- expect( node["mysql"]["server"]["port"] ).to be_nil
704
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
705
- expect( node["mysql"]["server"] ).to eql({
706
- "service_name" => "fancypants-sql",
707
- "data_dir" => "/my_raid_volume/lib/mysql",
708
- })
709
- end
710
-
711
- it "will autovivify" do
712
- node.force_default!["mysql"]["server"] = {
713
- "data_dir" => "/my_raid_volume/lib/mysql",
714
- }
715
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
716
- end
717
-
718
- it "lower precedence levels aren't removed" do
719
- node.role_override["mysql"]["server"]["port"] = 1234
720
- node.override["mysql"]["server"]["port"] = 2345
721
- node.force_override["mysql"]["server"]["port"] = 3456
722
- node.default["mysql"]["server"]["service_name"] = "fancypants-sql"
723
-
724
- node.force_override!["mysql"]["server"] = {
725
- "data_dir" => "/my_raid_volume/lib/mysql",
726
- }
727
-
728
- expect( node["mysql"]["server"]["port"] ).to be_nil
729
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
730
- expect( node["mysql"]["server"] ).to eql({
731
- "service_name" => "fancypants-sql",
732
- "data_dir" => "/my_raid_volume/lib/mysql",
733
- })
734
- end
735
-
736
- it "when overwriting a non-hash/array" do
737
- node.override["mysql"] = false
738
- node.force_override["mysql"] = true
739
- node.force_override!["mysql"]["server"] = {
740
- "data_dir" => "/my_raid_volume/lib/mysql",
741
- }
742
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
743
- end
744
-
745
- it "when overwriting an array with a hash" do
746
- node.force_override["mysql"][0] = true
747
- node.force_override!["mysql"]["server"] = {
748
- "data_dir" => "/my_raid_volume/lib/mysql",
749
- }
750
- expect( node["mysql"]["server"] ).to eql({
751
- "data_dir" => "/my_raid_volume/lib/mysql",
752
- })
753
- end
754
- end
755
-
756
- # In Chef-12.0 there is a deep_merge cache on the top level attribute which had a bug
757
- # where it cached node[:foo] separate from node['foo']. These tests exercise those edge conditions.
758
- #
759
- # https://github.com/chef/chef/issues/2700
760
- # https://github.com/chef/chef/issues/2712
761
- # https://github.com/chef/chef/issues/2745
762
- #
763
- describe "deep merge attribute cache edge conditions" do
764
- it "does not error with complicated attribute substitution" do
765
- node.default["chef_attribute_hell"]["attr1"] = "attribute1"
766
- node.default["chef_attribute_hell"]["attr2"] = "#{node[:chef_attribute_hell][:attr1]}/attr2"
767
- expect { node.default["chef_attribute_hell"]["attr3"] = "#{node[:chef_attribute_hell][:attr2]}/attr3" }.not_to raise_error
768
- end
769
-
770
- it "caches both strings and symbols correctly" do
771
- node.force_default[:solr][:version] = "4.10.2"
772
- node.force_default[:solr][:data_dir] = "/opt/solr-#{node['solr'][:version]}/example/solr"
773
- node.force_default[:solr][:xms] = "512M"
774
- expect(node[:solr][:xms]).to eql("512M")
775
- expect(node["solr"][:xms]).to eql("512M")
776
- end
777
-
778
- it "method interpolation syntax also works" do
779
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
780
- node.default["passenger"]["version"] = "4.0.57"
781
- node.default["passenger"]["root_path"] = "passenger-#{node['passenger']['version']}"
782
- node.default["passenger"]["root_path_2"] = "passenger-#{node[:passenger]['version']}"
783
- expect(node["passenger"]["root_path_2"]).to eql("passenger-4.0.57")
784
- expect(node[:passenger]["root_path_2"]).to eql("passenger-4.0.57")
785
- end
786
- end
787
-
788
- it "should raise an ArgumentError if you ask for an attribute that doesn't exist via method_missing" do
789
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
790
- expect { node.sunshine }.to raise_error(NoMethodError)
791
- end
792
-
793
- it "should allow you to iterate over attributes with each_attribute" do
794
- node.default["sunshine"] = "is bright"
795
- node.default["canada"] = "is a nice place"
796
- seen_attributes = Hash.new
797
- node.each_attribute do |a, v|
798
- seen_attributes[a] = v
799
- end
800
- expect(seen_attributes).to have_key("sunshine")
801
- expect(seen_attributes).to have_key("canada")
802
- expect(seen_attributes["sunshine"]).to eq("is bright")
803
- expect(seen_attributes["canada"]).to eq("is a nice place")
804
- end
805
-
806
- describe "functional attribute API" do
807
- # deeper functional testing of this API is in the VividMash spec tests
808
- it "should have an exist? function" do
809
- node.default["foo"]["bar"] = "baz"
810
- expect(node.exist?("foo", "bar")).to be true
811
- expect(node.exist?("bar", "foo")).to be false
812
- end
813
-
814
- it "should have a read function" do
815
- node.override["foo"]["bar"] = "baz"
816
- expect(node.read("foo", "bar")).to eql("baz")
817
- expect(node.read("bar", "foo")).to eql(nil)
818
- end
819
-
820
- it "should have a read! function" do
821
- node.override["foo"]["bar"] = "baz"
822
- expect(node.read!("foo", "bar")).to eql("baz")
823
- expect { node.read!("bar", "foo") }.to raise_error(Chef::Exceptions::NoSuchAttribute)
824
- end
825
-
826
- it "delegates write(:level) to node.level.write()" do
827
- node.write(:default, "foo", "bar", "baz")
828
- expect(node.default["foo"]["bar"]).to eql("baz")
829
- end
830
-
831
- it "delegates write!(:level) to node.level.write!()" do
832
- node.write!(:default, "foo", "bar", "baz")
833
- expect(node.default["foo"]["bar"]).to eql("baz")
834
- node.default["bar"] = true
835
- expect { node.write!(:default, "bar", "foo", "baz") }.to raise_error(Chef::Exceptions::AttributeTypeMismatch)
836
- end
837
-
838
- it "delegates unlink(:level) to node.level.unlink()" do
839
- node.default["foo"]["bar"] = "baz"
840
- expect(node.unlink(:default, "foo", "bar")).to eql("baz")
841
- expect(node.unlink(:default, "bar", "foo")).to eql(nil)
842
- end
843
-
844
- it "delegates unlink!(:level) to node.level.unlink!()" do
845
- node.default["foo"]["bar"] = "baz"
846
- expect(node.unlink!(:default, "foo", "bar")).to eql("baz")
847
- expect { node.unlink!(:default, "bar", "foo") }.to raise_error(Chef::Exceptions::NoSuchAttribute)
848
- end
849
- end
850
- end
851
-
852
- describe "consuming json" do
853
-
854
- before do
855
- @ohai_data = { :platform => "foo", :platform_version => "bar" }
856
- end
857
-
858
- it "consumes the run list portion of a collection of attributes and returns the remainder" do
859
- attrs = { "run_list" => [ "role[base]", "recipe[chef::server]" ], "foo" => "bar" }
860
- expect(node.consume_run_list(attrs)).to eq({ "foo" => "bar" })
861
- expect(node.run_list).to eq([ "role[base]", "recipe[chef::server]" ])
862
- end
863
-
864
- it "sets the node chef_environment" do
865
- attrs = { "chef_environment" => "foo_environment", "bar" => "baz" }
866
- expect(node.consume_chef_environment(attrs)).to eq({ "bar" => "baz" })
867
- expect(node.chef_environment).to eq("foo_environment")
868
- expect(node["chef_environment"]).to be nil
869
- end
870
-
871
- it "should overwrites the run list with the run list it consumes" do
872
- node.consume_run_list "recipes" => %w{one two}
873
- node.consume_run_list "recipes" => [ "three" ]
874
- expect(node.run_list).to eq([ "three" ])
875
- end
876
-
877
- it "should not add duplicate recipes from the json attributes" do
878
- node.run_list << "one"
879
- node.consume_run_list "recipes" => %w{one two three}
880
- expect(node.run_list).to eq(%w{one two three})
881
- end
882
-
883
- it "doesn't change the run list if no run_list is specified in the json" do
884
- node.run_list << "role[database]"
885
- node.consume_run_list "foo" => "bar"
886
- expect(node.run_list).to eq(["role[database]"])
887
- end
888
-
889
- it "raises an exception if you provide both recipe and run_list attributes, since this is ambiguous" do
890
- expect { node.consume_run_list "recipes" => "stuff", "run_list" => "other_stuff" }.to raise_error(Chef::Exceptions::AmbiguousRunlistSpecification)
891
- end
892
-
893
- it "should add json attributes to the node" do
894
- node.consume_external_attrs(@ohai_data, { "one" => "two", "three" => "four" })
895
- expect(node["one"]).to eql("two")
896
- expect(node["three"]).to eql("four")
897
- end
898
-
899
- it "should set the tags attribute to an empty array if it is not already defined" do
900
- node.consume_external_attrs(@ohai_data, {})
901
- expect(node.tags).to eql([])
902
- end
903
-
904
- it "should not set the tags attribute to an empty array if it is already defined" do
905
- node.tag("radiohead")
906
- node.consume_external_attrs(@ohai_data, {})
907
- expect(node.tags).to eql([ "radiohead" ])
908
- end
909
-
910
- it "should set the tags attribute to an empty array if it is nil" do
911
- node.attributes.normal = { "tags" => nil }
912
- node.consume_external_attrs(@ohai_data, {})
913
- expect(node.tags).to eql([])
914
- end
915
-
916
- it "should return an array if it is fed a string" do
917
- node.normal[:tags] = "string"
918
- node.consume_external_attrs(@ohai_data, {})
919
- expect(node.tags).to eql(["string"])
920
- end
921
-
922
- it "should return an array if it is fed a hash" do
923
- node.normal[:tags] = {}
924
- node.consume_external_attrs(@ohai_data, {})
925
- expect(node.tags).to eql([])
926
- end
927
-
928
- it "deep merges attributes instead of overwriting them" do
929
- node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "four" } })
930
- expect(node["one"].to_hash).to eq({ "two" => { "three" => "four" } })
931
- node.consume_external_attrs(@ohai_data, "one" => { "abc" => "123" })
932
- node.consume_external_attrs(@ohai_data, "one" => { "two" => { "foo" => "bar" } })
933
- expect(node["one"].to_hash).to eq({ "two" => { "three" => "four", "foo" => "bar" }, "abc" => "123" })
934
- end
935
-
936
- it "gives attributes from JSON priority when deep merging" do
937
- node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "four" } })
938
- expect(node["one"].to_hash).to eq({ "two" => { "three" => "four" } })
939
- node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "forty-two" } })
940
- expect(node["one"].to_hash).to eq({ "two" => { "three" => "forty-two" } })
941
- end
942
-
943
- end
944
-
945
- describe "preparing for a chef client run" do
946
- before do
947
- @ohai_data = { :platform => "foobuntu", :platform_version => "23.42" }
948
- end
949
-
950
- it "sets its platform according to platform detection" do
951
- node.consume_external_attrs(@ohai_data, {})
952
- expect(node.automatic_attrs[:platform]).to eq("foobuntu")
953
- expect(node.automatic_attrs[:platform_version]).to eq("23.42")
954
- end
955
-
956
- it "sets the chef guid attribute correctly" do
957
- guid = Chef::Config[:chef_guid]
958
- Chef::Config[:chef_guid] = "test-guid-guid"
959
- node.consume_external_attrs(@ohai_data, {})
960
- expect(node.automatic_attrs[:chef_guid]).to eq("test-guid-guid")
961
- Chef::Config[:chef_guid] = guid
962
- end
963
-
964
- it "consumes the run list from provided json attributes" do
965
- node.consume_external_attrs(@ohai_data, { "run_list" => ["recipe[unicorn]"] })
966
- expect(node.run_list).to eq(["recipe[unicorn]"])
967
- end
968
-
969
- it "saves non-runlist json attrs for later" do
970
- expansion = Chef::RunList::RunListExpansion.new("_default", [])
971
- allow(node.run_list).to receive(:expand).and_return(expansion)
972
- node.consume_external_attrs(@ohai_data, { "foo" => "bar" })
973
- node.expand!
974
- expect(node.normal_attrs).to eq({ "foo" => "bar", "tags" => [] })
975
- end
976
-
977
- end
978
-
979
- describe "when expanding its run list and merging attributes" do
980
- before do
981
- @environment = Chef::Environment.new.tap do |e|
982
- e.name("rspec_env")
983
- e.default_attributes("env default key" => "env default value")
984
- e.override_attributes("env override key" => "env override value")
985
- end
986
- expect(Chef::Environment).to receive(:load).with("rspec_env").and_return(@environment)
987
- @expansion = Chef::RunList::RunListExpansion.new("rspec_env", [])
988
- node.chef_environment("rspec_env")
989
- allow(node.run_list).to receive(:expand).and_return(@expansion)
990
- end
991
-
992
- it "sets the 'recipes' automatic attribute to the recipes in the expanded run_list" do
993
- @expansion.recipes << "recipe[chef::client]" << "recipe[nginx::default]"
994
- node.expand!
995
- expect(node.automatic_attrs[:recipes]).to eq(["recipe[chef::client]", "recipe[nginx::default]"])
996
- end
997
-
998
- it "sets the 'roles' automatic attribute to the expanded role list" do
999
- @expansion.instance_variable_set(:@applied_roles, { "arf" => nil, "countersnark" => nil })
1000
- node.expand!
1001
- expect(node.automatic_attrs[:roles].sort).to eq(%w{arf countersnark})
1002
- end
1003
-
1004
- it "applies default attributes from the environment as environment defaults" do
1005
- node.expand!
1006
- expect(node.attributes.env_default["env default key"]).to eq("env default value")
1007
- end
1008
-
1009
- it "applies override attributes from the environment as env overrides" do
1010
- node.expand!
1011
- expect(node.attributes.env_override["env override key"]).to eq("env override value")
1012
- end
1013
-
1014
- it "applies default attributes from roles as role defaults" do
1015
- @expansion.default_attrs["role default key"] = "role default value"
1016
- node.expand!
1017
- expect(node.attributes.role_default["role default key"]).to eq("role default value")
1018
- end
1019
-
1020
- it "applies override attributes from roles as role overrides" do
1021
- @expansion.override_attrs["role override key"] = "role override value"
1022
- node.expand!
1023
- expect(node.attributes.role_override["role override key"]).to eq("role override value")
1024
- end
1025
- end
1026
-
1027
- describe "loaded_recipe" do
1028
- it "should not add a recipe that is already in the recipes list" do
1029
- node.automatic_attrs[:recipes] = [ "nginx::module" ]
1030
- node.loaded_recipe(:nginx, "module")
1031
- expect(node.automatic_attrs[:recipes].length).to eq(1)
1032
- end
1033
-
1034
- it "should add a recipe that is not already in the recipes list" do
1035
- node.automatic_attrs[:recipes] = [ "nginx::other_module" ]
1036
- node.loaded_recipe(:nginx, "module")
1037
- expect(node.automatic_attrs[:recipes].length).to eq(2)
1038
- expect(node.recipe?("nginx::module")).to be true
1039
- expect(node.recipe?("nginx::other_module")).to be true
1040
- end
1041
- end
1042
-
1043
- describe "when querying for recipes in the run list" do
1044
- context "when a recipe is in the top level run list" do
1045
- before do
1046
- node.run_list << "recipe[nginx::module]"
1047
- end
1048
-
1049
- it "finds the recipe" do
1050
- expect(node.recipe?("nginx::module")).to be true
1051
- end
1052
-
1053
- it "does not find a recipe not in the run list" do
1054
- expect(node.recipe?("nginx::other_module")).to be false
1055
- end
1056
- end
1057
- context "when a recipe is in the expanded run list only" do
1058
- before do
1059
- node.run_list << "role[base]"
1060
- node.automatic_attrs[:recipes] = [ "nginx::module" ]
1061
- end
1062
-
1063
- it "finds a recipe in the expanded run list" do
1064
- expect(node.recipe?("nginx::module")).to be true
1065
- end
1066
-
1067
- it "does not find a recipe that's not in the run list" do
1068
- expect(node.recipe?("nginx::other_module")).to be false
1069
- end
1070
- end
1071
- end
1072
-
1073
- describe "when clearing computed state at the beginning of a run" do
1074
- before do
1075
- node.default[:foo] = "default"
1076
- node.normal[:foo] = "normal"
1077
- node.override[:foo] = "override"
1078
- node.reset_defaults_and_overrides
1079
- end
1080
-
1081
- it "removes default attributes" do
1082
- expect(node.default).to be_empty
1083
- end
1084
-
1085
- it "removes override attributes" do
1086
- expect(node.override).to be_empty
1087
- end
1088
-
1089
- it "leaves normal level attributes untouched" do
1090
- expect(node[:foo]).to eq("normal")
1091
- end
1092
-
1093
- end
1094
-
1095
- describe "when merging environment attributes" do
1096
- before do
1097
- node.chef_environment = "rspec"
1098
- @expansion = Chef::RunList::RunListExpansion.new("rspec", [])
1099
- @expansion.default_attrs.replace({ :default => "from role", :d_role => "role only" })
1100
- @expansion.override_attrs.replace({ :override => "from role", :o_role => "role only" })
1101
-
1102
- @environment = Chef::Environment.new
1103
- @environment.default_attributes = { :default => "from env", :d_env => "env only" }
1104
- @environment.override_attributes = { :override => "from env", :o_env => "env only" }
1105
- allow(Chef::Environment).to receive(:load).and_return(@environment)
1106
- node.apply_expansion_attributes(@expansion)
1107
- end
1108
-
1109
- it "does not nuke role-only default attrs" do
1110
- expect(node[:d_role]).to eq("role only")
1111
- end
1112
-
1113
- it "does not nuke role-only override attrs" do
1114
- expect(node[:o_role]).to eq("role only")
1115
- end
1116
-
1117
- it "does not nuke env-only default attrs" do
1118
- expect(node[:o_env]).to eq("env only")
1119
- end
1120
-
1121
- it "does not nuke role-only override attrs" do
1122
- expect(node[:o_env]).to eq("env only")
1123
- end
1124
-
1125
- it "gives role defaults precedence over env defaults" do
1126
- expect(node[:default]).to eq("from role")
1127
- end
1128
-
1129
- it "gives env overrides precedence over role overrides" do
1130
- expect(node[:override]).to eq("from env")
1131
- end
1132
- end
1133
-
1134
- describe "when evaluating attributes files" do
1135
- before do
1136
- @cookbook_repo = File.expand_path(File.join(CHEF_SPEC_DATA, "cookbooks"))
1137
- @cookbook_loader = Chef::CookbookLoader.new(@cookbook_repo)
1138
- @cookbook_loader.load_cookbooks
1139
-
1140
- @cookbook_collection = Chef::CookbookCollection.new(@cookbook_loader.cookbooks_by_name)
1141
-
1142
- @events = Chef::EventDispatch::Dispatcher.new
1143
- @run_context = Chef::RunContext.new(node, @cookbook_collection, @events)
1144
-
1145
- node.include_attribute("openldap::default")
1146
- node.include_attribute("openldap::smokey")
1147
- end
1148
-
1149
- it "sets attributes from the files" do
1150
- expect(node["ldap_server"]).to eql("ops1prod")
1151
- expect(node["ldap_basedn"]).to eql("dc=hjksolutions,dc=com")
1152
- expect(node["ldap_replication_password"]).to eql("forsure")
1153
- expect(node["smokey"]).to eql("robinson")
1154
- end
1155
-
1156
- it "gives a sensible error when attempting to load a missing attributes file" do
1157
- expect { node.include_attribute("nope-this::doesnt-exist") }.to raise_error(Chef::Exceptions::CookbookNotFound)
1158
- end
1159
- end
1160
-
1161
- describe "roles" do
1162
- it "should allow you to query whether or not it has a recipe applied with role?" do
1163
- node.run_list << "role[sunrise]"
1164
- expect(node.role?("sunrise")).to eql(true)
1165
- expect(node.role?("not at home")).to eql(false)
1166
- end
1167
-
1168
- it "should allow you to set roles with arguments" do
1169
- node.run_list << "role[one]"
1170
- node.run_list << "role[two]"
1171
- expect(node.role?("one")).to eql(true)
1172
- expect(node.role?("two")).to eql(true)
1173
- end
1174
- end
1175
-
1176
- describe "run_list" do
1177
- it "should have a Chef::RunList of recipes and roles that should be applied" do
1178
- expect(node.run_list).to be_a_kind_of(Chef::RunList)
1179
- end
1180
-
1181
- it "should allow you to query the run list with arguments" do
1182
- node.run_list "recipe[baz]"
1183
- expect(node.run_list?("recipe[baz]")).to eql(true)
1184
- end
1185
-
1186
- it "should allow you to set the run list with arguments" do
1187
- node.run_list "recipe[baz]", "role[foo]"
1188
- expect(node.run_list?("recipe[baz]")).to eql(true)
1189
- expect(node.run_list?("role[foo]")).to eql(true)
1190
- end
1191
- end
1192
-
1193
- describe "from file" do
1194
- it "should load a node from a ruby file" do
1195
- node.from_file(File.expand_path(File.join(CHEF_SPEC_DATA, "nodes", "test.rb")))
1196
- expect(node.name).to eql("test.example.com-short")
1197
- expect(node["sunshine"]).to eql("in")
1198
- expect(node["something"]).to eql("else")
1199
- expect(node.run_list).to eq(["operations-master", "operations-monitoring"])
1200
- end
1201
-
1202
- it "should raise an exception if the file cannot be found or read" do
1203
- expect { node.from_file("/tmp/monkeydiving") }.to raise_error(IOError)
1204
- end
1205
- end
1206
-
1207
- describe "update_from!" do
1208
- before(:each) do
1209
- node.name("orig")
1210
- node.chef_environment("dev")
1211
- node.default_attrs = { "one" => { "two" => "three", "four" => "five", "eight" => "nine" } }
1212
- node.override_attrs = { "one" => { "two" => "three", "four" => "six" } }
1213
- node.normal_attrs = { "one" => { "two" => "seven" } }
1214
- node.run_list << "role[marxist]"
1215
- node.run_list << "role[leninist]"
1216
- node.run_list << "recipe[stalinist]"
1217
-
1218
- @example = Chef::Node.new()
1219
- @example.name("newname")
1220
- @example.chef_environment("prod")
1221
- @example.default_attrs = { "alpha" => { "bravo" => "charlie", "delta" => "echo" } }
1222
- @example.override_attrs = { "alpha" => { "bravo" => "foxtrot", "delta" => "golf" } }
1223
- @example.normal_attrs = { "alpha" => { "bravo" => "hotel" } }
1224
- @example.run_list << "role[comedy]"
1225
- @example.run_list << "role[drama]"
1226
- @example.run_list << "recipe[mystery]"
1227
- end
1228
-
1229
- it "allows update of everything except name" do
1230
- node.update_from!(@example)
1231
- expect(node.name).to eq("orig")
1232
- expect(node.chef_environment).to eq(@example.chef_environment)
1233
- expect(node.default_attrs).to eq(@example.default_attrs)
1234
- expect(node.override_attrs).to eq(@example.override_attrs)
1235
- expect(node.normal_attrs).to eq(@example.normal_attrs)
1236
- expect(node.run_list).to eq(@example.run_list)
1237
- end
1238
-
1239
- it "should not update the name of the node" do
1240
- expect(node).not_to receive(:name).with(@example.name)
1241
- node.update_from!(@example)
1242
- end
1243
- end
1244
-
1245
- describe "to_hash" do
1246
- it "should serialize itself as a hash" do
1247
- node.chef_environment("dev")
1248
- node.default_attrs = { "one" => { "two" => "three", "four" => "five", "eight" => "nine" } }
1249
- node.override_attrs = { "one" => { "two" => "three", "four" => "six" } }
1250
- node.normal_attrs = { "one" => { "two" => "seven" } }
1251
- node.run_list << "role[marxist]"
1252
- node.run_list << "role[leninist]"
1253
- node.run_list << "recipe[stalinist]"
1254
- h = node.to_hash
1255
- expect(h["one"]["two"]).to eq("three")
1256
- expect(h["one"]["four"]).to eq("six")
1257
- expect(h["one"]["eight"]).to eq("nine")
1258
- expect(h["role"]).to be_include("marxist")
1259
- expect(h["role"]).to be_include("leninist")
1260
- expect(h["run_list"]).to be_include("role[marxist]")
1261
- expect(h["run_list"]).to be_include("role[leninist]")
1262
- expect(h["run_list"]).to be_include("recipe[stalinist]")
1263
- expect(h["chef_environment"]).to eq("dev")
1264
- end
1265
-
1266
- it "should return an empty array for empty run_list" do
1267
- expect(node.to_hash["run_list"]).to eq([])
1268
- end
1269
- end
1270
-
1271
- describe "converting to or from json" do
1272
- it "should serialize itself as json", :json => true do
1273
- node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1274
- json = Chef::JSONCompat.to_json(node)
1275
- expect(json).to match(/json_class/)
1276
- expect(json).to match(/name/)
1277
- expect(json).to match(/chef_environment/)
1278
- expect(json).to match(/normal/)
1279
- expect(json).to match(/default/)
1280
- expect(json).to match(/override/)
1281
- expect(json).to match(/run_list/)
1282
- end
1283
-
1284
- it "should serialize valid json with a run list", :json => true do
1285
- #This test came about because activesupport mucks with Chef json serialization
1286
- #Test should pass with and without Activesupport
1287
- node.run_list << { "type" => "role", "name" => "Cthulu" }
1288
- node.run_list << { "type" => "role", "name" => "Hastur" }
1289
- json = Chef::JSONCompat.to_json(node)
1290
- expect(json).to match(/\"run_list\":\[\"role\[Cthulu\]\",\"role\[Hastur\]\"\]/)
1291
- end
1292
-
1293
- it "should serialize the correct run list", :json => true do
1294
- node.run_list << "role[marxist]"
1295
- node.run_list << "role[leninist]"
1296
- node.override_runlist << "role[stalinist]"
1297
- expect(node.run_list).to be_include("role[stalinist]")
1298
- json = Chef::JSONCompat.to_json(node)
1299
- expect(json).to match(/\"run_list\":\[\"role\[marxist\]\",\"role\[leninist\]\"\]/)
1300
- end
1301
-
1302
- it "merges the override components into a combined override object" do
1303
- node.attributes.role_override["role override"] = "role override"
1304
- node.attributes.env_override["env override"] = "env override"
1305
- node_for_json = node.for_json
1306
- expect(node_for_json["override"]["role override"]).to eq("role override")
1307
- expect(node_for_json["override"]["env override"]).to eq("env override")
1308
- end
1309
-
1310
- it "merges the default components into a combined default object" do
1311
- node.attributes.role_default["role default"] = "role default"
1312
- node.attributes.env_default["env default"] = "env default"
1313
- node_for_json = node.for_json
1314
- expect(node_for_json["default"]["role default"]).to eq("role default")
1315
- expect(node_for_json["default"]["env default"]).to eq("env default")
1316
- end
1317
-
1318
- it "should deserialize itself from json", :json => true do
1319
- node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1320
- json = Chef::JSONCompat.to_json(node)
1321
- serialized_node = Chef::Node.from_hash(Chef::JSONCompat.parse(json))
1322
- expect(serialized_node).to be_a_kind_of(Chef::Node)
1323
- expect(serialized_node.name).to eql(node.name)
1324
- expect(serialized_node.chef_environment).to eql(node.chef_environment)
1325
- node.each_attribute do |k, v|
1326
- expect(serialized_node[k]).to eql(v)
1327
- end
1328
- expect(serialized_node.run_list).to eq(node.run_list)
1329
- end
1330
-
1331
- context "when policyfile attributes are not present" do
1332
-
1333
- it "does not have a policy_name key in the json" do
1334
- expect(node.for_json.keys).to_not include("policy_name")
1335
- end
1336
-
1337
- it "does not have a policy_group key in the json" do
1338
- expect(node.for_json.keys).to_not include("policy_name")
1339
- end
1340
- end
1341
-
1342
- context "when policyfile attributes are present" do
1343
-
1344
- before do
1345
- node.policy_name = "my-application"
1346
- node.policy_group = "staging"
1347
- end
1348
-
1349
- it "includes policy_name key in the json" do
1350
- expect(node.for_json).to have_key("policy_name")
1351
- expect(node.for_json["policy_name"]).to eq("my-application")
1352
- end
1353
-
1354
- it "includes a policy_group key in the json" do
1355
- expect(node.for_json).to have_key("policy_group")
1356
- expect(node.for_json["policy_group"]).to eq("staging")
1357
- end
1358
-
1359
- it "parses policyfile attributes from JSON" do
1360
- round_tripped_node = Chef::Node.from_hash(node.for_json)
1361
-
1362
- expect(round_tripped_node.policy_name).to eq("my-application")
1363
- expect(round_tripped_node.policy_group).to eq("staging")
1364
- expect(round_tripped_node.chef_environment).to eq("staging")
1365
- end
1366
-
1367
- end
1368
-
1369
- include_examples "to_json equivalent to Chef::JSONCompat.to_json" do
1370
- let(:jsonable) do
1371
- node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1372
- node
1373
- end
1374
- end
1375
- end
1376
-
1377
- describe "to_s" do
1378
- it "should turn into a string like node[name]" do
1379
- node.name("airplane")
1380
- expect(node.to_s).to eql("node[airplane]")
1381
- end
1382
- end
1383
-
1384
- describe "api model" do
1385
- before(:each) do
1386
- @rest = double("Chef::ServerAPI")
1387
- allow(Chef::ServerAPI).to receive(:new).and_return(@rest)
1388
- @query = double("Chef::Search::Query")
1389
- allow(Chef::Search::Query).to receive(:new).and_return(@query)
1390
- end
1391
-
1392
- describe "list" do
1393
- describe "inflated" do
1394
- it "should return a hash of node names and objects" do
1395
- n1 = double("Chef::Node", :name => "one")
1396
- allow(n1).to receive(:kind_of?).with(Chef::Node) { true }
1397
- expect(@query).to receive(:search).with(:node).and_yield(n1)
1398
- r = Chef::Node.list(true)
1399
- expect(r["one"]).to eq(n1)
1400
- end
1401
- end
1402
-
1403
- it "should return a hash of node names and urls" do
1404
- expect(@rest).to receive(:get).and_return({ "one" => "http://foo" })
1405
- r = Chef::Node.list
1406
- expect(r["one"]).to eq("http://foo")
1407
- end
1408
- end
1409
-
1410
- describe "load" do
1411
- it "should load a node by name" do
1412
- node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1413
- json = Chef::JSONCompat.to_json(node)
1414
- parsed = Chef::JSONCompat.parse(json)
1415
- expect(@rest).to receive(:get).with("nodes/test.example.com").and_return(parsed)
1416
- serialized_node = Chef::Node.load("test.example.com")
1417
- expect(serialized_node).to be_a_kind_of(Chef::Node)
1418
- expect(serialized_node.name).to eql(node.name)
1419
- end
1420
- end
1421
-
1422
- describe "destroy" do
1423
- it "should destroy a node" do
1424
- expect(@rest).to receive(:delete).with("nodes/monkey").and_return("foo")
1425
- node.name("monkey")
1426
- node.destroy
1427
- end
1428
- end
1429
-
1430
- describe "save" do
1431
- it "should update a node if it already exists" do
1432
- node.name("monkey")
1433
- allow(node).to receive(:data_for_save).and_return({})
1434
- expect(@rest).to receive(:put).with("nodes/monkey", {}).and_return("foo")
1435
- node.save
1436
- end
1437
-
1438
- it "should not try and create if it can update" do
1439
- node.name("monkey")
1440
- allow(node).to receive(:data_for_save).and_return({})
1441
- expect(@rest).to receive(:put).with("nodes/monkey", {}).and_return("foo")
1442
- expect(@rest).not_to receive(:post)
1443
- node.save
1444
- end
1445
-
1446
- it "should create if it cannot update" do
1447
- node.name("monkey")
1448
- allow(node).to receive(:data_for_save).and_return({})
1449
- exception = double("404 error", :code => "404")
1450
- expect(@rest).to receive(:put).and_raise(Net::HTTPServerException.new("foo", exception))
1451
- expect(@rest).to receive(:post).with("nodes", {})
1452
- node.save
1453
- end
1454
-
1455
- describe "when whyrun mode is enabled" do
1456
- before do
1457
- Chef::Config[:why_run] = true
1458
- end
1459
- after do
1460
- Chef::Config[:why_run] = false
1461
- end
1462
- it "should not save" do
1463
- node.name("monkey")
1464
- expect(@rest).not_to receive(:put)
1465
- expect(@rest).not_to receive(:post)
1466
- node.save
1467
- end
1468
- end
1469
-
1470
- context "with whitelisted attributes configured" do
1471
- it "should only save whitelisted attributes (and subattributes)" do
1472
- Chef::Config[:automatic_attribute_whitelist] = [
1473
- ["filesystem", "/dev/disk0s2"],
1474
- "network/interfaces/eth0",
1475
- ]
1476
-
1477
- data = {
1478
- "automatic" => {
1479
- "filesystem" => {
1480
- "/dev/disk0s2" => { "size" => "10mb" },
1481
- "map - autohome" => { "size" => "10mb" },
1482
- },
1483
- "network" => {
1484
- "interfaces" => {
1485
- "eth0" => {},
1486
- "eth1" => {},
1487
- },
1488
- },
1489
- },
1490
- "default" => {}, "normal" => {}, "override" => {}
1491
- }
1492
-
1493
- selected_data = {
1494
- "automatic" => {
1495
- "filesystem" => {
1496
- "/dev/disk0s2" => { "size" => "10mb" },
1497
- },
1498
- "network" => {
1499
- "interfaces" => {
1500
- "eth0" => {},
1501
- },
1502
- },
1503
- },
1504
- "default" => {}, "normal" => {}, "override" => {}
1505
- }
1506
-
1507
- node.name("picky-monkey")
1508
- allow(node).to receive(:for_json).and_return(data)
1509
- expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1510
- node.save
1511
- end
1512
-
1513
- it "should save false-y whitelisted attributes" do
1514
- Chef::Config[:default_attribute_whitelist] = [
1515
- "foo/bar/baz",
1516
- ]
1517
-
1518
- data = {
1519
- "default" => {
1520
- "foo" => {
1521
- "bar" => {
1522
- "baz" => false,
1523
- },
1524
- "other" => {
1525
- "stuff" => true,
1526
- },
1527
- },
1528
- },
1529
- }
1530
-
1531
- selected_data = {
1532
- "default" => {
1533
- "foo" => {
1534
- "bar" => {
1535
- "baz" => false,
1536
- },
1537
- },
1538
- },
1539
- }
1540
-
1541
- node.name("falsey-monkey")
1542
- allow(node).to receive(:for_json).and_return(data)
1543
- expect(@rest).to receive(:put).with("nodes/falsey-monkey", selected_data).and_return("foo")
1544
- node.save
1545
- end
1546
-
1547
- it "should not save any attributes if the whitelist is empty" do
1548
- Chef::Config[:automatic_attribute_whitelist] = []
1549
-
1550
- data = {
1551
- "automatic" => {
1552
- "filesystem" => {
1553
- "/dev/disk0s2" => { "size" => "10mb" },
1554
- "map - autohome" => { "size" => "10mb" },
1555
- },
1556
- },
1557
- "default" => {}, "normal" => {}, "override" => {}
1558
- }
1559
-
1560
- selected_data = {
1561
- "automatic" => {}, "default" => {}, "normal" => {}, "override" => {}
1562
- }
1563
-
1564
- node.name("picky-monkey")
1565
- allow(node).to receive(:for_json).and_return(data)
1566
- expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1567
- node.save
1568
- end
1569
- end
1570
-
1571
- context "with blacklisted attributes configured" do
1572
- it "should only save non-blacklisted attributes (and subattributes)" do
1573
- Chef::Config[:automatic_attribute_blacklist] = [
1574
- ["filesystem", "/dev/disk0s2"],
1575
- "network/interfaces/eth0",
1576
- ]
1577
-
1578
- data = {
1579
- "automatic" => {
1580
- "filesystem" => {
1581
- "/dev/disk0s2" => { "size" => "10mb" },
1582
- "map - autohome" => { "size" => "10mb" },
1583
- },
1584
- "network" => {
1585
- "interfaces" => {
1586
- "eth0" => {},
1587
- "eth1" => {},
1588
- },
1589
- },
1590
- },
1591
- "default" => {}, "normal" => {}, "override" => {}
1592
- }
1593
-
1594
- selected_data = {
1595
- "automatic" => {
1596
- "filesystem" => {
1597
- "map - autohome" => { "size" => "10mb" },
1598
- },
1599
- "network" => {
1600
- "interfaces" => {
1601
- "eth1" => {},
1602
- },
1603
- },
1604
- },
1605
- "default" => {}, "normal" => {}, "override" => {}
1606
- }
1607
- node.name("picky-monkey")
1608
- allow(node).to receive(:for_json).and_return(data)
1609
- expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1610
- node.save
1611
- end
1612
-
1613
- it "should save all attributes if the blacklist is empty" do
1614
- Chef::Config[:automatic_attribute_blacklist] = []
1615
-
1616
- data = {
1617
- "automatic" => {
1618
- "filesystem" => {
1619
- "/dev/disk0s2" => { "size" => "10mb" },
1620
- "map - autohome" => { "size" => "10mb" },
1621
- },
1622
- },
1623
- "default" => {}, "normal" => {}, "override" => {}
1624
- }
1625
-
1626
- selected_data = {
1627
- "automatic" => {
1628
- "filesystem" => {
1629
- "/dev/disk0s2" => { "size" => "10mb" },
1630
- "map - autohome" => { "size" => "10mb" },
1631
- },
1632
- },
1633
- "default" => {}, "normal" => {}, "override" => {}
1634
- }
1635
-
1636
- node.name("picky-monkey")
1637
- allow(node).to receive(:for_json).and_return(data)
1638
- expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1639
- node.save
1640
- end
1641
- end
1642
-
1643
- context "when policyfile attributes are present" do
1644
-
1645
- before do
1646
- node.name("example-node")
1647
- node.policy_name = "my-application"
1648
- node.policy_group = "staging"
1649
- end
1650
-
1651
- context "and the server supports policyfile attributes in node JSON" do
1652
-
1653
- it "creates the object normally" do
1654
- expect(@rest).to receive(:post).with("nodes", node.for_json)
1655
- node.create
1656
- end
1657
-
1658
- it "saves the node object normally" do
1659
- expect(@rest).to receive(:put).with("nodes/example-node", node.for_json)
1660
- node.save
1661
- end
1662
- end
1663
-
1664
- # Chef Server before 12.3
1665
- context "and the Chef Server does not support policyfile attributes in node JSON" do
1666
-
1667
- let(:response_body) { %q[{"error":["Invalid key policy_name in request body"]}] }
1668
-
1669
- let(:response) do
1670
- Net::HTTPResponse.send(:response_class, "400").new("1.0", "400", "Bad Request").tap do |r|
1671
- allow(r).to receive(:body).and_return(response_body)
1672
- end
1673
- end
1674
-
1675
- let(:http_exception) do
1676
- begin
1677
- response.error!
1678
- rescue => e
1679
- e
1680
- end
1681
- end
1682
-
1683
- let(:trimmed_node) do
1684
- node.for_json.tap do |j|
1685
- j.delete("policy_name")
1686
- j.delete("policy_group")
1687
- end
1688
-
1689
- end
1690
-
1691
- it "lets the 400 pass through" do
1692
- expect(@rest).to receive(:put).and_raise(http_exception)
1693
- expect { node.save }.to raise_error(http_exception)
1694
- end
1695
-
1696
- end
1697
-
1698
- end
1699
-
1700
- end
1701
- end
1702
-
1703
- describe "method_missing handling" do
1704
- it "should have an #empty? method via Chef::Node::Attribute" do
1705
- node.default["foo"] = "bar"
1706
- expect(node.empty?).to be false
1707
- end
1708
-
1709
- it "it should correctly implement #respond_to?" do
1710
- expect(node.respond_to?(:empty?)).to be true
1711
- end
1712
-
1713
- it "it should correctly retrieve the method with #method" do
1714
- expect(node.method(:empty?)).to be_kind_of(Method)
1715
- end
1716
- end
1717
-
1718
- describe "path tracking via __path__" do
1719
- it "works through hash keys" do
1720
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1721
- expect(node["foo"]["bar"].__path__).to eql(%w{foo bar})
1722
- end
1723
-
1724
- it "works through the default level" do
1725
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1726
- expect(node.default["foo"]["bar"].__path__).to eql(%w{foo bar})
1727
- end
1728
-
1729
- it "works through arrays" do
1730
- node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1731
- expect(node["foo"][0].__path__).to eql(["foo", 0])
1732
- expect(node["foo"][0]["bar"].__path__).to eql(["foo", 0, "bar"])
1733
- end
1734
-
1735
- it "works through arrays at the default level" do
1736
- node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1737
- expect(node.default["foo"][0].__path__).to eql(["foo", 0])
1738
- expect(node.default["foo"][0]["bar"].__path__).to eql(["foo", 0, "bar"])
1739
- end
1740
-
1741
- # if we set __path__ in the initializer we'd get this wrong, this is why we
1742
- # update the path on every #[] or #[]= operator
1743
- it "works on access when the node has been rearranged" do
1744
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1745
- a = node.default["foo"]
1746
- node.default["fizz"] = a
1747
- expect(node["fizz"]["bar"].__path__).to eql(%w{fizz bar})
1748
- expect(node["foo"]["bar"].__path__).to eql(%w{foo bar})
1749
- end
1750
-
1751
- # We have a problem because the __path__ is stored on in each node, but the
1752
- # node can be wired up at multiple locations in the tree via pointers. One
1753
- # solution would be to deep-dup the value in `#[]=(key, value)` and fix the
1754
- # __path__ on all the dup'd nodes. The problem is that this would create an
1755
- # unusual situation where after assignment, you couldn't mutate the thing you
1756
- # hand a handle on. I'm not entirely positive this behavior is the correct
1757
- # thing to support, but it is more hash-like (although if we start with a hash
1758
- # then convert_value does its thing and we *do* get dup'd on assignment). This
1759
- # behavior likely makes any implementation of a deep merge cache built over the
1760
- # top of __path__ tracking have edge conditions where it will fail.
1761
- #
1762
- # Removing this support would be a breaking change. The test is included here
1763
- # because it seems most likely that someone would break this behavior while trying
1764
- # to fix __path__ behavior.
1765
- it "does not dup in the background when a node is assigned" do
1766
- # get a handle on a vividmash (can't be a hash or else we convert_value it)
1767
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1768
- a = node.default["foo"]
1769
- # assign that somewhere else in the tree
1770
- node.default["fizz"] = a
1771
- # now upate the source
1772
- a["duptest"] = true
1773
- # the tree should have been updated
1774
- expect(node.default["fizz"]["duptest"]).to be true
1775
- expect(node["fizz"]["duptest"]).to be true
1776
- end
1777
- end
1778
-
1779
- describe "root tracking via __root__" do
1780
- it "works through hash keys" do
1781
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1782
- expect(node["foo"]["bar"].__root__).to eql(node.attributes)
1783
- end
1784
-
1785
- it "works through the default level" do
1786
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1787
- expect(node.default["foo"]["bar"].__root__).to eql(node.attributes)
1788
- end
1789
-
1790
- it "works through arrays" do
1791
- node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1792
- expect(node["foo"][0].__root__).to eql(node.attributes)
1793
- expect(node["foo"][0]["bar"].__root__).to eql(node.attributes)
1794
- end
1795
-
1796
- it "works through arrays at the default level" do
1797
- node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1798
- expect(node.default["foo"][0].__root__).to eql(node.attributes)
1799
- expect(node.default["foo"][0]["bar"].__root__).to eql(node.attributes)
1800
- end
1801
- end
1802
-
1803
- describe "ways of abusing Chef 12 node state" do
1804
- # these tests abuse the top_level_breadcrumb state in Chef 12
1805
- it "derived attributes work correctly" do
1806
- node.default["v1"] = 1
1807
- expect(node["a"]).to eql(nil)
1808
- node.default["a"] = node["v1"]
1809
- expect(node["a"]).to eql(1)
1810
- end
1811
-
1812
- it "works when saving nodes to variables" do
1813
- a = node.default["a"]
1814
- expect(node["a"]).to eql({})
1815
- node.default["b"] = 0
1816
- a["key"] = 1
1817
-
1818
- expect(node["a"]["key"]).to eql(1)
1819
- end
1820
- end
1821
- end
1
+ #
2
+ # Author:: Adam Jacob (<adam@chef.io>)
3
+ # Copyright:: Copyright 2008-2018, Chef Software Inc.
4
+ # License:: Apache License, Version 2.0
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+ #
18
+
19
+ require "spec_helper"
20
+ require "ostruct"
21
+
22
+ describe Chef::Node do
23
+
24
+ let(:node) { Chef::Node.new() }
25
+ let(:platform_introspector) { node }
26
+
27
+ it_behaves_like "a platform introspector"
28
+
29
+ it "creates a node and assigns it a name" do
30
+ node = Chef::Node.build("solo-node")
31
+ expect(node.name).to eq("solo-node")
32
+ end
33
+
34
+ it "should validate the name of the node" do
35
+ expect { Chef::Node.build("solo node") }.to raise_error(Chef::Exceptions::ValidationFailed)
36
+ end
37
+
38
+ it "should be sortable" do
39
+ n1 = Chef::Node.build("alpha")
40
+ n2 = Chef::Node.build("beta")
41
+ n3 = Chef::Node.build("omega")
42
+ expect([n3, n1, n2].sort).to eq([n1, n2, n3])
43
+ end
44
+
45
+ it "should share identity only with others of the same name" do
46
+ n1 = Chef::Node.build("foo")
47
+ n2 = Chef::Node.build("foo")
48
+ n3 = Chef::Node.build("bar")
49
+ expect(n1).to eq(n2)
50
+ expect(n1).not_to eq(n3)
51
+ end
52
+
53
+ describe "when the node does not exist on the server" do
54
+ before do
55
+ response = OpenStruct.new(:code => "404")
56
+ exception = Net::HTTPServerException.new("404 not found", response)
57
+ allow(Chef::Node).to receive(:load).and_raise(exception)
58
+ node.name("created-node")
59
+ end
60
+
61
+ it "creates a new node for find_or_create" do
62
+ allow(Chef::Node).to receive(:new).and_return(node)
63
+ expect(node).to receive(:create).and_return(node)
64
+ node = Chef::Node.find_or_create("created-node")
65
+ expect(node.name).to eq("created-node")
66
+ expect(node).to equal(node)
67
+ end
68
+ end
69
+
70
+ describe "when the node exists on the server" do
71
+ before do
72
+ node.name("existing-node")
73
+ allow(Chef::Node).to receive(:load).and_return(node)
74
+ end
75
+
76
+ it "loads the node via the REST API for find_or_create" do
77
+ expect(Chef::Node.find_or_create("existing-node")).to equal(node)
78
+ end
79
+ end
80
+
81
+ describe "run_state" do
82
+ it "is an empty hash" do
83
+ expect(node.run_state).to respond_to(:keys)
84
+ expect(node.run_state).to be_empty
85
+ end
86
+ end
87
+
88
+ describe "initialize" do
89
+ it "should default to the '_default' chef_environment" do
90
+ n = Chef::Node.new
91
+ expect(n.chef_environment).to eq("_default")
92
+ end
93
+ end
94
+
95
+ describe "name" do
96
+ it "should allow you to set a name with name(something)" do
97
+ expect { node.name("latte") }.not_to raise_error
98
+ end
99
+
100
+ it "should return the name with name()" do
101
+ node.name("latte")
102
+ expect(node.name).to eql("latte")
103
+ end
104
+
105
+ it "should always have a string for name" do
106
+ expect { node.name(Hash.new) }.to raise_error(ArgumentError)
107
+ end
108
+
109
+ it "cannot be blank" do
110
+ expect { node.name("") }.to raise_error(Chef::Exceptions::ValidationFailed)
111
+ end
112
+
113
+ it "should not accept name doesn't match /^[\-[:alnum:]_:.]+$/" do
114
+ expect { node.name("space in it") }.to raise_error(Chef::Exceptions::ValidationFailed)
115
+ end
116
+ end
117
+
118
+ describe "chef_environment" do
119
+ it "should set an environment with chef_environment(something)" do
120
+ expect { node.chef_environment("latte") }.not_to raise_error
121
+ end
122
+
123
+ it "should return the chef_environment with chef_environment()" do
124
+ node.chef_environment("latte")
125
+ expect(node.chef_environment).to eq("latte")
126
+ end
127
+
128
+ it "should disallow non-strings" do
129
+ expect { node.chef_environment(Hash.new) }.to raise_error(ArgumentError)
130
+ expect { node.chef_environment(42) }.to raise_error(ArgumentError)
131
+ end
132
+
133
+ it "cannot be blank" do
134
+ expect { node.chef_environment("") }.to raise_error(Chef::Exceptions::ValidationFailed)
135
+ end
136
+ end
137
+
138
+ describe "policy_name" do
139
+
140
+ it "defaults to nil" do
141
+ expect(node.policy_name).to be_nil
142
+ end
143
+
144
+ it "sets policy_name with a regular setter" do
145
+ node.policy_name = "example-policy"
146
+ expect(node.policy_name).to eq("example-policy")
147
+ end
148
+
149
+ it "allows policy_name with every valid character" do
150
+ expect { node.policy_name = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqurstuvwxyz0123456789-_:." }.to_not raise_error
151
+ end
152
+
153
+ it "sets policy_name when given an argument" do
154
+ node.policy_name("example-policy")
155
+ expect(node.policy_name).to eq("example-policy")
156
+ end
157
+
158
+ it "sets policy_name to nil when given nil" do
159
+ node.policy_name = "example-policy"
160
+ node.policy_name = nil
161
+ expect(node.policy_name).to be_nil
162
+ end
163
+
164
+ it "disallows non-strings" do
165
+ expect { node.policy_name(Hash.new) }.to raise_error(Chef::Exceptions::ValidationFailed)
166
+ expect { node.policy_name(42) }.to raise_error(Chef::Exceptions::ValidationFailed)
167
+ end
168
+
169
+ it "cannot be blank" do
170
+ expect { node.policy_name("") }.to raise_error(Chef::Exceptions::ValidationFailed)
171
+ end
172
+ end
173
+
174
+ describe "policy_group" do
175
+
176
+ it "defaults to nil" do
177
+ expect(node.policy_group).to be_nil
178
+ end
179
+
180
+ it "sets policy_group with a regular setter" do
181
+ node.policy_group = "staging"
182
+ expect(node.policy_group).to eq("staging")
183
+ end
184
+
185
+ it "allows policy_group with every valid character" do
186
+ expect { node.policy_group = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqurstuvwxyz0123456789-_:." }.to_not raise_error
187
+ end
188
+
189
+ it "sets a policy_group with policy_group(something)" do
190
+ node.policy_group("staging")
191
+ expect(node.policy_group).to eq("staging")
192
+ end
193
+
194
+ it "sets policy_group to nil when given nil" do
195
+ node.policy_group = "staging"
196
+ node.policy_group = nil
197
+ expect(node.policy_group).to be_nil
198
+ end
199
+
200
+ it "disallows non-strings" do
201
+ expect { node.policy_group(Hash.new) }.to raise_error(Chef::Exceptions::ValidationFailed)
202
+ expect { node.policy_group(42) }.to raise_error(Chef::Exceptions::ValidationFailed)
203
+ end
204
+
205
+ it "cannot be blank" do
206
+ expect { node.policy_group("") }.to raise_error(Chef::Exceptions::ValidationFailed)
207
+ end
208
+ end
209
+
210
+ describe "attributes" do
211
+ it "should have attributes" do
212
+ expect(node.attribute).to be_a_kind_of(Hash)
213
+ end
214
+
215
+ it "should allow attributes to be accessed by name or symbol directly on node[]" do
216
+ node.default["locust"] = "something"
217
+ expect(node[:locust]).to eql("something")
218
+ expect(node["locust"]).to eql("something")
219
+ end
220
+
221
+ it "should return nil if it cannot find an attribute with node[]" do
222
+ expect(node["secret"]).to eql(nil)
223
+ end
224
+
225
+ it "does not allow you to set an attribute via node[]=" do
226
+ expect { node["secret"] = "shush" }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
227
+ end
228
+
229
+ it "should allow you to query whether an attribute exists with attribute?" do
230
+ node.default["locust"] = "something"
231
+ expect(node.attribute?("locust")).to eql(true)
232
+ expect(node.attribute?("no dice")).to eql(false)
233
+ end
234
+
235
+ it "should let you go deep with attribute?" do
236
+ node.normal["battles"]["people"]["wonkey"] = true
237
+ expect(node["battles"]["people"].attribute?("wonkey")).to eq(true)
238
+ expect(node["battles"]["people"].attribute?("snozzberry")).to eq(false)
239
+ end
240
+
241
+ it "does not allow modification of node attributes via hash methods" do
242
+ node.default["h4sh"] = { foo: "bar" }
243
+ expect { node["h4sh"].delete("foo") }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
244
+ end
245
+
246
+ it "does not allow modification of node attributes via array methods" do
247
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
248
+ node.default["array"] = []
249
+ expect { node["array"] << "boom" }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
250
+ end
251
+
252
+ it "returns merged immutable attributes for arrays" do
253
+ node.default["array"] = []
254
+ expect( node["array"].class ).to eql(Chef::Node::ImmutableArray)
255
+ end
256
+
257
+ it "returns merged immutable attributes for hashes" do
258
+ node.default["h4sh"] = {}
259
+ expect( node["h4sh"].class ).to eql(Chef::Node::ImmutableMash)
260
+ end
261
+
262
+ describe "normal attributes" do
263
+ it "should allow you to set an attribute with set, without pre-declaring a hash" do
264
+ node.normal[:snoopy][:is_a_puppy] = true
265
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
266
+ end
267
+
268
+ it "should allow you to set an attribute with set_unless" do
269
+ node.normal_unless[:snoopy][:is_a_puppy] = false
270
+ expect(node[:snoopy][:is_a_puppy]).to eq(false)
271
+ end
272
+
273
+ it "should not allow you to set an attribute with set_unless if it already exists" do
274
+ node.normal[:snoopy][:is_a_puppy] = true
275
+ node.normal_unless[:snoopy][:is_a_puppy] = false
276
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
277
+ end
278
+
279
+ it "should allow you to set an attribute with set_unless if is a nil value" do
280
+ node.attributes.normal = { snoopy: { is_a_puppy: nil } }
281
+ node.normal_unless[:snoopy][:is_a_puppy] = false
282
+ expect(node[:snoopy][:is_a_puppy]).to eq(false)
283
+ end
284
+
285
+ it "should allow you to set a value after a set_unless" do
286
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
287
+ node.normal_unless[:snoopy][:is_a_puppy] = false
288
+ node.normal[:snoopy][:is_a_puppy] = true
289
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
290
+ end
291
+
292
+ it "should let you set a value after a 'dangling' set_unless" do
293
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
294
+ node.normal[:snoopy][:is_a_puppy] = "what"
295
+ node.normal_unless[:snoopy][:is_a_puppy]
296
+ node.normal[:snoopy][:is_a_puppy] = true
297
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
298
+ end
299
+
300
+ it "should let you use tag as a convience method for the tags attribute" do
301
+ node.normal["tags"] = %w{one two}
302
+ node.tag("three", "four")
303
+ expect(node["tags"]).to eq(%w{one two three four})
304
+ end
305
+
306
+ it "normal_unless sets a value even if default or override attrs are set" do
307
+ node.default[:decontamination] = true
308
+ node.override[:decontamination] = false
309
+ node.normal_unless[:decontamination] = "foo"
310
+ expect(node.normal[:decontamination]).to eql("foo")
311
+ end
312
+
313
+ it "default_unless sets a value even if normal or override attrs are set" do
314
+ node.normal[:decontamination] = true
315
+ node.override[:decontamination] = false
316
+ node.default_unless[:decontamination] = "foo"
317
+ expect(node.default[:decontamination]).to eql("foo")
318
+ end
319
+
320
+ it "override_unless sets a value even if default or normal attrs are set" do
321
+ node.default[:decontamination] = true
322
+ node.normal[:decontamination] = false
323
+ node.override_unless[:decontamination] = "foo"
324
+ expect(node.override[:decontamination]).to eql("foo")
325
+ end
326
+
327
+ it "consume_attributes does not exhibit chef/chef/issues/6302 bug" do
328
+ node.normal["a"]["r1"] = nil
329
+ node.consume_attributes({ "a" => { "r2" => nil } })
330
+ expect(node["a"]["r1"]).to be_nil
331
+ expect(node["a"]["r2"]).to be_nil
332
+ end
333
+ end
334
+
335
+ describe "default attributes" do
336
+ it "should be set with default, without pre-declaring a hash" do
337
+ node.default[:snoopy][:is_a_puppy] = true
338
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
339
+ end
340
+
341
+ it "should allow you to set with default_unless without pre-declaring a hash" do
342
+ node.default_unless[:snoopy][:is_a_puppy] = false
343
+ expect(node[:snoopy][:is_a_puppy]).to eq(false)
344
+ end
345
+
346
+ it "should not allow you to set an attribute with default_unless if it already exists" do
347
+ node.default[:snoopy][:is_a_puppy] = true
348
+ node.default_unless[:snoopy][:is_a_puppy] = false
349
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
350
+ end
351
+
352
+ it "should allow you to set a value after a default_unless" do
353
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
354
+ node.default_unless[:snoopy][:is_a_puppy] = false
355
+ node.default[:snoopy][:is_a_puppy] = true
356
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
357
+ end
358
+
359
+ it "should allow you to set a value after a 'dangling' default_unless" do
360
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
361
+ node.default[:snoopy][:is_a_puppy] = "what"
362
+ node.default_unless[:snoopy][:is_a_puppy]
363
+ node.default[:snoopy][:is_a_puppy] = true
364
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
365
+ end
366
+
367
+ it "does not exhibit chef/chef/issues/5005 bug" do
368
+ node.env_default["a"]["r1"]["g"]["u"] = "u1"
369
+ node.default_unless["a"]["r1"]["g"]["r"] = "r"
370
+ expect(node["a"]["r1"]["g"]["u"]).to eql("u1")
371
+ end
372
+
373
+ it "default_unless correctly resets the deep merge cache" do
374
+ node.normal["tags"] = [] # this sets our top-level breadcrumb
375
+ node.default_unless["foo"]["bar"] = "NK-19V"
376
+ expect(node["foo"]["bar"]).to eql("NK-19V")
377
+ node.default_unless["foo"]["baz"] = "NK-33"
378
+ expect(node["foo"]["baz"]).to eql("NK-33")
379
+ end
380
+
381
+ it "normal_unless correctly resets the deep merge cache" do
382
+ node.normal["tags"] = [] # this sets our top-level breadcrumb
383
+ node.normal_unless["foo"]["bar"] = "NK-19V"
384
+ expect(node["foo"]["bar"]).to eql("NK-19V")
385
+ node.normal_unless["foo"]["baz"] = "NK-33"
386
+ expect(node["foo"]["baz"]).to eql("NK-33")
387
+ end
388
+
389
+ it "override_unless correctly resets the deep merge cache" do
390
+ node.normal["tags"] = [] # this sets our top-level breadcrumb
391
+ node.override_unless["foo"]["bar"] = "NK-19V"
392
+ expect(node["foo"]["bar"]).to eql("NK-19V")
393
+ node.override_unless["foo"]["baz"] = "NK-33"
394
+ expect(node["foo"]["baz"]).to eql("NK-33")
395
+ end
396
+ end
397
+
398
+ describe "override attributes" do
399
+ it "should be set with override, without pre-declaring a hash" do
400
+ node.override[:snoopy][:is_a_puppy] = true
401
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
402
+ end
403
+
404
+ it "should allow you to set with override_unless without pre-declaring a hash" do
405
+ node.override_unless[:snoopy][:is_a_puppy] = false
406
+ expect(node[:snoopy][:is_a_puppy]).to eq(false)
407
+ end
408
+
409
+ it "should not allow you to set an attribute with override_unless if it already exists" do
410
+ node.override[:snoopy][:is_a_puppy] = true
411
+ node.override_unless[:snoopy][:is_a_puppy] = false
412
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
413
+ end
414
+
415
+ it "should allow you to set a value after an override_unless" do
416
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
417
+ node.override_unless[:snoopy][:is_a_puppy] = false
418
+ node.override[:snoopy][:is_a_puppy] = true
419
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
420
+ end
421
+
422
+ it "should allow you to set a value after a 'dangling' override_unless" do
423
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
424
+ node.override_unless[:snoopy][:is_a_puppy] = "what"
425
+ node.override_unless[:snoopy][:is_a_puppy]
426
+ node.override[:snoopy][:is_a_puppy] = true
427
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
428
+ end
429
+ end
430
+
431
+ describe "globally deleting attributes" do
432
+ context "with hash values" do
433
+ before do
434
+ node.role_default["mysql"]["server"]["port"] = 1234
435
+ node.normal["mysql"]["server"]["port"] = 2345
436
+ node.override["mysql"]["server"]["port"] = 3456
437
+ end
438
+
439
+ it "deletes all the values and returns the value with the highest precidence" do
440
+ expect( node.rm("mysql", "server", "port") ).to eql(3456)
441
+ expect( node["mysql"]["server"]["port"] ).to be_nil
442
+ expect( node["mysql"]["server"] ).to eql({})
443
+ end
444
+
445
+ it "deletes nested things correctly" do
446
+ node.default["mysql"]["client"]["client_setting"] = "foo"
447
+ expect( node.rm("mysql", "server") ).to eql( { "port" => 3456 } )
448
+ expect( node["mysql"] ).to eql( { "client" => { "client_setting" => "foo" } } )
449
+ end
450
+
451
+ it "returns nil if the node attribute does not exist" do
452
+ expect( node.rm("no", "such", "thing") ).to be_nil
453
+ end
454
+
455
+ it "can delete the entire tree" do
456
+ expect( node.rm("mysql") ).to eql({ "server" => { "port" => 3456 } })
457
+ end
458
+ end
459
+
460
+ context "when trying to delete through a thing that isn't an array-like or hash-like object" do
461
+ before do
462
+ node.default["mysql"] = true
463
+ end
464
+
465
+ it "returns nil when you're two levels deeper" do
466
+ expect( node.rm("mysql", "server", "port") ).to eql(nil)
467
+ end
468
+
469
+ it "returns nil when you're one level deeper" do
470
+ expect( node.rm("mysql", "server") ).to eql(nil)
471
+ end
472
+
473
+ it "correctly deletes at the top level" do
474
+ expect( node.rm("mysql") ).to eql(true)
475
+ end
476
+ end
477
+
478
+ context "with array indexes" do
479
+ before do
480
+ node.role_default["mysql"]["server"][0]["port"] = 1234
481
+ node.normal["mysql"]["server"][0]["port"] = 2345
482
+ node.override["mysql"]["server"][0]["port"] = 3456
483
+ node.override["mysql"]["server"][1]["port"] = 3456
484
+ end
485
+
486
+ it "deletes the array element" do
487
+ expect( node.rm("mysql", "server", 0, "port") ).to eql(3456)
488
+ expect( node["mysql"]["server"][0]["port"] ).to be_nil
489
+ expect( node["mysql"]["server"][1]["port"] ).to eql(3456)
490
+ end
491
+ end
492
+
493
+ context "with real arrays" do
494
+ before do
495
+ node.role_default["mysql"]["server"] = [ {
496
+ "port" => 1234,
497
+ } ]
498
+ node.normal["mysql"]["server"] = [ {
499
+ "port" => 2345,
500
+ } ]
501
+ node.override["mysql"]["server"] = [ {
502
+ "port" => 3456,
503
+ } ]
504
+ end
505
+
506
+ it "deletes the array element" do
507
+ expect( node.rm("mysql", "server", 0, "port") ).to eql(3456)
508
+ expect( node["mysql"]["server"][0]["port"] ).to be_nil
509
+ end
510
+
511
+ it "when mistaking arrays for hashes, it considers the value removed and does nothing" do
512
+ node.rm("mysql", "server", "port")
513
+ expect(node["mysql"]["server"][0]["port"]).to eql(3456)
514
+ end
515
+ end
516
+ end
517
+
518
+ describe "granular deleting attributes" do
519
+ context "when only defaults exist" do
520
+ before do
521
+ node.role_default["mysql"]["server"]["port"] = 1234
522
+ node.default["mysql"]["server"]["port"] = 2345
523
+ node.force_default["mysql"]["server"]["port"] = 3456
524
+ end
525
+
526
+ it "returns the deleted values" do
527
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
528
+ end
529
+
530
+ it "returns nil for the combined attribues" do
531
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
532
+ expect( node["mysql"]["server"]["port"] ).to eql(nil)
533
+ end
534
+
535
+ it "returns an empty hash for the default attrs" do
536
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
537
+ # this auto-vivifies, should it?
538
+ expect( node.default_attrs["mysql"]["server"]["port"] ).to eql({})
539
+ end
540
+
541
+ it "returns an empty hash after the last key is deleted" do
542
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
543
+ expect( node["mysql"]["server"] ).to eql({})
544
+ end
545
+ end
546
+
547
+ context "when trying to delete through a thing that isn't an array-like or hash-like object" do
548
+ before do
549
+ node.default["mysql"] = true
550
+ end
551
+
552
+ it "returns nil when you're two levels deeper" do
553
+ expect( node.rm_default("mysql", "server", "port") ).to eql(nil)
554
+ end
555
+
556
+ it "returns nil when you're one level deeper" do
557
+ expect( node.rm_default("mysql", "server") ).to eql(nil)
558
+ end
559
+
560
+ it "correctly deletes at the top level" do
561
+ expect( node.rm_default("mysql") ).to eql(true)
562
+ end
563
+ end
564
+
565
+ context "when a higher precedence exists" do
566
+ before do
567
+ node.role_default["mysql"]["server"]["port"] = 1234
568
+ node.default["mysql"]["server"]["port"] = 2345
569
+ node.force_default["mysql"]["server"]["port"] = 3456
570
+
571
+ node.override["mysql"]["server"]["port"] = 9999
572
+ end
573
+
574
+ it "returns the deleted values" do
575
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
576
+ end
577
+
578
+ it "returns the higher precedence values after the delete" do
579
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
580
+ expect( node["mysql"]["server"]["port"] ).to eql(9999)
581
+ end
582
+
583
+ it "returns an empty has for the default attrs" do
584
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
585
+ # this auto-vivifies, should it?
586
+ expect( node.default_attrs["mysql"]["server"]["port"] ).to eql({})
587
+ end
588
+ end
589
+
590
+ context "when a lower precedence exists" do
591
+ before do
592
+ node.default["mysql"]["server"]["port"] = 2345
593
+ node.override["mysql"]["server"]["port"] = 9999
594
+ node.role_override["mysql"]["server"]["port"] = 9876
595
+ node.force_override["mysql"]["server"]["port"] = 6669
596
+ end
597
+
598
+ it "returns the deleted values" do
599
+ expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
600
+ end
601
+
602
+ it "returns the lower precedence levels after the delete" do
603
+ expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
604
+ expect( node["mysql"]["server"]["port"] ).to eql(2345)
605
+ end
606
+
607
+ it "returns an empty has for the override attrs" do
608
+ expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
609
+ # this auto-vivifies, should it?
610
+ expect( node.override_attrs["mysql"]["server"]["port"] ).to eql({})
611
+ end
612
+ end
613
+
614
+ it "rm_default returns nil on deleting non-existent values" do
615
+ expect( node.rm_default("no", "such", "thing") ).to be_nil
616
+ end
617
+
618
+ it "rm_normal returns nil on deleting non-existent values" do
619
+ expect( node.rm_normal("no", "such", "thing") ).to be_nil
620
+ end
621
+
622
+ it "rm_override returns nil on deleting non-existent values" do
623
+ expect( node.rm_override("no", "such", "thing") ).to be_nil
624
+ end
625
+ end
626
+
627
+ describe "granular replacing attributes" do
628
+ it "removes everything at the level of the last key" do
629
+ node.default["mysql"]["server"]["port"] = 2345
630
+
631
+ node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
632
+
633
+ expect( node["mysql"]["server"] ).to eql({ "data_dir" => "/my_raid_volume/lib/mysql" })
634
+ end
635
+
636
+ it "replaces a value at the cookbook sub-level of the atributes only" do
637
+ node.default["mysql"]["server"]["port"] = 2345
638
+ node.default["mysql"]["server"]["service_name"] = "fancypants-sql"
639
+ node.role_default["mysql"]["server"]["port"] = 1234
640
+ node.force_default["mysql"]["server"]["port"] = 3456
641
+
642
+ node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
643
+
644
+ expect( node["mysql"]["server"]["port"] ).to eql(3456)
645
+ expect( node["mysql"]["server"]["service_name"] ).to be_nil
646
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
647
+ expect( node["mysql"]["server"] ).to eql({ "port" => 3456, "data_dir" => "/my_raid_volume/lib/mysql" })
648
+ end
649
+
650
+ it "higher precedence values aren't removed" do
651
+ node.role_default["mysql"]["server"]["port"] = 1234
652
+ node.default["mysql"]["server"]["port"] = 2345
653
+ node.force_default["mysql"]["server"]["port"] = 3456
654
+ node.override["mysql"]["server"]["service_name"] = "fancypants-sql"
655
+
656
+ node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
657
+
658
+ expect( node["mysql"]["server"]["port"] ).to eql(3456)
659
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
660
+ expect( node["mysql"]["server"] ).to eql({ "service_name" => "fancypants-sql", "port" => 3456, "data_dir" => "/my_raid_volume/lib/mysql" })
661
+ end
662
+ end
663
+
664
+ describe "granular force replacing attributes" do
665
+ it "removes everything at the level of the last key" do
666
+ node.force_default["mysql"]["server"]["port"] = 2345
667
+
668
+ node.force_default!["mysql"]["server"] = {
669
+ "data_dir" => "/my_raid_volume/lib/mysql",
670
+ }
671
+
672
+ expect( node["mysql"]["server"] ).to eql({
673
+ "data_dir" => "/my_raid_volume/lib/mysql",
674
+ })
675
+ end
676
+
677
+ it "removes all values from the precedence level when setting" do
678
+ node.role_default["mysql"]["server"]["port"] = 1234
679
+ node.default["mysql"]["server"]["port"] = 2345
680
+ node.force_default["mysql"]["server"]["port"] = 3456
681
+
682
+ node.force_default!["mysql"]["server"] = {
683
+ "data_dir" => "/my_raid_volume/lib/mysql",
684
+ }
685
+
686
+ expect( node["mysql"]["server"]["port"] ).to be_nil
687
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
688
+ expect( node["mysql"]["server"] ).to eql({
689
+ "data_dir" => "/my_raid_volume/lib/mysql",
690
+ })
691
+ end
692
+
693
+ it "higher precedence levels are not removed" do
694
+ node.role_default["mysql"]["server"]["port"] = 1234
695
+ node.default["mysql"]["server"]["port"] = 2345
696
+ node.force_default["mysql"]["server"]["port"] = 3456
697
+ node.override["mysql"]["server"]["service_name"] = "fancypants-sql"
698
+
699
+ node.force_default!["mysql"]["server"] = {
700
+ "data_dir" => "/my_raid_volume/lib/mysql",
701
+ }
702
+
703
+ expect( node["mysql"]["server"]["port"] ).to be_nil
704
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
705
+ expect( node["mysql"]["server"] ).to eql({
706
+ "service_name" => "fancypants-sql",
707
+ "data_dir" => "/my_raid_volume/lib/mysql",
708
+ })
709
+ end
710
+
711
+ it "will autovivify" do
712
+ node.force_default!["mysql"]["server"] = {
713
+ "data_dir" => "/my_raid_volume/lib/mysql",
714
+ }
715
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
716
+ end
717
+
718
+ it "lower precedence levels aren't removed" do
719
+ node.role_override["mysql"]["server"]["port"] = 1234
720
+ node.override["mysql"]["server"]["port"] = 2345
721
+ node.force_override["mysql"]["server"]["port"] = 3456
722
+ node.default["mysql"]["server"]["service_name"] = "fancypants-sql"
723
+
724
+ node.force_override!["mysql"]["server"] = {
725
+ "data_dir" => "/my_raid_volume/lib/mysql",
726
+ }
727
+
728
+ expect( node["mysql"]["server"]["port"] ).to be_nil
729
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
730
+ expect( node["mysql"]["server"] ).to eql({
731
+ "service_name" => "fancypants-sql",
732
+ "data_dir" => "/my_raid_volume/lib/mysql",
733
+ })
734
+ end
735
+
736
+ it "when overwriting a non-hash/array" do
737
+ node.override["mysql"] = false
738
+ node.force_override["mysql"] = true
739
+ node.force_override!["mysql"]["server"] = {
740
+ "data_dir" => "/my_raid_volume/lib/mysql",
741
+ }
742
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
743
+ end
744
+
745
+ it "when overwriting an array with a hash" do
746
+ node.force_override["mysql"][0] = true
747
+ node.force_override!["mysql"]["server"] = {
748
+ "data_dir" => "/my_raid_volume/lib/mysql",
749
+ }
750
+ expect( node["mysql"]["server"] ).to eql({
751
+ "data_dir" => "/my_raid_volume/lib/mysql",
752
+ })
753
+ end
754
+ end
755
+
756
+ # In Chef-12.0 there is a deep_merge cache on the top level attribute which had a bug
757
+ # where it cached node[:foo] separate from node['foo']. These tests exercise those edge conditions.
758
+ #
759
+ # https://github.com/chef/chef/issues/2700
760
+ # https://github.com/chef/chef/issues/2712
761
+ # https://github.com/chef/chef/issues/2745
762
+ #
763
+ describe "deep merge attribute cache edge conditions" do
764
+ it "does not error with complicated attribute substitution" do
765
+ node.default["chef_attribute_hell"]["attr1"] = "attribute1"
766
+ node.default["chef_attribute_hell"]["attr2"] = "#{node[:chef_attribute_hell][:attr1]}/attr2"
767
+ expect { node.default["chef_attribute_hell"]["attr3"] = "#{node[:chef_attribute_hell][:attr2]}/attr3" }.not_to raise_error
768
+ end
769
+
770
+ it "caches both strings and symbols correctly" do
771
+ node.force_default[:solr][:version] = "4.10.2"
772
+ node.force_default[:solr][:data_dir] = "/opt/solr-#{node['solr'][:version]}/example/solr"
773
+ node.force_default[:solr][:xms] = "512M"
774
+ expect(node[:solr][:xms]).to eql("512M")
775
+ expect(node["solr"][:xms]).to eql("512M")
776
+ end
777
+
778
+ it "method interpolation syntax also works" do
779
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
780
+ node.default["passenger"]["version"] = "4.0.57"
781
+ node.default["passenger"]["root_path"] = "passenger-#{node['passenger']['version']}"
782
+ node.default["passenger"]["root_path_2"] = "passenger-#{node[:passenger]['version']}"
783
+ expect(node["passenger"]["root_path_2"]).to eql("passenger-4.0.57")
784
+ expect(node[:passenger]["root_path_2"]).to eql("passenger-4.0.57")
785
+ end
786
+ end
787
+
788
+ it "should raise an ArgumentError if you ask for an attribute that doesn't exist via method_missing" do
789
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
790
+ expect { node.sunshine }.to raise_error(NoMethodError)
791
+ end
792
+
793
+ it "should allow you to iterate over attributes with each_attribute" do
794
+ node.default["sunshine"] = "is bright"
795
+ node.default["canada"] = "is a nice place"
796
+ seen_attributes = Hash.new
797
+ node.each_attribute do |a, v|
798
+ seen_attributes[a] = v
799
+ end
800
+ expect(seen_attributes).to have_key("sunshine")
801
+ expect(seen_attributes).to have_key("canada")
802
+ expect(seen_attributes["sunshine"]).to eq("is bright")
803
+ expect(seen_attributes["canada"]).to eq("is a nice place")
804
+ end
805
+
806
+ describe "functional attribute API" do
807
+ # deeper functional testing of this API is in the VividMash spec tests
808
+ it "should have an exist? function" do
809
+ node.default["foo"]["bar"] = "baz"
810
+ expect(node.exist?("foo", "bar")).to be true
811
+ expect(node.exist?("bar", "foo")).to be false
812
+ end
813
+
814
+ it "should have a read function" do
815
+ node.override["foo"]["bar"] = "baz"
816
+ expect(node.read("foo", "bar")).to eql("baz")
817
+ expect(node.read("bar", "foo")).to eql(nil)
818
+ end
819
+
820
+ it "should have a read! function" do
821
+ node.override["foo"]["bar"] = "baz"
822
+ expect(node.read!("foo", "bar")).to eql("baz")
823
+ expect { node.read!("bar", "foo") }.to raise_error(Chef::Exceptions::NoSuchAttribute)
824
+ end
825
+
826
+ it "delegates write(:level) to node.level.write()" do
827
+ node.write(:default, "foo", "bar", "baz")
828
+ expect(node.default["foo"]["bar"]).to eql("baz")
829
+ end
830
+
831
+ it "delegates write!(:level) to node.level.write!()" do
832
+ node.write!(:default, "foo", "bar", "baz")
833
+ expect(node.default["foo"]["bar"]).to eql("baz")
834
+ node.default["bar"] = true
835
+ expect { node.write!(:default, "bar", "foo", "baz") }.to raise_error(Chef::Exceptions::AttributeTypeMismatch)
836
+ end
837
+
838
+ it "delegates unlink(:level) to node.level.unlink()" do
839
+ node.default["foo"]["bar"] = "baz"
840
+ expect(node.unlink(:default, "foo", "bar")).to eql("baz")
841
+ expect(node.unlink(:default, "bar", "foo")).to eql(nil)
842
+ end
843
+
844
+ it "delegates unlink!(:level) to node.level.unlink!()" do
845
+ node.default["foo"]["bar"] = "baz"
846
+ expect(node.unlink!(:default, "foo", "bar")).to eql("baz")
847
+ expect { node.unlink!(:default, "bar", "foo") }.to raise_error(Chef::Exceptions::NoSuchAttribute)
848
+ end
849
+ end
850
+ end
851
+
852
+ describe "consuming json" do
853
+
854
+ before do
855
+ @ohai_data = { :platform => "foo", :platform_version => "bar" }
856
+ end
857
+
858
+ it "consumes the run list portion of a collection of attributes and returns the remainder" do
859
+ attrs = { "run_list" => [ "role[base]", "recipe[chef::server]" ], "foo" => "bar" }
860
+ expect(node.consume_run_list(attrs)).to eq({ "foo" => "bar" })
861
+ expect(node.run_list).to eq([ "role[base]", "recipe[chef::server]" ])
862
+ end
863
+
864
+ it "sets the node chef_environment" do
865
+ attrs = { "chef_environment" => "foo_environment", "bar" => "baz" }
866
+ expect(node.consume_chef_environment(attrs)).to eq({ "bar" => "baz" })
867
+ expect(node.chef_environment).to eq("foo_environment")
868
+ expect(node["chef_environment"]).to be nil
869
+ end
870
+
871
+ it "should overwrites the run list with the run list it consumes" do
872
+ node.consume_run_list "recipes" => %w{one two}
873
+ node.consume_run_list "recipes" => [ "three" ]
874
+ expect(node.run_list).to eq([ "three" ])
875
+ end
876
+
877
+ it "should not add duplicate recipes from the json attributes" do
878
+ node.run_list << "one"
879
+ node.consume_run_list "recipes" => %w{one two three}
880
+ expect(node.run_list).to eq(%w{one two three})
881
+ end
882
+
883
+ it "doesn't change the run list if no run_list is specified in the json" do
884
+ node.run_list << "role[database]"
885
+ node.consume_run_list "foo" => "bar"
886
+ expect(node.run_list).to eq(["role[database]"])
887
+ end
888
+
889
+ it "raises an exception if you provide both recipe and run_list attributes, since this is ambiguous" do
890
+ expect { node.consume_run_list "recipes" => "stuff", "run_list" => "other_stuff" }.to raise_error(Chef::Exceptions::AmbiguousRunlistSpecification)
891
+ end
892
+
893
+ it "should add json attributes to the node" do
894
+ node.consume_external_attrs(@ohai_data, { "one" => "two", "three" => "four" })
895
+ expect(node["one"]).to eql("two")
896
+ expect(node["three"]).to eql("four")
897
+ end
898
+
899
+ it "should set the tags attribute to an empty array if it is not already defined" do
900
+ node.consume_external_attrs(@ohai_data, {})
901
+ expect(node.tags).to eql([])
902
+ end
903
+
904
+ it "should not set the tags attribute to an empty array if it is already defined" do
905
+ node.tag("radiohead")
906
+ node.consume_external_attrs(@ohai_data, {})
907
+ expect(node.tags).to eql([ "radiohead" ])
908
+ end
909
+
910
+ it "should set the tags attribute to an empty array if it is nil" do
911
+ node.attributes.normal = { "tags" => nil }
912
+ node.consume_external_attrs(@ohai_data, {})
913
+ expect(node.tags).to eql([])
914
+ end
915
+
916
+ it "should return an array if it is fed a string" do
917
+ node.normal[:tags] = "string"
918
+ node.consume_external_attrs(@ohai_data, {})
919
+ expect(node.tags).to eql(["string"])
920
+ end
921
+
922
+ it "should return an array if it is fed a hash" do
923
+ node.normal[:tags] = {}
924
+ node.consume_external_attrs(@ohai_data, {})
925
+ expect(node.tags).to eql([])
926
+ end
927
+
928
+ it "deep merges attributes instead of overwriting them" do
929
+ node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "four" } })
930
+ expect(node["one"].to_hash).to eq({ "two" => { "three" => "four" } })
931
+ node.consume_external_attrs(@ohai_data, "one" => { "abc" => "123" })
932
+ node.consume_external_attrs(@ohai_data, "one" => { "two" => { "foo" => "bar" } })
933
+ expect(node["one"].to_hash).to eq({ "two" => { "three" => "four", "foo" => "bar" }, "abc" => "123" })
934
+ end
935
+
936
+ it "gives attributes from JSON priority when deep merging" do
937
+ node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "four" } })
938
+ expect(node["one"].to_hash).to eq({ "two" => { "three" => "four" } })
939
+ node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "forty-two" } })
940
+ expect(node["one"].to_hash).to eq({ "two" => { "three" => "forty-two" } })
941
+ end
942
+
943
+ end
944
+
945
+ describe "preparing for a chef client run" do
946
+ before do
947
+ @ohai_data = { :platform => "foobuntu", :platform_version => "23.42" }
948
+ end
949
+
950
+ it "sets its platform according to platform detection" do
951
+ node.consume_external_attrs(@ohai_data, {})
952
+ expect(node.automatic_attrs[:platform]).to eq("foobuntu")
953
+ expect(node.automatic_attrs[:platform_version]).to eq("23.42")
954
+ end
955
+
956
+ it "sets the chef guid attribute correctly" do
957
+ guid = Chef::Config[:chef_guid]
958
+ Chef::Config[:chef_guid] = "test-guid-guid"
959
+ node.consume_external_attrs(@ohai_data, {})
960
+ expect(node.automatic_attrs[:chef_guid]).to eq("test-guid-guid")
961
+ Chef::Config[:chef_guid] = guid
962
+ end
963
+
964
+ it "consumes the run list from provided json attributes" do
965
+ node.consume_external_attrs(@ohai_data, { "run_list" => ["recipe[unicorn]"] })
966
+ expect(node.run_list).to eq(["recipe[unicorn]"])
967
+ end
968
+
969
+ it "saves non-runlist json attrs for later" do
970
+ expansion = Chef::RunList::RunListExpansion.new("_default", [])
971
+ allow(node.run_list).to receive(:expand).and_return(expansion)
972
+ node.consume_external_attrs(@ohai_data, { "foo" => "bar" })
973
+ node.expand!
974
+ expect(node.normal_attrs).to eq({ "foo" => "bar", "tags" => [] })
975
+ end
976
+
977
+ end
978
+
979
+ describe "when expanding its run list and merging attributes" do
980
+ before do
981
+ @environment = Chef::Environment.new.tap do |e|
982
+ e.name("rspec_env")
983
+ e.default_attributes("env default key" => "env default value")
984
+ e.override_attributes("env override key" => "env override value")
985
+ end
986
+ expect(Chef::Environment).to receive(:load).with("rspec_env").and_return(@environment)
987
+ @expansion = Chef::RunList::RunListExpansion.new("rspec_env", [])
988
+ node.chef_environment("rspec_env")
989
+ allow(node.run_list).to receive(:expand).and_return(@expansion)
990
+ end
991
+
992
+ it "sets the 'recipes' automatic attribute to the recipes in the expanded run_list" do
993
+ @expansion.recipes << "recipe[chef::client]" << "recipe[nginx::default]"
994
+ node.expand!
995
+ expect(node.automatic_attrs[:recipes]).to eq(["recipe[chef::client]", "recipe[nginx::default]"])
996
+ end
997
+
998
+ it "sets the 'roles' automatic attribute to the expanded role list" do
999
+ @expansion.instance_variable_set(:@applied_roles, { "arf" => nil, "countersnark" => nil })
1000
+ node.expand!
1001
+ expect(node.automatic_attrs[:roles].sort).to eq(%w{arf countersnark})
1002
+ end
1003
+
1004
+ it "applies default attributes from the environment as environment defaults" do
1005
+ node.expand!
1006
+ expect(node.attributes.env_default["env default key"]).to eq("env default value")
1007
+ end
1008
+
1009
+ it "applies override attributes from the environment as env overrides" do
1010
+ node.expand!
1011
+ expect(node.attributes.env_override["env override key"]).to eq("env override value")
1012
+ end
1013
+
1014
+ it "applies default attributes from roles as role defaults" do
1015
+ @expansion.default_attrs["role default key"] = "role default value"
1016
+ node.expand!
1017
+ expect(node.attributes.role_default["role default key"]).to eq("role default value")
1018
+ end
1019
+
1020
+ it "applies override attributes from roles as role overrides" do
1021
+ @expansion.override_attrs["role override key"] = "role override value"
1022
+ node.expand!
1023
+ expect(node.attributes.role_override["role override key"]).to eq("role override value")
1024
+ end
1025
+ end
1026
+
1027
+ describe "loaded_recipe" do
1028
+ it "should not add a recipe that is already in the recipes list" do
1029
+ node.automatic_attrs[:recipes] = [ "nginx::module" ]
1030
+ node.loaded_recipe(:nginx, "module")
1031
+ expect(node.automatic_attrs[:recipes].length).to eq(1)
1032
+ end
1033
+
1034
+ it "should add a recipe that is not already in the recipes list" do
1035
+ node.automatic_attrs[:recipes] = [ "nginx::other_module" ]
1036
+ node.loaded_recipe(:nginx, "module")
1037
+ expect(node.automatic_attrs[:recipes].length).to eq(2)
1038
+ expect(node.recipe?("nginx::module")).to be true
1039
+ expect(node.recipe?("nginx::other_module")).to be true
1040
+ end
1041
+ end
1042
+
1043
+ describe "when querying for recipes in the run list" do
1044
+ context "when a recipe is in the top level run list" do
1045
+ before do
1046
+ node.run_list << "recipe[nginx::module]"
1047
+ end
1048
+
1049
+ it "finds the recipe" do
1050
+ expect(node.recipe?("nginx::module")).to be true
1051
+ end
1052
+
1053
+ it "does not find a recipe not in the run list" do
1054
+ expect(node.recipe?("nginx::other_module")).to be false
1055
+ end
1056
+ end
1057
+ context "when a recipe is in the expanded run list only" do
1058
+ before do
1059
+ node.run_list << "role[base]"
1060
+ node.automatic_attrs[:recipes] = [ "nginx::module" ]
1061
+ end
1062
+
1063
+ it "finds a recipe in the expanded run list" do
1064
+ expect(node.recipe?("nginx::module")).to be true
1065
+ end
1066
+
1067
+ it "does not find a recipe that's not in the run list" do
1068
+ expect(node.recipe?("nginx::other_module")).to be false
1069
+ end
1070
+ end
1071
+ end
1072
+
1073
+ describe "when clearing computed state at the beginning of a run" do
1074
+ before do
1075
+ node.default[:foo] = "default"
1076
+ node.normal[:foo] = "normal"
1077
+ node.override[:foo] = "override"
1078
+ node.reset_defaults_and_overrides
1079
+ end
1080
+
1081
+ it "removes default attributes" do
1082
+ expect(node.default).to be_empty
1083
+ end
1084
+
1085
+ it "removes override attributes" do
1086
+ expect(node.override).to be_empty
1087
+ end
1088
+
1089
+ it "leaves normal level attributes untouched" do
1090
+ expect(node[:foo]).to eq("normal")
1091
+ end
1092
+
1093
+ end
1094
+
1095
+ describe "when merging environment attributes" do
1096
+ before do
1097
+ node.chef_environment = "rspec"
1098
+ @expansion = Chef::RunList::RunListExpansion.new("rspec", [])
1099
+ @expansion.default_attrs.replace({ :default => "from role", :d_role => "role only" })
1100
+ @expansion.override_attrs.replace({ :override => "from role", :o_role => "role only" })
1101
+
1102
+ @environment = Chef::Environment.new
1103
+ @environment.default_attributes = { :default => "from env", :d_env => "env only" }
1104
+ @environment.override_attributes = { :override => "from env", :o_env => "env only" }
1105
+ allow(Chef::Environment).to receive(:load).and_return(@environment)
1106
+ node.apply_expansion_attributes(@expansion)
1107
+ end
1108
+
1109
+ it "does not nuke role-only default attrs" do
1110
+ expect(node[:d_role]).to eq("role only")
1111
+ end
1112
+
1113
+ it "does not nuke role-only override attrs" do
1114
+ expect(node[:o_role]).to eq("role only")
1115
+ end
1116
+
1117
+ it "does not nuke env-only default attrs" do
1118
+ expect(node[:o_env]).to eq("env only")
1119
+ end
1120
+
1121
+ it "does not nuke role-only override attrs" do
1122
+ expect(node[:o_env]).to eq("env only")
1123
+ end
1124
+
1125
+ it "gives role defaults precedence over env defaults" do
1126
+ expect(node[:default]).to eq("from role")
1127
+ end
1128
+
1129
+ it "gives env overrides precedence over role overrides" do
1130
+ expect(node[:override]).to eq("from env")
1131
+ end
1132
+ end
1133
+
1134
+ describe "when evaluating attributes files" do
1135
+ before do
1136
+ @cookbook_repo = File.expand_path(File.join(CHEF_SPEC_DATA, "cookbooks"))
1137
+ @cookbook_loader = Chef::CookbookLoader.new(@cookbook_repo)
1138
+ @cookbook_loader.load_cookbooks
1139
+
1140
+ @cookbook_collection = Chef::CookbookCollection.new(@cookbook_loader.cookbooks_by_name)
1141
+
1142
+ @events = Chef::EventDispatch::Dispatcher.new
1143
+ @run_context = Chef::RunContext.new(node, @cookbook_collection, @events)
1144
+
1145
+ node.include_attribute("openldap::default")
1146
+ node.include_attribute("openldap::smokey")
1147
+ end
1148
+
1149
+ it "sets attributes from the files" do
1150
+ expect(node["ldap_server"]).to eql("ops1prod")
1151
+ expect(node["ldap_basedn"]).to eql("dc=hjksolutions,dc=com")
1152
+ expect(node["ldap_replication_password"]).to eql("forsure")
1153
+ expect(node["smokey"]).to eql("robinson")
1154
+ end
1155
+
1156
+ it "gives a sensible error when attempting to load a missing attributes file" do
1157
+ expect { node.include_attribute("nope-this::doesnt-exist") }.to raise_error(Chef::Exceptions::CookbookNotFound)
1158
+ end
1159
+ end
1160
+
1161
+ describe "roles" do
1162
+ it "should allow you to query whether or not it has a recipe applied with role?" do
1163
+ node.run_list << "role[sunrise]"
1164
+ expect(node.role?("sunrise")).to eql(true)
1165
+ expect(node.role?("not at home")).to eql(false)
1166
+ end
1167
+
1168
+ it "should allow you to set roles with arguments" do
1169
+ node.run_list << "role[one]"
1170
+ node.run_list << "role[two]"
1171
+ expect(node.role?("one")).to eql(true)
1172
+ expect(node.role?("two")).to eql(true)
1173
+ end
1174
+ end
1175
+
1176
+ describe "run_list" do
1177
+ it "should have a Chef::RunList of recipes and roles that should be applied" do
1178
+ expect(node.run_list).to be_a_kind_of(Chef::RunList)
1179
+ end
1180
+
1181
+ it "should allow you to query the run list with arguments" do
1182
+ node.run_list "recipe[baz]"
1183
+ expect(node.run_list?("recipe[baz]")).to eql(true)
1184
+ end
1185
+
1186
+ it "should allow you to set the run list with arguments" do
1187
+ node.run_list "recipe[baz]", "role[foo]"
1188
+ expect(node.run_list?("recipe[baz]")).to eql(true)
1189
+ expect(node.run_list?("role[foo]")).to eql(true)
1190
+ end
1191
+ end
1192
+
1193
+ describe "from file" do
1194
+ it "should load a node from a ruby file" do
1195
+ node.from_file(File.expand_path(File.join(CHEF_SPEC_DATA, "nodes", "test.rb")))
1196
+ expect(node.name).to eql("test.example.com-short")
1197
+ expect(node["sunshine"]).to eql("in")
1198
+ expect(node["something"]).to eql("else")
1199
+ expect(node.run_list).to eq(["operations-master", "operations-monitoring"])
1200
+ end
1201
+
1202
+ it "should raise an exception if the file cannot be found or read" do
1203
+ expect { node.from_file("/tmp/monkeydiving") }.to raise_error(IOError)
1204
+ end
1205
+ end
1206
+
1207
+ describe "update_from!" do
1208
+ before(:each) do
1209
+ node.name("orig")
1210
+ node.chef_environment("dev")
1211
+ node.default_attrs = { "one" => { "two" => "three", "four" => "five", "eight" => "nine" } }
1212
+ node.override_attrs = { "one" => { "two" => "three", "four" => "six" } }
1213
+ node.normal_attrs = { "one" => { "two" => "seven" } }
1214
+ node.run_list << "role[marxist]"
1215
+ node.run_list << "role[leninist]"
1216
+ node.run_list << "recipe[stalinist]"
1217
+
1218
+ @example = Chef::Node.new()
1219
+ @example.name("newname")
1220
+ @example.chef_environment("prod")
1221
+ @example.default_attrs = { "alpha" => { "bravo" => "charlie", "delta" => "echo" } }
1222
+ @example.override_attrs = { "alpha" => { "bravo" => "foxtrot", "delta" => "golf" } }
1223
+ @example.normal_attrs = { "alpha" => { "bravo" => "hotel" } }
1224
+ @example.run_list << "role[comedy]"
1225
+ @example.run_list << "role[drama]"
1226
+ @example.run_list << "recipe[mystery]"
1227
+ end
1228
+
1229
+ it "allows update of everything except name" do
1230
+ node.update_from!(@example)
1231
+ expect(node.name).to eq("orig")
1232
+ expect(node.chef_environment).to eq(@example.chef_environment)
1233
+ expect(node.default_attrs).to eq(@example.default_attrs)
1234
+ expect(node.override_attrs).to eq(@example.override_attrs)
1235
+ expect(node.normal_attrs).to eq(@example.normal_attrs)
1236
+ expect(node.run_list).to eq(@example.run_list)
1237
+ end
1238
+
1239
+ it "should not update the name of the node" do
1240
+ expect(node).not_to receive(:name).with(@example.name)
1241
+ node.update_from!(@example)
1242
+ end
1243
+ end
1244
+
1245
+ describe "to_hash" do
1246
+ it "should serialize itself as a hash" do
1247
+ node.chef_environment("dev")
1248
+ node.default_attrs = { "one" => { "two" => "three", "four" => "five", "eight" => "nine" } }
1249
+ node.override_attrs = { "one" => { "two" => "three", "four" => "six" } }
1250
+ node.normal_attrs = { "one" => { "two" => "seven" } }
1251
+ node.run_list << "role[marxist]"
1252
+ node.run_list << "role[leninist]"
1253
+ node.run_list << "recipe[stalinist]"
1254
+ h = node.to_hash
1255
+ expect(h["one"]["two"]).to eq("three")
1256
+ expect(h["one"]["four"]).to eq("six")
1257
+ expect(h["one"]["eight"]).to eq("nine")
1258
+ expect(h["role"]).to be_include("marxist")
1259
+ expect(h["role"]).to be_include("leninist")
1260
+ expect(h["run_list"]).to be_include("role[marxist]")
1261
+ expect(h["run_list"]).to be_include("role[leninist]")
1262
+ expect(h["run_list"]).to be_include("recipe[stalinist]")
1263
+ expect(h["chef_environment"]).to eq("dev")
1264
+ end
1265
+
1266
+ it "should return an empty array for empty run_list" do
1267
+ expect(node.to_hash["run_list"]).to eq([])
1268
+ end
1269
+ end
1270
+
1271
+ describe "converting to or from json" do
1272
+ it "should serialize itself as json", :json => true do
1273
+ node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1274
+ json = Chef::JSONCompat.to_json(node)
1275
+ expect(json).to match(/json_class/)
1276
+ expect(json).to match(/name/)
1277
+ expect(json).to match(/chef_environment/)
1278
+ expect(json).to match(/normal/)
1279
+ expect(json).to match(/default/)
1280
+ expect(json).to match(/override/)
1281
+ expect(json).to match(/run_list/)
1282
+ end
1283
+
1284
+ it "should serialize valid json with a run list", :json => true do
1285
+ #This test came about because activesupport mucks with Chef json serialization
1286
+ #Test should pass with and without Activesupport
1287
+ node.run_list << { "type" => "role", "name" => "Cthulu" }
1288
+ node.run_list << { "type" => "role", "name" => "Hastur" }
1289
+ json = Chef::JSONCompat.to_json(node)
1290
+ expect(json).to match(/\"run_list\":\[\"role\[Cthulu\]\",\"role\[Hastur\]\"\]/)
1291
+ end
1292
+
1293
+ it "should serialize the correct run list", :json => true do
1294
+ node.run_list << "role[marxist]"
1295
+ node.run_list << "role[leninist]"
1296
+ node.override_runlist << "role[stalinist]"
1297
+ expect(node.run_list).to be_include("role[stalinist]")
1298
+ json = Chef::JSONCompat.to_json(node)
1299
+ expect(json).to match(/\"run_list\":\[\"role\[marxist\]\",\"role\[leninist\]\"\]/)
1300
+ end
1301
+
1302
+ it "merges the override components into a combined override object" do
1303
+ node.attributes.role_override["role override"] = "role override"
1304
+ node.attributes.env_override["env override"] = "env override"
1305
+ node_for_json = node.for_json
1306
+ expect(node_for_json["override"]["role override"]).to eq("role override")
1307
+ expect(node_for_json["override"]["env override"]).to eq("env override")
1308
+ end
1309
+
1310
+ it "merges the default components into a combined default object" do
1311
+ node.attributes.role_default["role default"] = "role default"
1312
+ node.attributes.env_default["env default"] = "env default"
1313
+ node_for_json = node.for_json
1314
+ expect(node_for_json["default"]["role default"]).to eq("role default")
1315
+ expect(node_for_json["default"]["env default"]).to eq("env default")
1316
+ end
1317
+
1318
+ it "should deserialize itself from json", :json => true do
1319
+ node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1320
+ json = Chef::JSONCompat.to_json(node)
1321
+ serialized_node = Chef::Node.from_hash(Chef::JSONCompat.parse(json))
1322
+ expect(serialized_node).to be_a_kind_of(Chef::Node)
1323
+ expect(serialized_node.name).to eql(node.name)
1324
+ expect(serialized_node.chef_environment).to eql(node.chef_environment)
1325
+ node.each_attribute do |k, v|
1326
+ expect(serialized_node[k]).to eql(v)
1327
+ end
1328
+ expect(serialized_node.run_list).to eq(node.run_list)
1329
+ end
1330
+
1331
+ context "when policyfile attributes are not present" do
1332
+
1333
+ it "does not have a policy_name key in the json" do
1334
+ expect(node.for_json.keys).to_not include("policy_name")
1335
+ end
1336
+
1337
+ it "does not have a policy_group key in the json" do
1338
+ expect(node.for_json.keys).to_not include("policy_name")
1339
+ end
1340
+ end
1341
+
1342
+ context "when policyfile attributes are present" do
1343
+
1344
+ before do
1345
+ node.policy_name = "my-application"
1346
+ node.policy_group = "staging"
1347
+ end
1348
+
1349
+ it "includes policy_name key in the json" do
1350
+ expect(node.for_json).to have_key("policy_name")
1351
+ expect(node.for_json["policy_name"]).to eq("my-application")
1352
+ end
1353
+
1354
+ it "includes a policy_group key in the json" do
1355
+ expect(node.for_json).to have_key("policy_group")
1356
+ expect(node.for_json["policy_group"]).to eq("staging")
1357
+ end
1358
+
1359
+ it "parses policyfile attributes from JSON" do
1360
+ round_tripped_node = Chef::Node.from_hash(node.for_json)
1361
+
1362
+ expect(round_tripped_node.policy_name).to eq("my-application")
1363
+ expect(round_tripped_node.policy_group).to eq("staging")
1364
+ expect(round_tripped_node.chef_environment).to eq("staging")
1365
+ end
1366
+
1367
+ end
1368
+
1369
+ include_examples "to_json equivalent to Chef::JSONCompat.to_json" do
1370
+ let(:jsonable) do
1371
+ node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1372
+ node
1373
+ end
1374
+ end
1375
+ end
1376
+
1377
+ describe "to_s" do
1378
+ it "should turn into a string like node[name]" do
1379
+ node.name("airplane")
1380
+ expect(node.to_s).to eql("node[airplane]")
1381
+ end
1382
+ end
1383
+
1384
+ describe "api model" do
1385
+ before(:each) do
1386
+ @rest = double("Chef::ServerAPI")
1387
+ allow(Chef::ServerAPI).to receive(:new).and_return(@rest)
1388
+ @query = double("Chef::Search::Query")
1389
+ allow(Chef::Search::Query).to receive(:new).and_return(@query)
1390
+ end
1391
+
1392
+ describe "list" do
1393
+ describe "inflated" do
1394
+ it "should return a hash of node names and objects" do
1395
+ n1 = double("Chef::Node", :name => "one")
1396
+ allow(n1).to receive(:kind_of?).with(Chef::Node) { true }
1397
+ expect(@query).to receive(:search).with(:node).and_yield(n1)
1398
+ r = Chef::Node.list(true)
1399
+ expect(r["one"]).to eq(n1)
1400
+ end
1401
+ end
1402
+
1403
+ it "should return a hash of node names and urls" do
1404
+ expect(@rest).to receive(:get).and_return({ "one" => "http://foo" })
1405
+ r = Chef::Node.list
1406
+ expect(r["one"]).to eq("http://foo")
1407
+ end
1408
+ end
1409
+
1410
+ describe "load" do
1411
+ it "should load a node by name" do
1412
+ node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1413
+ json = Chef::JSONCompat.to_json(node)
1414
+ parsed = Chef::JSONCompat.parse(json)
1415
+ expect(@rest).to receive(:get).with("nodes/test.example.com").and_return(parsed)
1416
+ serialized_node = Chef::Node.load("test.example.com")
1417
+ expect(serialized_node).to be_a_kind_of(Chef::Node)
1418
+ expect(serialized_node.name).to eql(node.name)
1419
+ end
1420
+ end
1421
+
1422
+ describe "destroy" do
1423
+ it "should destroy a node" do
1424
+ expect(@rest).to receive(:delete).with("nodes/monkey").and_return("foo")
1425
+ node.name("monkey")
1426
+ node.destroy
1427
+ end
1428
+ end
1429
+
1430
+ describe "save" do
1431
+ it "should update a node if it already exists" do
1432
+ node.name("monkey")
1433
+ allow(node).to receive(:data_for_save).and_return({})
1434
+ expect(@rest).to receive(:put).with("nodes/monkey", {}).and_return("foo")
1435
+ node.save
1436
+ end
1437
+
1438
+ it "should not try and create if it can update" do
1439
+ node.name("monkey")
1440
+ allow(node).to receive(:data_for_save).and_return({})
1441
+ expect(@rest).to receive(:put).with("nodes/monkey", {}).and_return("foo")
1442
+ expect(@rest).not_to receive(:post)
1443
+ node.save
1444
+ end
1445
+
1446
+ it "should create if it cannot update" do
1447
+ node.name("monkey")
1448
+ allow(node).to receive(:data_for_save).and_return({})
1449
+ exception = double("404 error", :code => "404")
1450
+ expect(@rest).to receive(:put).and_raise(Net::HTTPServerException.new("foo", exception))
1451
+ expect(@rest).to receive(:post).with("nodes", {})
1452
+ node.save
1453
+ end
1454
+
1455
+ describe "when whyrun mode is enabled" do
1456
+ before do
1457
+ Chef::Config[:why_run] = true
1458
+ end
1459
+ after do
1460
+ Chef::Config[:why_run] = false
1461
+ end
1462
+ it "should not save" do
1463
+ node.name("monkey")
1464
+ expect(@rest).not_to receive(:put)
1465
+ expect(@rest).not_to receive(:post)
1466
+ node.save
1467
+ end
1468
+ end
1469
+
1470
+ context "with whitelisted attributes configured" do
1471
+ it "should only save whitelisted attributes (and subattributes)" do
1472
+ Chef::Config[:automatic_attribute_whitelist] = [
1473
+ ["filesystem", "/dev/disk0s2"],
1474
+ "network/interfaces/eth0",
1475
+ ]
1476
+
1477
+ data = {
1478
+ "automatic" => {
1479
+ "filesystem" => {
1480
+ "/dev/disk0s2" => { "size" => "10mb" },
1481
+ "map - autohome" => { "size" => "10mb" },
1482
+ },
1483
+ "network" => {
1484
+ "interfaces" => {
1485
+ "eth0" => {},
1486
+ "eth1" => {},
1487
+ },
1488
+ },
1489
+ },
1490
+ "default" => {}, "normal" => {}, "override" => {}
1491
+ }
1492
+
1493
+ selected_data = {
1494
+ "automatic" => {
1495
+ "filesystem" => {
1496
+ "/dev/disk0s2" => { "size" => "10mb" },
1497
+ },
1498
+ "network" => {
1499
+ "interfaces" => {
1500
+ "eth0" => {},
1501
+ },
1502
+ },
1503
+ },
1504
+ "default" => {}, "normal" => {}, "override" => {}
1505
+ }
1506
+
1507
+ node.name("picky-monkey")
1508
+ allow(node).to receive(:for_json).and_return(data)
1509
+ expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1510
+ node.save
1511
+ end
1512
+
1513
+ it "should save false-y whitelisted attributes" do
1514
+ Chef::Config[:default_attribute_whitelist] = [
1515
+ "foo/bar/baz",
1516
+ ]
1517
+
1518
+ data = {
1519
+ "default" => {
1520
+ "foo" => {
1521
+ "bar" => {
1522
+ "baz" => false,
1523
+ },
1524
+ "other" => {
1525
+ "stuff" => true,
1526
+ },
1527
+ },
1528
+ },
1529
+ }
1530
+
1531
+ selected_data = {
1532
+ "default" => {
1533
+ "foo" => {
1534
+ "bar" => {
1535
+ "baz" => false,
1536
+ },
1537
+ },
1538
+ },
1539
+ }
1540
+
1541
+ node.name("falsey-monkey")
1542
+ allow(node).to receive(:for_json).and_return(data)
1543
+ expect(@rest).to receive(:put).with("nodes/falsey-monkey", selected_data).and_return("foo")
1544
+ node.save
1545
+ end
1546
+
1547
+ it "should not save any attributes if the whitelist is empty" do
1548
+ Chef::Config[:automatic_attribute_whitelist] = []
1549
+
1550
+ data = {
1551
+ "automatic" => {
1552
+ "filesystem" => {
1553
+ "/dev/disk0s2" => { "size" => "10mb" },
1554
+ "map - autohome" => { "size" => "10mb" },
1555
+ },
1556
+ },
1557
+ "default" => {}, "normal" => {}, "override" => {}
1558
+ }
1559
+
1560
+ selected_data = {
1561
+ "automatic" => {}, "default" => {}, "normal" => {}, "override" => {}
1562
+ }
1563
+
1564
+ node.name("picky-monkey")
1565
+ allow(node).to receive(:for_json).and_return(data)
1566
+ expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1567
+ node.save
1568
+ end
1569
+ end
1570
+
1571
+ context "with blacklisted attributes configured" do
1572
+ it "should only save non-blacklisted attributes (and subattributes)" do
1573
+ Chef::Config[:automatic_attribute_blacklist] = [
1574
+ ["filesystem", "/dev/disk0s2"],
1575
+ "network/interfaces/eth0",
1576
+ ]
1577
+
1578
+ data = {
1579
+ "automatic" => {
1580
+ "filesystem" => {
1581
+ "/dev/disk0s2" => { "size" => "10mb" },
1582
+ "map - autohome" => { "size" => "10mb" },
1583
+ },
1584
+ "network" => {
1585
+ "interfaces" => {
1586
+ "eth0" => {},
1587
+ "eth1" => {},
1588
+ },
1589
+ },
1590
+ },
1591
+ "default" => {}, "normal" => {}, "override" => {}
1592
+ }
1593
+
1594
+ selected_data = {
1595
+ "automatic" => {
1596
+ "filesystem" => {
1597
+ "map - autohome" => { "size" => "10mb" },
1598
+ },
1599
+ "network" => {
1600
+ "interfaces" => {
1601
+ "eth1" => {},
1602
+ },
1603
+ },
1604
+ },
1605
+ "default" => {}, "normal" => {}, "override" => {}
1606
+ }
1607
+ node.name("picky-monkey")
1608
+ allow(node).to receive(:for_json).and_return(data)
1609
+ expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1610
+ node.save
1611
+ end
1612
+
1613
+ it "should save all attributes if the blacklist is empty" do
1614
+ Chef::Config[:automatic_attribute_blacklist] = []
1615
+
1616
+ data = {
1617
+ "automatic" => {
1618
+ "filesystem" => {
1619
+ "/dev/disk0s2" => { "size" => "10mb" },
1620
+ "map - autohome" => { "size" => "10mb" },
1621
+ },
1622
+ },
1623
+ "default" => {}, "normal" => {}, "override" => {}
1624
+ }
1625
+
1626
+ selected_data = {
1627
+ "automatic" => {
1628
+ "filesystem" => {
1629
+ "/dev/disk0s2" => { "size" => "10mb" },
1630
+ "map - autohome" => { "size" => "10mb" },
1631
+ },
1632
+ },
1633
+ "default" => {}, "normal" => {}, "override" => {}
1634
+ }
1635
+
1636
+ node.name("picky-monkey")
1637
+ allow(node).to receive(:for_json).and_return(data)
1638
+ expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1639
+ node.save
1640
+ end
1641
+ end
1642
+
1643
+ context "when policyfile attributes are present" do
1644
+
1645
+ before do
1646
+ node.name("example-node")
1647
+ node.policy_name = "my-application"
1648
+ node.policy_group = "staging"
1649
+ end
1650
+
1651
+ context "and the server supports policyfile attributes in node JSON" do
1652
+
1653
+ it "creates the object normally" do
1654
+ expect(@rest).to receive(:post).with("nodes", node.for_json)
1655
+ node.create
1656
+ end
1657
+
1658
+ it "saves the node object normally" do
1659
+ expect(@rest).to receive(:put).with("nodes/example-node", node.for_json)
1660
+ node.save
1661
+ end
1662
+ end
1663
+
1664
+ # Chef Server before 12.3
1665
+ context "and the Chef Server does not support policyfile attributes in node JSON" do
1666
+
1667
+ let(:response_body) { %q[{"error":["Invalid key policy_name in request body"]}] }
1668
+
1669
+ let(:response) do
1670
+ Net::HTTPResponse.send(:response_class, "400").new("1.0", "400", "Bad Request").tap do |r|
1671
+ allow(r).to receive(:body).and_return(response_body)
1672
+ end
1673
+ end
1674
+
1675
+ let(:http_exception) do
1676
+ begin
1677
+ response.error!
1678
+ rescue => e
1679
+ e
1680
+ end
1681
+ end
1682
+
1683
+ let(:trimmed_node) do
1684
+ node.for_json.tap do |j|
1685
+ j.delete("policy_name")
1686
+ j.delete("policy_group")
1687
+ end
1688
+
1689
+ end
1690
+
1691
+ it "lets the 400 pass through" do
1692
+ expect(@rest).to receive(:put).and_raise(http_exception)
1693
+ expect { node.save }.to raise_error(http_exception)
1694
+ end
1695
+
1696
+ end
1697
+
1698
+ end
1699
+
1700
+ end
1701
+ end
1702
+
1703
+ describe "method_missing handling" do
1704
+ it "should have an #empty? method via Chef::Node::Attribute" do
1705
+ node.default["foo"] = "bar"
1706
+ expect(node.empty?).to be false
1707
+ end
1708
+
1709
+ it "it should correctly implement #respond_to?" do
1710
+ expect(node.respond_to?(:empty?)).to be true
1711
+ end
1712
+
1713
+ it "it should correctly retrieve the method with #method" do
1714
+ expect(node.method(:empty?)).to be_kind_of(Method)
1715
+ end
1716
+ end
1717
+
1718
+ describe "path tracking via __path__" do
1719
+ it "works through hash keys" do
1720
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1721
+ expect(node["foo"]["bar"].__path__).to eql(%w{foo bar})
1722
+ end
1723
+
1724
+ it "works through the default level" do
1725
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1726
+ expect(node.default["foo"]["bar"].__path__).to eql(%w{foo bar})
1727
+ end
1728
+
1729
+ it "works through arrays" do
1730
+ node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1731
+ expect(node["foo"][0].__path__).to eql(["foo", 0])
1732
+ expect(node["foo"][0]["bar"].__path__).to eql(["foo", 0, "bar"])
1733
+ end
1734
+
1735
+ it "works through arrays at the default level" do
1736
+ node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1737
+ expect(node.default["foo"][0].__path__).to eql(["foo", 0])
1738
+ expect(node.default["foo"][0]["bar"].__path__).to eql(["foo", 0, "bar"])
1739
+ end
1740
+
1741
+ # if we set __path__ in the initializer we'd get this wrong, this is why we
1742
+ # update the path on every #[] or #[]= operator
1743
+ it "works on access when the node has been rearranged" do
1744
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1745
+ a = node.default["foo"]
1746
+ node.default["fizz"] = a
1747
+ expect(node["fizz"]["bar"].__path__).to eql(%w{fizz bar})
1748
+ expect(node["foo"]["bar"].__path__).to eql(%w{foo bar})
1749
+ end
1750
+
1751
+ # We have a problem because the __path__ is stored on in each node, but the
1752
+ # node can be wired up at multiple locations in the tree via pointers. One
1753
+ # solution would be to deep-dup the value in `#[]=(key, value)` and fix the
1754
+ # __path__ on all the dup'd nodes. The problem is that this would create an
1755
+ # unusual situation where after assignment, you couldn't mutate the thing you
1756
+ # hand a handle on. I'm not entirely positive this behavior is the correct
1757
+ # thing to support, but it is more hash-like (although if we start with a hash
1758
+ # then convert_value does its thing and we *do* get dup'd on assignment). This
1759
+ # behavior likely makes any implementation of a deep merge cache built over the
1760
+ # top of __path__ tracking have edge conditions where it will fail.
1761
+ #
1762
+ # Removing this support would be a breaking change. The test is included here
1763
+ # because it seems most likely that someone would break this behavior while trying
1764
+ # to fix __path__ behavior.
1765
+ it "does not dup in the background when a node is assigned" do
1766
+ # get a handle on a vividmash (can't be a hash or else we convert_value it)
1767
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1768
+ a = node.default["foo"]
1769
+ # assign that somewhere else in the tree
1770
+ node.default["fizz"] = a
1771
+ # now upate the source
1772
+ a["duptest"] = true
1773
+ # the tree should have been updated
1774
+ expect(node.default["fizz"]["duptest"]).to be true
1775
+ expect(node["fizz"]["duptest"]).to be true
1776
+ end
1777
+ end
1778
+
1779
+ describe "root tracking via __root__" do
1780
+ it "works through hash keys" do
1781
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1782
+ expect(node["foo"]["bar"].__root__).to eql(node.attributes)
1783
+ end
1784
+
1785
+ it "works through the default level" do
1786
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1787
+ expect(node.default["foo"]["bar"].__root__).to eql(node.attributes)
1788
+ end
1789
+
1790
+ it "works through arrays" do
1791
+ node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1792
+ expect(node["foo"][0].__root__).to eql(node.attributes)
1793
+ expect(node["foo"][0]["bar"].__root__).to eql(node.attributes)
1794
+ end
1795
+
1796
+ it "works through arrays at the default level" do
1797
+ node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1798
+ expect(node.default["foo"][0].__root__).to eql(node.attributes)
1799
+ expect(node.default["foo"][0]["bar"].__root__).to eql(node.attributes)
1800
+ end
1801
+ end
1802
+
1803
+ describe "ways of abusing Chef 12 node state" do
1804
+ # these tests abuse the top_level_breadcrumb state in Chef 12
1805
+ it "derived attributes work correctly" do
1806
+ node.default["v1"] = 1
1807
+ expect(node["a"]).to eql(nil)
1808
+ node.default["a"] = node["v1"]
1809
+ expect(node["a"]).to eql(1)
1810
+ end
1811
+
1812
+ it "works when saving nodes to variables" do
1813
+ a = node.default["a"]
1814
+ expect(node["a"]).to eql({})
1815
+ node.default["b"] = 0
1816
+ a["key"] = 1
1817
+
1818
+ expect(node["a"]["key"]).to eql(1)
1819
+ end
1820
+ end
1821
+ end