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