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