chef 12.22.1 → 12.22.3

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 (2061) hide show
  1. checksums.yaml +4 -4
  2. data/CONTRIBUTING.md +151 -151
  3. data/Gemfile +95 -95
  4. data/LICENSE +201 -201
  5. data/README.md +309 -309
  6. data/Rakefile +104 -104
  7. data/VERSION +1 -1
  8. data/acceptance/.gitignore +3 -3
  9. data/acceptance/.shared/kitchen_acceptance/.kitchen.digitalocean.yml +33 -33
  10. data/acceptance/.shared/kitchen_acceptance/.kitchen.ec2.yml +283 -283
  11. data/acceptance/.shared/kitchen_acceptance/.kitchen.vagrant.yml +59 -59
  12. data/acceptance/.shared/kitchen_acceptance/libraries/kitchen.rb +68 -68
  13. data/acceptance/.shared/kitchen_acceptance/metadata.rb +1 -1
  14. data/acceptance/Gemfile +16 -16
  15. data/acceptance/Gemfile.lock +258 -258
  16. data/acceptance/README.md +137 -137
  17. data/acceptance/basics/.acceptance/acceptance-cookbook/.gitignore +2 -2
  18. data/acceptance/basics/.acceptance/acceptance-cookbook/metadata.rb +3 -3
  19. data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  20. data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  21. data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  22. data/acceptance/basics/.kitchen.yml +4 -4
  23. data/acceptance/basics/test/integration/chef-current-install/serverspec/chef_client_spec.rb +19 -19
  24. data/acceptance/basics/test/integration/chef-current-install/serverspec/spec_helper.rb +6 -6
  25. data/acceptance/basics/test/integration/helpers/serverspec/Gemfile +8 -8
  26. data/acceptance/data-collector/.acceptance/acceptance-cookbook/.gitignore +2 -2
  27. data/acceptance/data-collector/.acceptance/acceptance-cookbook/metadata.rb +3 -3
  28. data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/destroy.rb +2 -2
  29. data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/provision.rb +2 -2
  30. data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/verify.rb +2 -2
  31. data/acceptance/data-collector/.acceptance/data-collector-test/.gitignore +16 -16
  32. data/acceptance/data-collector/.acceptance/data-collector-test/Berksfile +3 -3
  33. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/api.rb +85 -85
  34. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/apigemfile +3 -3
  35. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-both-mode.rb +4 -4
  36. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-client-mode.rb +4 -4
  37. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-no-endpoint.rb +2 -2
  38. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-solo-mode.rb +4 -4
  39. data/acceptance/data-collector/.acceptance/data-collector-test/files/default/config.ru +2 -2
  40. data/acceptance/data-collector/.acceptance/data-collector-test/metadata.rb +7 -7
  41. data/acceptance/data-collector/.acceptance/data-collector-test/recipes/default.rb +38 -38
  42. data/acceptance/data-collector/.kitchen.yml +9 -9
  43. data/acceptance/data-collector/Berksfile +3 -3
  44. data/acceptance/data-collector/test/integration/default/serverspec/default_spec.rb +204 -204
  45. data/acceptance/data-collector/test/integration/helpers/serverspec/Gemfile +8 -8
  46. data/acceptance/fips/.acceptance/acceptance-cookbook/.gitignore +2 -2
  47. data/acceptance/fips/.acceptance/acceptance-cookbook/metadata.rb +2 -2
  48. data/acceptance/fips/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  49. data/acceptance/fips/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  50. data/acceptance/fips/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  51. data/acceptance/fips/.kitchen.yml +8 -8
  52. data/acceptance/fips/test/integration/fips-integration/serverspec/Gemfile +9 -9
  53. data/acceptance/fips/test/integration/fips-integration/serverspec/fips-integration_spec.rb +52 -52
  54. data/acceptance/fips/test/integration/fips-unit-functional/serverspec/Gemfile +7 -7
  55. data/acceptance/fips/test/integration/fips-unit-functional/serverspec/fips-unit-functional_spec.rb +56 -56
  56. data/acceptance/omnitruck/.acceptance/acceptance-cookbook/.gitignore +2 -2
  57. data/acceptance/omnitruck/.acceptance/acceptance-cookbook/metadata.rb +1 -1
  58. data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  59. data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  60. data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/verify.rb +61 -61
  61. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/.gitignore +2 -2
  62. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/libraries/cookbook_kitchen.rb +43 -43
  63. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/libraries/top_cookbooks.rb +39 -39
  64. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/metadata.rb +3 -3
  65. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  66. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  67. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  68. data/acceptance/top-cookbooks/.gitignore +1 -1
  69. data/acceptance/top-cookbooks/.kitchen.chocolatey.yml +6 -6
  70. data/acceptance/top-cookbooks/.kitchen.iis.yml +4 -4
  71. data/acceptance/top-cookbooks/.kitchen.learn-the-basics-rhel.yml +7 -7
  72. data/acceptance/top-cookbooks/.kitchen.learn-the-basics-ubuntu.yml +7 -7
  73. data/acceptance/top-cookbooks/.kitchen.learn-the-basics-windows.yml +7 -7
  74. data/acceptance/top-cookbooks/.kitchen.powershell.yml +4 -4
  75. data/acceptance/top-cookbooks/.kitchen.sql_server.yml +5 -5
  76. data/acceptance/top-cookbooks/.kitchen.winbox.yml +8 -8
  77. data/acceptance/top-cookbooks/.kitchen.windows.yml +38 -38
  78. data/acceptance/trivial/.acceptance/acceptance-cookbook/.gitignore +2 -2
  79. data/acceptance/trivial/.acceptance/acceptance-cookbook/metadata.rb +2 -2
  80. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  81. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  82. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  83. data/acceptance/trivial/.kitchen.yml +7 -7
  84. data/acceptance/trivial/test/integration/chef-current-install/inspec/chef_client_spec.rb +5 -5
  85. data/acceptance/windows-service/.acceptance/acceptance-cookbook/.gitignore +2 -2
  86. data/acceptance/windows-service/.acceptance/acceptance-cookbook/metadata.rb +2 -2
  87. data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  88. data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  89. data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  90. data/acceptance/windows-service/.kitchen.yml +7 -7
  91. data/acceptance/windows-service/test/integration/chef-windows-service/inspec/chef_windows_service_spec.rb +58 -58
  92. data/bin/chef-apply +25 -25
  93. data/bin/chef-client +26 -26
  94. data/bin/chef-shell +34 -34
  95. data/bin/chef-solo +25 -25
  96. data/bin/knife +25 -25
  97. data/chef-universal-mingw32.gemspec +23 -23
  98. data/chef.gemspec +61 -61
  99. data/distro/common/html/_sources/ctl_chef_client.txt +35 -35
  100. data/distro/common/html/_sources/ctl_chef_server.txt +341 -341
  101. data/distro/common/html/_sources/ctl_chef_shell.txt +15 -15
  102. data/distro/common/html/_sources/ctl_chef_solo.txt +25 -25
  103. data/distro/common/html/_sources/index.txt +135 -135
  104. data/distro/common/html/_sources/knife.txt +74 -74
  105. data/distro/common/html/_sources/knife_bootstrap.txt +56 -56
  106. data/distro/common/html/_sources/knife_client.txt +150 -150
  107. data/distro/common/html/_sources/knife_common_options.txt +6 -6
  108. data/distro/common/html/_sources/knife_configure.txt +29 -29
  109. data/distro/common/html/_sources/knife_cookbook.txt +236 -236
  110. data/distro/common/html/_sources/knife_cookbook_site.txt +157 -157
  111. data/distro/common/html/_sources/knife_data_bag.txt +159 -159
  112. data/distro/common/html/_sources/knife_delete.txt +26 -26
  113. data/distro/common/html/_sources/knife_deps.txt +61 -61
  114. data/distro/common/html/_sources/knife_diff.txt +34 -34
  115. data/distro/common/html/_sources/knife_download.txt +44 -44
  116. data/distro/common/html/_sources/knife_edit.txt +26 -26
  117. data/distro/common/html/_sources/knife_environment.txt +158 -158
  118. data/distro/common/html/_sources/knife_exec.txt +47 -47
  119. data/distro/common/html/_sources/knife_index_rebuild.txt +20 -20
  120. data/distro/common/html/_sources/knife_list.txt +33 -33
  121. data/distro/common/html/_sources/knife_node.txt +250 -250
  122. data/distro/common/html/_sources/knife_raw.txt +35 -35
  123. data/distro/common/html/_sources/knife_recipe_list.txt +23 -23
  124. data/distro/common/html/_sources/knife_role.txt +157 -157
  125. data/distro/common/html/_sources/knife_search.txt +53 -53
  126. data/distro/common/html/_sources/knife_serve.txt +18 -18
  127. data/distro/common/html/_sources/knife_show.txt +26 -26
  128. data/distro/common/html/_sources/knife_ssh.txt +43 -43
  129. data/distro/common/html/_sources/knife_ssl_check.txt +41 -41
  130. data/distro/common/html/_sources/knife_ssl_fetch.txt +41 -41
  131. data/distro/common/html/_sources/knife_status.txt +37 -37
  132. data/distro/common/html/_sources/knife_tag.txt +69 -69
  133. data/distro/common/html/_sources/knife_upload.txt +49 -49
  134. data/distro/common/html/_sources/knife_user.txt +127 -127
  135. data/distro/common/html/_sources/knife_using.txt +43 -43
  136. data/distro/common/html/_sources/knife_xargs.txt +30 -30
  137. data/distro/common/html/_static/basic.css +536 -536
  138. data/distro/common/html/_static/doctools.js +238 -238
  139. data/distro/common/html/_static/guide.css +504 -504
  140. data/distro/common/html/_static/pygments.css +61 -61
  141. data/distro/common/html/_static/searchtools.js +621 -621
  142. data/distro/common/html/_static/underscore.js +31 -31
  143. data/distro/common/html/_static/websupport.js +808 -808
  144. data/distro/common/html/ctl_chef_client.html +269 -269
  145. data/distro/common/html/ctl_chef_server.html +727 -727
  146. data/distro/common/html/ctl_chef_shell.html +162 -162
  147. data/distro/common/html/ctl_chef_solo.html +193 -193
  148. data/distro/common/html/index.html +201 -201
  149. data/distro/common/html/knife.html +169 -169
  150. data/distro/common/html/knife_bootstrap.html +284 -284
  151. data/distro/common/html/knife_client.html +284 -284
  152. data/distro/common/html/knife_common_options.html +95 -95
  153. data/distro/common/html/knife_configure.html +104 -104
  154. data/distro/common/html/knife_cookbook.html +486 -486
  155. data/distro/common/html/knife_cookbook_site.html +375 -375
  156. data/distro/common/html/knife_data_bag.html +373 -373
  157. data/distro/common/html/knife_delete.html +92 -92
  158. data/distro/common/html/knife_deps.html +142 -142
  159. data/distro/common/html/knife_diff.html +122 -122
  160. data/distro/common/html/knife_download.html +144 -144
  161. data/distro/common/html/knife_edit.html +88 -88
  162. data/distro/common/html/knife_environment.html +322 -322
  163. data/distro/common/html/knife_exec.html +219 -219
  164. data/distro/common/html/knife_index_rebuild.html +82 -82
  165. data/distro/common/html/knife_list.html +113 -113
  166. data/distro/common/html/knife_node.html +457 -457
  167. data/distro/common/html/knife_raw.html +109 -109
  168. data/distro/common/html/knife_recipe_list.html +90 -90
  169. data/distro/common/html/knife_role.html +294 -294
  170. data/distro/common/html/knife_search.html +202 -202
  171. data/distro/common/html/knife_serve.html +78 -78
  172. data/distro/common/html/knife_show.html +103 -103
  173. data/distro/common/html/knife_ssh.html +176 -176
  174. data/distro/common/html/knife_ssl_check.html +150 -150
  175. data/distro/common/html/knife_ssl_fetch.html +150 -150
  176. data/distro/common/html/knife_status.html +143 -143
  177. data/distro/common/html/knife_tag.html +137 -137
  178. data/distro/common/html/knife_upload.html +152 -152
  179. data/distro/common/html/knife_user.html +241 -241
  180. data/distro/common/html/knife_using.html +209 -209
  181. data/distro/common/html/knife_xargs.html +121 -121
  182. data/distro/common/html/search.html +81 -81
  183. data/distro/common/man/man1/README.md +58 -58
  184. data/distro/common/man/man1/chef-shell.1 +194 -194
  185. data/distro/common/man/man1/knife-bootstrap.1 +215 -215
  186. data/distro/common/man/man1/knife-client.1 +443 -443
  187. data/distro/common/man/man1/knife-configure.1 +161 -161
  188. data/distro/common/man/man1/knife-cookbook-site.1 +552 -552
  189. data/distro/common/man/man1/knife-cookbook.1 +770 -770
  190. data/distro/common/man/man1/knife-data-bag.1 +617 -617
  191. data/distro/common/man/man1/knife-delete.1 +127 -127
  192. data/distro/common/man/man1/knife-deps.1 +246 -246
  193. data/distro/common/man/man1/knife-diff.1 +226 -226
  194. data/distro/common/man/man1/knife-download.1 +258 -258
  195. data/distro/common/man/man1/knife-edit.1 +121 -121
  196. data/distro/common/man/man1/knife-environment.1 +496 -496
  197. data/distro/common/man/man1/knife-exec.1 +362 -362
  198. data/distro/common/man/man1/knife-index-rebuild.1 +63 -63
  199. data/distro/common/man/man1/knife-list.1 +174 -174
  200. data/distro/common/man/man1/knife-node.1 +716 -716
  201. data/distro/common/man/man1/knife-raw.1 +172 -172
  202. data/distro/common/man/man1/knife-recipe-list.1 +85 -85
  203. data/distro/common/man/man1/knife-role.1 +426 -426
  204. data/distro/common/man/man1/knife-search.1 +359 -359
  205. data/distro/common/man/man1/knife-serve.1 +109 -109
  206. data/distro/common/man/man1/knife-show.1 +160 -160
  207. data/distro/common/man/man1/knife-ssh.1 +284 -284
  208. data/distro/common/man/man1/knife-ssl-check.1 +207 -207
  209. data/distro/common/man/man1/knife-ssl-fetch.1 +207 -207
  210. data/distro/common/man/man1/knife-status.1 +234 -234
  211. data/distro/common/man/man1/knife-tag.1 +189 -189
  212. data/distro/common/man/man1/knife-upload.1 +280 -280
  213. data/distro/common/man/man1/knife-user.1 +356 -356
  214. data/distro/common/man/man1/knife-xargs.1 +189 -189
  215. data/distro/common/man/man1/knife.1 +332 -332
  216. data/distro/common/man/man8/chef-apply.8 +86 -86
  217. data/distro/common/man/man8/chef-client.8 +398 -398
  218. data/distro/common/man/man8/chef-solo.8 +260 -260
  219. data/distro/common/markdown/README +3 -3
  220. data/distro/common/markdown/man1/chef-shell.mkd +195 -195
  221. data/distro/common/markdown/man1/knife-bootstrap.mkd +141 -141
  222. data/distro/common/markdown/man1/knife-client.mkd +103 -103
  223. data/distro/common/markdown/man1/knife-configure.mkd +71 -71
  224. data/distro/common/markdown/man1/knife-cookbook-site.mkd +123 -123
  225. data/distro/common/markdown/man1/knife-cookbook.mkd +263 -263
  226. data/distro/common/markdown/man1/knife-data-bag.mkd +121 -121
  227. data/distro/common/markdown/man1/knife-environment.mkd +151 -151
  228. data/distro/common/markdown/man1/knife-exec.mkd +42 -42
  229. data/distro/common/markdown/man1/knife-index.mkd +30 -30
  230. data/distro/common/markdown/man1/knife-node.mkd +130 -130
  231. data/distro/common/markdown/man1/knife-role.mkd +85 -85
  232. data/distro/common/markdown/man1/knife-search.mkd +180 -180
  233. data/distro/common/markdown/man1/knife-ssh.mkd +69 -69
  234. data/distro/common/markdown/man1/knife-status.mkd +36 -36
  235. data/distro/common/markdown/man1/knife-tag.mkd +39 -39
  236. data/distro/common/markdown/man1/knife.mkd +213 -213
  237. data/distro/common/markdown/man8/chef-client.mkd +75 -75
  238. data/distro/common/markdown/man8/chef-expander.mkd +81 -81
  239. data/distro/common/markdown/man8/chef-expanderctl.mkd +57 -57
  240. data/distro/common/markdown/man8/chef-server-webui.mkd +121 -121
  241. data/distro/common/markdown/man8/chef-server.mkd +120 -120
  242. data/distro/common/markdown/man8/chef-solo.mkd +107 -107
  243. data/distro/common/markdown/man8/chef-solr.mkd +89 -89
  244. data/distro/powershell/chef/chef.psm1 +442 -442
  245. data/lib-backcompat/chef/chef_fs/file_system/acl_entry.rb +5 -5
  246. data/lib-backcompat/chef/chef_fs/file_system/already_exists_error.rb +20 -20
  247. data/lib-backcompat/chef/chef_fs/file_system/chef_repository_file_system_root_dir.rb +5 -5
  248. data/lib-backcompat/chef/chef_fs/file_system/chef_server_root_dir.rb +5 -5
  249. data/lib-backcompat/chef/chef_fs/file_system/cookbook_frozen_error.rb +20 -20
  250. data/lib-backcompat/chef/chef_fs/file_system/default_environment_cannot_be_modified_error.rb +20 -20
  251. data/lib-backcompat/chef/chef_fs/file_system/file_system_error.rb +20 -20
  252. data/lib-backcompat/chef/chef_fs/file_system/must_delete_recursively_error.rb +20 -20
  253. data/lib-backcompat/chef/chef_fs/file_system/not_found_error.rb +20 -20
  254. data/lib-backcompat/chef/chef_fs/file_system/operation_failed_error.rb +20 -20
  255. data/lib-backcompat/chef/chef_fs/file_system/operation_not_allowed_error.rb +20 -20
  256. data/lib-backcompat/chef/chef_fs/file_system/repository/chef_repository_file_system_acls_dir.rb +5 -5
  257. data/lib-backcompat/chef/chef_fs/file_system/repository/chef_repository_file_system_client_keys_dir.rb +5 -5
  258. data/lib-backcompat/chef/chef_fs/file_system/repository/chef_repository_file_system_entry.rb +6 -6
  259. data/lib-backcompat/chef/chef_fs/file_system/repository/chef_repository_file_system_policies_dir.rb +5 -5
  260. data/lib-backcompat/chef/chef_fs/file_system/repository/file_system_root_dir.rb +34 -34
  261. data/lib/chef.rb +35 -35
  262. data/lib/chef/api_client.rb +231 -231
  263. data/lib/chef/api_client/registration.rb +192 -192
  264. data/lib/chef/api_client_v1.rb +323 -323
  265. data/lib/chef/application.rb +378 -378
  266. data/lib/chef/application/apply.rb +219 -219
  267. data/lib/chef/application/client.rb +528 -528
  268. data/lib/chef/application/exit_code.rb +233 -233
  269. data/lib/chef/application/knife.rb +216 -216
  270. data/lib/chef/application/solo.rb +379 -379
  271. data/lib/chef/application/windows_service.rb +337 -337
  272. data/lib/chef/application/windows_service_manager.rb +204 -204
  273. data/lib/chef/applications.rb +4 -4
  274. data/lib/chef/audit/audit_event_proxy.rb +93 -93
  275. data/lib/chef/audit/audit_reporter.rb +176 -176
  276. data/lib/chef/audit/control_group_data.rb +139 -139
  277. data/lib/chef/audit/logger.rb +36 -36
  278. data/lib/chef/audit/rspec_formatter.rb +37 -37
  279. data/lib/chef/audit/runner.rb +196 -196
  280. data/lib/chef/chef_class.rb +240 -240
  281. data/lib/chef/chef_fs.rb +59 -59
  282. data/lib/chef/chef_fs/chef_fs_data_store.rb +870 -870
  283. data/lib/chef/chef_fs/command_line.rb +292 -292
  284. data/lib/chef/chef_fs/config.rb +284 -284
  285. data/lib/chef/chef_fs/data_handler/acl_data_handler.rb +26 -26
  286. data/lib/chef/chef_fs/data_handler/client_data_handler.rb +39 -39
  287. data/lib/chef/chef_fs/data_handler/client_key_data_handler.rb +11 -11
  288. data/lib/chef/chef_fs/data_handler/container_data_handler.rb +35 -35
  289. data/lib/chef/chef_fs/data_handler/cookbook_data_handler.rb +38 -38
  290. data/lib/chef/chef_fs/data_handler/data_bag_item_data_handler.rb +62 -62
  291. data/lib/chef/chef_fs/data_handler/data_handler_base.rb +205 -205
  292. data/lib/chef/chef_fs/data_handler/environment_data_handler.rb +40 -40
  293. data/lib/chef/chef_fs/data_handler/group_data_handler.rb +55 -55
  294. data/lib/chef/chef_fs/data_handler/node_data_handler.rb +36 -36
  295. data/lib/chef/chef_fs/data_handler/organization_data_handler.rb +36 -36
  296. data/lib/chef/chef_fs/data_handler/organization_invites_data_handler.rb +17 -17
  297. data/lib/chef/chef_fs/data_handler/organization_members_data_handler.rb +17 -17
  298. data/lib/chef/chef_fs/data_handler/policy_data_handler.rb +48 -48
  299. data/lib/chef/chef_fs/data_handler/policy_group_data_handler.rb +33 -33
  300. data/lib/chef/chef_fs/data_handler/role_data_handler.rb +40 -40
  301. data/lib/chef/chef_fs/data_handler/user_data_handler.rb +29 -29
  302. data/lib/chef/chef_fs/file_pattern.rb +301 -301
  303. data/lib/chef/chef_fs/file_system.rb +431 -431
  304. data/lib/chef/chef_fs/file_system/base_fs_dir.rb +47 -47
  305. data/lib/chef/chef_fs/file_system/base_fs_object.rb +187 -187
  306. data/lib/chef/chef_fs/file_system/chef_server/acl_dir.rb +65 -65
  307. data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +67 -67
  308. data/lib/chef/chef_fs/file_system/chef_server/acls_dir.rb +75 -75
  309. data/lib/chef/chef_fs/file_system/chef_server/chef_server_root_dir.rb +196 -196
  310. data/lib/chef/chef_fs/file_system/chef_server/cookbook_artifact_dir.rb +38 -38
  311. data/lib/chef/chef_fs/file_system/chef_server/cookbook_artifacts_dir.rb +102 -102
  312. data/lib/chef/chef_fs/file_system/chef_server/cookbook_dir.rb +221 -221
  313. data/lib/chef/chef_fs/file_system/chef_server/cookbook_file.rb +78 -78
  314. data/lib/chef/chef_fs/file_system/chef_server/cookbook_subdir.rb +61 -61
  315. data/lib/chef/chef_fs/file_system/chef_server/cookbooks_acl_dir.rb +42 -42
  316. data/lib/chef/chef_fs/file_system/chef_server/cookbooks_dir.rb +101 -101
  317. data/lib/chef/chef_fs/file_system/chef_server/data_bag_dir.rb +76 -76
  318. data/lib/chef/chef_fs/file_system/chef_server/data_bag_entry.rb +19 -19
  319. data/lib/chef/chef_fs/file_system/chef_server/data_bags_dir.rb +67 -67
  320. data/lib/chef/chef_fs/file_system/chef_server/environments_dir.rb +56 -56
  321. data/lib/chef/chef_fs/file_system/chef_server/nodes_dir.rb +51 -51
  322. data/lib/chef/chef_fs/file_system/chef_server/org_entry.rb +35 -35
  323. data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +65 -65
  324. data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +64 -64
  325. data/lib/chef/chef_fs/file_system/chef_server/policies_acl_dir.rb +41 -41
  326. data/lib/chef/chef_fs/file_system/chef_server/policies_dir.rb +158 -158
  327. data/lib/chef/chef_fs/file_system/chef_server/policy_group_entry.rb +135 -135
  328. data/lib/chef/chef_fs/file_system/chef_server/policy_groups_dir.rb +43 -43
  329. data/lib/chef/chef_fs/file_system/chef_server/policy_revision_entry.rb +38 -38
  330. data/lib/chef/chef_fs/file_system/chef_server/rest_list_dir.rb +176 -176
  331. data/lib/chef/chef_fs/file_system/chef_server/rest_list_entry.rb +198 -198
  332. data/lib/chef/chef_fs/file_system/chef_server/versioned_cookbook_dir.rb +45 -45
  333. data/lib/chef/chef_fs/file_system/chef_server/versioned_cookbooks_dir.rb +107 -107
  334. data/lib/chef/chef_fs/file_system/exceptions.rb +105 -105
  335. data/lib/chef/chef_fs/file_system/memory/memory_dir.rb +53 -53
  336. data/lib/chef/chef_fs/file_system/memory/memory_file.rb +20 -20
  337. data/lib/chef/chef_fs/file_system/memory/memory_root.rb +23 -23
  338. data/lib/chef/chef_fs/file_system/multiplexed_dir.rb +62 -62
  339. data/lib/chef/chef_fs/file_system/nonexistent_fs_object.rb +32 -32
  340. data/lib/chef/chef_fs/file_system/repository/acl.rb +45 -45
  341. data/lib/chef/chef_fs/file_system/repository/acls_dir.rb +50 -50
  342. data/lib/chef/chef_fs/file_system/repository/acls_sub_dir.rb +38 -38
  343. data/lib/chef/chef_fs/file_system/repository/base_file.rb +155 -155
  344. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_artifact_dir.rb +41 -41
  345. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +144 -144
  346. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +177 -177
  347. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +231 -231
  348. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_versioned_cookbook_dir.rb +42 -42
  349. data/lib/chef/chef_fs/file_system/repository/client.rb +38 -38
  350. data/lib/chef/chef_fs/file_system/repository/client_key.rb +38 -38
  351. data/lib/chef/chef_fs/file_system/repository/client_keys_dir.rb +42 -42
  352. data/lib/chef/chef_fs/file_system/repository/client_keys_sub_dir.rb +38 -38
  353. data/lib/chef/chef_fs/file_system/repository/clients_dir.rb +37 -37
  354. data/lib/chef/chef_fs/file_system/repository/container.rb +38 -38
  355. data/lib/chef/chef_fs/file_system/repository/containers_dir.rb +37 -37
  356. data/lib/chef/chef_fs/file_system/repository/cookbook_artifacts_dir.rb +36 -36
  357. data/lib/chef/chef_fs/file_system/repository/cookbooks_dir.rb +51 -51
  358. data/lib/chef/chef_fs/file_system/repository/data_bag.rb +39 -39
  359. data/lib/chef/chef_fs/file_system/repository/data_bag_item.rb +38 -38
  360. data/lib/chef/chef_fs/file_system/repository/data_bags_dir.rb +39 -39
  361. data/lib/chef/chef_fs/file_system/repository/directory.rb +167 -167
  362. data/lib/chef/chef_fs/file_system/repository/environment.rb +38 -38
  363. data/lib/chef/chef_fs/file_system/repository/environments_dir.rb +37 -37
  364. data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +151 -151
  365. data/lib/chef/chef_fs/file_system/repository/group.rb +38 -38
  366. data/lib/chef/chef_fs/file_system/repository/groups_dir.rb +37 -37
  367. data/lib/chef/chef_fs/file_system/repository/node.rb +38 -38
  368. data/lib/chef/chef_fs/file_system/repository/nodes_dir.rb +59 -59
  369. data/lib/chef/chef_fs/file_system/repository/policies_dir.rb +42 -42
  370. data/lib/chef/chef_fs/file_system/repository/policy.rb +38 -38
  371. data/lib/chef/chef_fs/file_system/repository/policy_group.rb +38 -38
  372. data/lib/chef/chef_fs/file_system/repository/policy_groups_dir.rb +37 -37
  373. data/lib/chef/chef_fs/file_system/repository/role.rb +38 -38
  374. data/lib/chef/chef_fs/file_system/repository/roles_dir.rb +37 -37
  375. data/lib/chef/chef_fs/file_system/repository/user.rb +38 -38
  376. data/lib/chef/chef_fs/file_system/repository/users_dir.rb +37 -37
  377. data/lib/chef/chef_fs/file_system/repository/versioned_cookbooks_dir.rb +34 -34
  378. data/lib/chef/chef_fs/file_system_cache.rb +80 -80
  379. data/lib/chef/chef_fs/knife.rb +161 -161
  380. data/lib/chef/chef_fs/parallelizer.rb +103 -103
  381. data/lib/chef/chef_fs/parallelizer/flatten_enumerable.rb +35 -35
  382. data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +277 -277
  383. data/lib/chef/chef_fs/path_utils.rb +127 -127
  384. data/lib/chef/client.rb +1023 -1023
  385. data/lib/chef/config.rb +85 -85
  386. data/lib/chef/config_fetcher.rb +72 -72
  387. data/lib/chef/constants.rb +28 -28
  388. data/lib/chef/cookbook/chefignore.rb +74 -74
  389. data/lib/chef/cookbook/cookbook_collection.rb +63 -63
  390. data/lib/chef/cookbook/cookbook_version_loader.rb +351 -351
  391. data/lib/chef/cookbook/file_system_file_vendor.rb +58 -58
  392. data/lib/chef/cookbook/file_vendor.rb +71 -71
  393. data/lib/chef/cookbook/gem_installer.rb +84 -84
  394. data/lib/chef/cookbook/metadata.rb +912 -912
  395. data/lib/chef/cookbook/remote_file_vendor.rb +87 -87
  396. data/lib/chef/cookbook/synchronizer.rb +298 -298
  397. data/lib/chef/cookbook/syntax_check.rb +260 -260
  398. data/lib/chef/cookbook_loader.rb +200 -200
  399. data/lib/chef/cookbook_manifest.rb +290 -290
  400. data/lib/chef/cookbook_site_streaming_uploader.rb +243 -243
  401. data/lib/chef/cookbook_uploader.rb +157 -157
  402. data/lib/chef/cookbook_version.rb +637 -637
  403. data/lib/chef/daemon.rb +131 -131
  404. data/lib/chef/data_bag.rb +176 -176
  405. data/lib/chef/data_bag_item.rb +218 -218
  406. data/lib/chef/data_collector.rb +489 -489
  407. data/lib/chef/data_collector/messages.rb +98 -98
  408. data/lib/chef/data_collector/messages/helpers.rb +161 -161
  409. data/lib/chef/data_collector/resource_report.rb +123 -123
  410. data/lib/chef/decorator.rb +81 -81
  411. data/lib/chef/decorator/lazy.rb +60 -60
  412. data/lib/chef/decorator/lazy_array.rb +59 -59
  413. data/lib/chef/decorator/unchain.rb +59 -59
  414. data/lib/chef/delayed_evaluator.rb +21 -21
  415. data/lib/chef/deprecated.rb +250 -250
  416. data/lib/chef/deprecation/mixin/template.rb +48 -48
  417. data/lib/chef/deprecation/provider/cookbook_file.rb +54 -54
  418. data/lib/chef/deprecation/provider/file.rb +198 -198
  419. data/lib/chef/deprecation/provider/remote_directory.rb +52 -52
  420. data/lib/chef/deprecation/provider/remote_file.rb +85 -85
  421. data/lib/chef/deprecation/provider/template.rb +63 -63
  422. data/lib/chef/deprecation/warnings.rb +36 -36
  423. data/lib/chef/digester.rb +74 -74
  424. data/lib/chef/dsl.rb +6 -6
  425. data/lib/chef/dsl/audit.rb +51 -51
  426. data/lib/chef/dsl/chef_provisioning.rb +57 -57
  427. data/lib/chef/dsl/cheffish.rb +65 -65
  428. data/lib/chef/dsl/core.rb +52 -52
  429. data/lib/chef/dsl/data_query.rb +89 -89
  430. data/lib/chef/dsl/declare_resource.rb +295 -295
  431. data/lib/chef/dsl/definitions.rb +43 -43
  432. data/lib/chef/dsl/include_attribute.rb +61 -61
  433. data/lib/chef/dsl/include_recipe.rb +44 -44
  434. data/lib/chef/dsl/method_missing.rb +75 -75
  435. data/lib/chef/dsl/platform_introspection.rb +268 -268
  436. data/lib/chef/dsl/powershell.rb +29 -29
  437. data/lib/chef/dsl/reboot_pending.rb +64 -64
  438. data/lib/chef/dsl/recipe.rb +95 -95
  439. data/lib/chef/dsl/registry_helper.rb +63 -63
  440. data/lib/chef/dsl/resources.rb +56 -56
  441. data/lib/chef/dsl/universal.rb +50 -50
  442. data/lib/chef/encrypted_data_bag_item.rb +155 -155
  443. data/lib/chef/encrypted_data_bag_item/assertions.rb +54 -54
  444. data/lib/chef/encrypted_data_bag_item/check_encrypted.rb +56 -56
  445. data/lib/chef/encrypted_data_bag_item/decryption_failure.rb +22 -22
  446. data/lib/chef/encrypted_data_bag_item/decryptor.rb +227 -227
  447. data/lib/chef/encrypted_data_bag_item/encrypted_data_bag_item_assertions.rb +37 -37
  448. data/lib/chef/encrypted_data_bag_item/encryption_failure.rb +22 -22
  449. data/lib/chef/encrypted_data_bag_item/encryptor.rb +225 -225
  450. data/lib/chef/encrypted_data_bag_item/unacceptable_encrypted_data_bag_item_format.rb +22 -22
  451. data/lib/chef/encrypted_data_bag_item/unsupported_cipher.rb +22 -22
  452. data/lib/chef/encrypted_data_bag_item/unsupported_encrypted_data_bag_item_format.rb +22 -22
  453. data/lib/chef/environment.rb +324 -324
  454. data/lib/chef/event_dispatch/base.rb +429 -429
  455. data/lib/chef/event_dispatch/dispatcher.rb +62 -62
  456. data/lib/chef/event_dispatch/dsl.rb +65 -65
  457. data/lib/chef/event_dispatch/events_output_stream.rb +37 -37
  458. data/lib/chef/event_loggers/base.rb +62 -62
  459. data/lib/chef/event_loggers/windows_eventlog.rb +101 -101
  460. data/lib/chef/exceptions.rb +532 -532
  461. data/lib/chef/file_access_control.rb +75 -75
  462. data/lib/chef/file_access_control/unix.rb +290 -290
  463. data/lib/chef/file_access_control/windows.rb +335 -335
  464. data/lib/chef/file_cache.rb +221 -221
  465. data/lib/chef/file_content_management/content_base.rb +56 -56
  466. data/lib/chef/file_content_management/deploy.rb +37 -37
  467. data/lib/chef/file_content_management/deploy/cp.rb +48 -48
  468. data/lib/chef/file_content_management/deploy/mv_unix.rb +76 -76
  469. data/lib/chef/file_content_management/deploy/mv_windows.rb +103 -103
  470. data/lib/chef/file_content_management/tempfile.rb +107 -107
  471. data/lib/chef/formatters/base.rb +247 -247
  472. data/lib/chef/formatters/doc.rb +447 -447
  473. data/lib/chef/formatters/error_description.rb +86 -86
  474. data/lib/chef/formatters/error_inspectors.rb +19 -19
  475. data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +183 -183
  476. data/lib/chef/formatters/error_inspectors/compile_error_inspector.rb +154 -154
  477. data/lib/chef/formatters/error_inspectors/cookbook_resolve_error_inspector.rb +168 -168
  478. data/lib/chef/formatters/error_inspectors/cookbook_sync_error_inspector.rb +82 -82
  479. data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +128 -128
  480. data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +147 -147
  481. data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +124 -124
  482. data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +121 -121
  483. data/lib/chef/formatters/error_mapper.rb +85 -85
  484. data/lib/chef/formatters/indentable_output_stream.rb +170 -170
  485. data/lib/chef/formatters/minimal.rb +233 -233
  486. data/lib/chef/guard_interpreter.rb +32 -32
  487. data/lib/chef/guard_interpreter/default_guard_interpreter.rb +43 -43
  488. data/lib/chef/guard_interpreter/resource_guard_interpreter.rb +138 -138
  489. data/lib/chef/handler.rb +268 -268
  490. data/lib/chef/handler/error_report.rb +33 -33
  491. data/lib/chef/handler/json_file.rb +63 -63
  492. data/lib/chef/http.rb +489 -489
  493. data/lib/chef/http/api_versions.rb +50 -50
  494. data/lib/chef/http/auth_credentials.rb +57 -57
  495. data/lib/chef/http/authenticator.rb +106 -106
  496. data/lib/chef/http/basic_client.rb +158 -158
  497. data/lib/chef/http/cookie_jar.rb +31 -31
  498. data/lib/chef/http/cookie_manager.rb +59 -59
  499. data/lib/chef/http/decompressor.rb +142 -142
  500. data/lib/chef/http/http_request.rb +186 -186
  501. data/lib/chef/http/json_input.rb +73 -73
  502. data/lib/chef/http/json_output.rb +78 -78
  503. data/lib/chef/http/json_to_model_output.rb +34 -34
  504. data/lib/chef/http/remote_request_id.rb +46 -46
  505. data/lib/chef/http/simple.rb +40 -40
  506. data/lib/chef/http/simple_json.rb +43 -43
  507. data/lib/chef/http/socketless_chef_zero_client.rb +208 -208
  508. data/lib/chef/http/ssl_policies.rb +130 -130
  509. data/lib/chef/http/validate_content_length.rb +114 -114
  510. data/lib/chef/json_compat.rb +160 -160
  511. data/lib/chef/key.rb +272 -272
  512. data/lib/chef/knife.rb +613 -613
  513. data/lib/chef/knife/bootstrap.rb +489 -489
  514. data/lib/chef/knife/bootstrap/chef_vault_handler.rb +159 -159
  515. data/lib/chef/knife/bootstrap/client_builder.rb +208 -208
  516. data/lib/chef/knife/bootstrap/templates/README.md +11 -11
  517. data/lib/chef/knife/bootstrap/templates/chef-full.erb +236 -236
  518. data/lib/chef/knife/client_bulk_delete.rb +104 -104
  519. data/lib/chef/knife/client_create.rb +111 -111
  520. data/lib/chef/knife/client_delete.rb +63 -63
  521. data/lib/chef/knife/client_edit.rb +53 -53
  522. data/lib/chef/knife/client_key_create.rb +67 -67
  523. data/lib/chef/knife/client_key_delete.rb +76 -76
  524. data/lib/chef/knife/client_key_edit.rb +79 -79
  525. data/lib/chef/knife/client_key_list.rb +69 -69
  526. data/lib/chef/knife/client_key_show.rb +76 -76
  527. data/lib/chef/knife/client_list.rb +42 -42
  528. data/lib/chef/knife/client_reregister.rb +59 -59
  529. data/lib/chef/knife/client_show.rb +49 -49
  530. data/lib/chef/knife/configure.rb +171 -171
  531. data/lib/chef/knife/configure_client.rb +50 -50
  532. data/lib/chef/knife/cookbook_bulk_delete.rb +71 -71
  533. data/lib/chef/knife/cookbook_create.rb +462 -462
  534. data/lib/chef/knife/cookbook_delete.rb +151 -151
  535. data/lib/chef/knife/cookbook_download.rb +143 -143
  536. data/lib/chef/knife/cookbook_list.rb +47 -47
  537. data/lib/chef/knife/cookbook_metadata.rb +107 -107
  538. data/lib/chef/knife/cookbook_metadata_from_file.rb +44 -44
  539. data/lib/chef/knife/cookbook_show.rb +94 -94
  540. data/lib/chef/knife/cookbook_site_download.rb +116 -116
  541. data/lib/chef/knife/cookbook_site_install.rb +196 -196
  542. data/lib/chef/knife/cookbook_site_list.rb +65 -65
  543. data/lib/chef/knife/cookbook_site_search.rb +53 -53
  544. data/lib/chef/knife/cookbook_site_share.rb +170 -170
  545. data/lib/chef/knife/cookbook_site_show.rb +66 -66
  546. data/lib/chef/knife/cookbook_site_unshare.rb +63 -63
  547. data/lib/chef/knife/cookbook_site_vendor.rb +46 -46
  548. data/lib/chef/knife/cookbook_test.rb +95 -95
  549. data/lib/chef/knife/cookbook_upload.rb +308 -308
  550. data/lib/chef/knife/core/bootstrap_context.rb +267 -267
  551. data/lib/chef/knife/core/cookbook_scm_repo.rb +159 -159
  552. data/lib/chef/knife/core/custom_manifest_loader.rb +69 -69
  553. data/lib/chef/knife/core/gem_glob_loader.rb +138 -138
  554. data/lib/chef/knife/core/generic_presenter.rb +232 -232
  555. data/lib/chef/knife/core/hashed_command_loader.rb +99 -99
  556. data/lib/chef/knife/core/node_editor.rb +130 -130
  557. data/lib/chef/knife/core/node_presenter.rb +159 -159
  558. data/lib/chef/knife/core/object_loader.rb +115 -115
  559. data/lib/chef/knife/core/status_presenter.rb +157 -157
  560. data/lib/chef/knife/core/subcommand_loader.rb +212 -212
  561. data/lib/chef/knife/core/text_formatter.rb +85 -85
  562. data/lib/chef/knife/core/ui.rb +278 -278
  563. data/lib/chef/knife/data_bag_create.rb +80 -80
  564. data/lib/chef/knife/data_bag_delete.rb +49 -49
  565. data/lib/chef/knife/data_bag_edit.rb +74 -74
  566. data/lib/chef/knife/data_bag_from_file.rb +114 -114
  567. data/lib/chef/knife/data_bag_list.rb +42 -42
  568. data/lib/chef/knife/data_bag_secret_options.rb +142 -142
  569. data/lib/chef/knife/data_bag_show.rb +69 -69
  570. data/lib/chef/knife/delete.rb +107 -107
  571. data/lib/chef/knife/deps.rb +138 -138
  572. data/lib/chef/knife/diff.rb +68 -68
  573. data/lib/chef/knife/download.rb +68 -68
  574. data/lib/chef/knife/edit.rb +72 -72
  575. data/lib/chef/knife/environment_compare.rb +127 -127
  576. data/lib/chef/knife/environment_create.rb +53 -53
  577. data/lib/chef/knife/environment_delete.rb +45 -45
  578. data/lib/chef/knife/environment_edit.rb +45 -45
  579. data/lib/chef/knife/environment_from_file.rb +82 -82
  580. data/lib/chef/knife/environment_list.rb +42 -42
  581. data/lib/chef/knife/environment_show.rb +48 -48
  582. data/lib/chef/knife/exec.rb +87 -87
  583. data/lib/chef/knife/help.rb +101 -101
  584. data/lib/chef/knife/help_topics.rb +4 -4
  585. data/lib/chef/knife/index_rebuild.rb +133 -133
  586. data/lib/chef/knife/key_create.rb +112 -112
  587. data/lib/chef/knife/key_create_base.rb +50 -50
  588. data/lib/chef/knife/key_delete.rb +55 -55
  589. data/lib/chef/knife/key_edit.rb +118 -118
  590. data/lib/chef/knife/key_edit_base.rb +55 -55
  591. data/lib/chef/knife/key_list.rb +88 -88
  592. data/lib/chef/knife/key_list_base.rb +45 -45
  593. data/lib/chef/knife/key_show.rb +53 -53
  594. data/lib/chef/knife/list.rb +156 -156
  595. data/lib/chef/knife/node_bulk_delete.rb +74 -74
  596. data/lib/chef/knife/node_create.rb +47 -47
  597. data/lib/chef/knife/node_delete.rb +46 -46
  598. data/lib/chef/knife/node_edit.rb +70 -70
  599. data/lib/chef/knife/node_environment_set.rb +54 -54
  600. data/lib/chef/knife/node_from_file.rb +51 -51
  601. data/lib/chef/knife/node_list.rb +44 -44
  602. data/lib/chef/knife/node_run_list_add.rb +104 -104
  603. data/lib/chef/knife/node_run_list_remove.rb +67 -67
  604. data/lib/chef/knife/node_run_list_set.rb +66 -66
  605. data/lib/chef/knife/node_show.rb +61 -61
  606. data/lib/chef/knife/null.rb +10 -10
  607. data/lib/chef/knife/osc_user_create.rb +97 -97
  608. data/lib/chef/knife/osc_user_delete.rb +51 -51
  609. data/lib/chef/knife/osc_user_edit.rb +58 -58
  610. data/lib/chef/knife/osc_user_list.rb +47 -47
  611. data/lib/chef/knife/osc_user_reregister.rb +64 -64
  612. data/lib/chef/knife/osc_user_show.rb +53 -53
  613. data/lib/chef/knife/raw.rb +103 -103
  614. data/lib/chef/knife/recipe_list.rb +32 -32
  615. data/lib/chef/knife/rehash.rb +65 -65
  616. data/lib/chef/knife/role_bulk_delete.rb +65 -65
  617. data/lib/chef/knife/role_create.rb +53 -53
  618. data/lib/chef/knife/role_delete.rb +46 -46
  619. data/lib/chef/knife/role_edit.rb +45 -45
  620. data/lib/chef/knife/role_env_run_list_add.rb +86 -86
  621. data/lib/chef/knife/role_env_run_list_clear.rb +55 -55
  622. data/lib/chef/knife/role_env_run_list_remove.rb +57 -57
  623. data/lib/chef/knife/role_env_run_list_replace.rb +59 -59
  624. data/lib/chef/knife/role_env_run_list_set.rb +70 -70
  625. data/lib/chef/knife/role_from_file.rb +51 -51
  626. data/lib/chef/knife/role_list.rb +42 -42
  627. data/lib/chef/knife/role_run_list_add.rb +86 -86
  628. data/lib/chef/knife/role_run_list_clear.rb +55 -55
  629. data/lib/chef/knife/role_run_list_remove.rb +57 -57
  630. data/lib/chef/knife/role_run_list_replace.rb +59 -59
  631. data/lib/chef/knife/role_run_list_set.rb +70 -70
  632. data/lib/chef/knife/role_show.rb +49 -49
  633. data/lib/chef/knife/search.rb +201 -201
  634. data/lib/chef/knife/serve.rb +48 -48
  635. data/lib/chef/knife/show.rb +56 -56
  636. data/lib/chef/knife/ssh.rb +591 -591
  637. data/lib/chef/knife/ssl_check.rb +283 -283
  638. data/lib/chef/knife/ssl_fetch.rb +161 -161
  639. data/lib/chef/knife/status.rb +110 -110
  640. data/lib/chef/knife/supermarket_download.rb +33 -33
  641. data/lib/chef/knife/supermarket_install.rb +33 -33
  642. data/lib/chef/knife/supermarket_list.rb +33 -33
  643. data/lib/chef/knife/supermarket_search.rb +33 -33
  644. data/lib/chef/knife/supermarket_share.rb +33 -33
  645. data/lib/chef/knife/supermarket_show.rb +33 -33
  646. data/lib/chef/knife/supermarket_unshare.rb +33 -33
  647. data/lib/chef/knife/tag_create.rb +52 -52
  648. data/lib/chef/knife/tag_delete.rb +60 -60
  649. data/lib/chef/knife/tag_list.rb +47 -47
  650. data/lib/chef/knife/upload.rb +70 -70
  651. data/lib/chef/knife/user_create.rb +150 -150
  652. data/lib/chef/knife/user_delete.rb +95 -95
  653. data/lib/chef/knife/user_edit.rb +81 -81
  654. data/lib/chef/knife/user_key_create.rb +69 -69
  655. data/lib/chef/knife/user_key_delete.rb +76 -76
  656. data/lib/chef/knife/user_key_edit.rb +79 -79
  657. data/lib/chef/knife/user_key_list.rb +69 -69
  658. data/lib/chef/knife/user_key_show.rb +76 -76
  659. data/lib/chef/knife/user_list.rb +45 -45
  660. data/lib/chef/knife/user_reregister.rb +89 -89
  661. data/lib/chef/knife/user_show.rb +78 -78
  662. data/lib/chef/knife/xargs.rb +266 -266
  663. data/lib/chef/local_mode.rb +128 -128
  664. data/lib/chef/log.rb +68 -68
  665. data/lib/chef/log/syslog.rb +45 -45
  666. data/lib/chef/log/winevt.rb +99 -99
  667. data/lib/chef/mash.rb +232 -232
  668. data/lib/chef/mixin/api_version_request_handling.rb +66 -66
  669. data/lib/chef/mixin/checksum.rb +37 -37
  670. data/lib/chef/mixin/command.rb +194 -194
  671. data/lib/chef/mixin/command/unix.rb +220 -220
  672. data/lib/chef/mixin/command/windows.rb +71 -71
  673. data/lib/chef/mixin/convert_to_class_name.rb +126 -126
  674. data/lib/chef/mixin/create_path.rb +71 -71
  675. data/lib/chef/mixin/deep_merge.rb +140 -140
  676. data/lib/chef/mixin/deprecation.rb +117 -117
  677. data/lib/chef/mixin/descendants_tracker.rb +81 -81
  678. data/lib/chef/mixin/enforce_ownership_and_permissions.rb +39 -39
  679. data/lib/chef/mixin/file_class.rb +35 -35
  680. data/lib/chef/mixin/from_file.rb +50 -50
  681. data/lib/chef/mixin/get_source_from_package.rb +47 -47
  682. data/lib/chef/mixin/homebrew_user.rb +68 -68
  683. data/lib/chef/mixin/language.rb +48 -48
  684. data/lib/chef/mixin/language_include_attribute.rb +34 -34
  685. data/lib/chef/mixin/language_include_recipe.rb +31 -31
  686. data/lib/chef/mixin/lazy_module_include.rb +77 -77
  687. data/lib/chef/mixin/notifying_block.rb +51 -51
  688. data/lib/chef/mixin/params_validate.rb +489 -489
  689. data/lib/chef/mixin/path_sanity.rb +68 -68
  690. data/lib/chef/mixin/powershell_out.rb +98 -98
  691. data/lib/chef/mixin/powershell_type_coercions.rb +84 -84
  692. data/lib/chef/mixin/properties.rb +306 -306
  693. data/lib/chef/mixin/provides.rb +28 -28
  694. data/lib/chef/mixin/proxified_socket.rb +42 -42
  695. data/lib/chef/mixin/recipe_definition_dsl_core.rb +35 -35
  696. data/lib/chef/mixin/securable.rb +196 -196
  697. data/lib/chef/mixin/shell_out.rb +211 -211
  698. data/lib/chef/mixin/subclass_directive.rb +37 -37
  699. data/lib/chef/mixin/template.rb +262 -262
  700. data/lib/chef/mixin/unformatter.rb +32 -32
  701. data/lib/chef/mixin/uris.rb +42 -42
  702. data/lib/chef/mixin/versioned_api.rb +69 -69
  703. data/lib/chef/mixin/which.rb +50 -50
  704. data/lib/chef/mixin/why_run.rb +331 -331
  705. data/lib/chef/mixin/wide_string.rb +72 -72
  706. data/lib/chef/mixin/windows_architecture_helper.rb +113 -113
  707. data/lib/chef/mixin/windows_env_helper.rb +67 -67
  708. data/lib/chef/mixin/xml_escape.rb +138 -138
  709. data/lib/chef/mixins.rb +13 -13
  710. data/lib/chef/monkey_patches/net_http.rb +60 -60
  711. data/lib/chef/monkey_patches/webrick-utils.rb +51 -51
  712. data/lib/chef/monkey_patches/win32/registry.rb +86 -86
  713. data/lib/chef/monologger.rb +88 -88
  714. data/lib/chef/nil_argument.rb +3 -3
  715. data/lib/chef/node.rb +677 -677
  716. data/lib/chef/node/attribute.rb +673 -673
  717. data/lib/chef/node/attribute_collections.rb +231 -231
  718. data/lib/chef/node/common_api.rb +121 -121
  719. data/lib/chef/node/immutable_collections.rb +180 -180
  720. data/lib/chef/node/mixin/deep_merge_cache.rb +61 -61
  721. data/lib/chef/node/mixin/immutablize_array.rb +67 -67
  722. data/lib/chef/node/mixin/immutablize_hash.rb +54 -54
  723. data/lib/chef/node/mixin/state_tracking.rb +96 -96
  724. data/lib/chef/node_map.rb +238 -238
  725. data/lib/chef/null_logger.rb +72 -72
  726. data/lib/chef/org.rb +147 -147
  727. data/lib/chef/platform.rb +30 -30
  728. data/lib/chef/platform/priority_map.rb +41 -41
  729. data/lib/chef/platform/provider_handler_map.rb +29 -29
  730. data/lib/chef/platform/provider_mapping.rb +222 -222
  731. data/lib/chef/platform/provider_priority_map.rb +11 -11
  732. data/lib/chef/platform/query_helpers.rb +112 -112
  733. data/lib/chef/platform/rebooter.rb +67 -67
  734. data/lib/chef/platform/resource_handler_map.rb +29 -29
  735. data/lib/chef/platform/resource_priority_map.rb +11 -11
  736. data/lib/chef/platform/service_helpers.rb +122 -122
  737. data/lib/chef/policy_builder.rb +42 -42
  738. data/lib/chef/policy_builder/dynamic.rb +185 -185
  739. data/lib/chef/policy_builder/expand_node_object.rb +278 -278
  740. data/lib/chef/policy_builder/policyfile.rb +550 -550
  741. data/lib/chef/property.rb +731 -731
  742. data/lib/chef/provider.rb +458 -458
  743. data/lib/chef/provider/apt_repository.rb +258 -258
  744. data/lib/chef/provider/apt_update.rb +87 -87
  745. data/lib/chef/provider/batch.rb +45 -45
  746. data/lib/chef/provider/breakpoint.rb +38 -38
  747. data/lib/chef/provider/cookbook_file.rb +53 -53
  748. data/lib/chef/provider/cookbook_file/content.rb +49 -49
  749. data/lib/chef/provider/cron.rb +262 -262
  750. data/lib/chef/provider/cron/aix.rb +50 -50
  751. data/lib/chef/provider/cron/solaris.rb +22 -22
  752. data/lib/chef/provider/cron/unix.rb +83 -83
  753. data/lib/chef/provider/deploy.rb +476 -476
  754. data/lib/chef/provider/deploy/revision.rb +107 -107
  755. data/lib/chef/provider/deploy/timestamped.rb +34 -34
  756. data/lib/chef/provider/directory.rb +168 -168
  757. data/lib/chef/provider/dsc_resource.rb +213 -213
  758. data/lib/chef/provider/dsc_script.rb +189 -189
  759. data/lib/chef/provider/env.rb +169 -169
  760. data/lib/chef/provider/env/windows.rb +72 -72
  761. data/lib/chef/provider/erl_call.rb +108 -108
  762. data/lib/chef/provider/execute.rb +128 -128
  763. data/lib/chef/provider/file.rb +488 -488
  764. data/lib/chef/provider/file/content.rb +39 -39
  765. data/lib/chef/provider/git.rb +334 -334
  766. data/lib/chef/provider/group.rb +185 -185
  767. data/lib/chef/provider/group/aix.rb +79 -79
  768. data/lib/chef/provider/group/dscl.rb +173 -173
  769. data/lib/chef/provider/group/gpasswd.rb +58 -58
  770. data/lib/chef/provider/group/groupadd.rb +133 -133
  771. data/lib/chef/provider/group/groupmod.rb +123 -123
  772. data/lib/chef/provider/group/pw.rb +137 -137
  773. data/lib/chef/provider/group/suse.rb +83 -83
  774. data/lib/chef/provider/group/usermod.rb +90 -90
  775. data/lib/chef/provider/group/windows.rb +109 -109
  776. data/lib/chef/provider/http_request.rb +122 -122
  777. data/lib/chef/provider/ifconfig.rb +283 -283
  778. data/lib/chef/provider/ifconfig/aix.rb +94 -94
  779. data/lib/chef/provider/ifconfig/debian.rb +85 -85
  780. data/lib/chef/provider/ifconfig/redhat.rb +48 -48
  781. data/lib/chef/provider/launchd.rb +208 -208
  782. data/lib/chef/provider/link.rb +172 -172
  783. data/lib/chef/provider/log.rb +57 -57
  784. data/lib/chef/provider/lwrp_base.rb +98 -98
  785. data/lib/chef/provider/mdadm.rb +93 -93
  786. data/lib/chef/provider/mount.rb +171 -171
  787. data/lib/chef/provider/mount/aix.rb +180 -180
  788. data/lib/chef/provider/mount/mount.rb +270 -270
  789. data/lib/chef/provider/mount/solaris.rb +271 -271
  790. data/lib/chef/provider/mount/windows.rb +92 -92
  791. data/lib/chef/provider/noop.rb +37 -37
  792. data/lib/chef/provider/ohai.rb +51 -51
  793. data/lib/chef/provider/osx_profile.rb +257 -257
  794. data/lib/chef/provider/package.rb +656 -656
  795. data/lib/chef/provider/package/aix.rb +143 -143
  796. data/lib/chef/provider/package/apt.rb +201 -201
  797. data/lib/chef/provider/package/cab.rb +179 -179
  798. data/lib/chef/provider/package/chocolatey.rb +275 -275
  799. data/lib/chef/provider/package/dnf.rb +192 -192
  800. data/lib/chef/provider/package/dnf/dnf_helper.py +91 -91
  801. data/lib/chef/provider/package/dnf/python_helper.rb +157 -157
  802. data/lib/chef/provider/package/dnf/version.rb +56 -56
  803. data/lib/chef/provider/package/dpkg.rb +225 -225
  804. data/lib/chef/provider/package/easy_install.rb +135 -135
  805. data/lib/chef/provider/package/freebsd/base.rb +89 -89
  806. data/lib/chef/provider/package/freebsd/pkg.rb +114 -114
  807. data/lib/chef/provider/package/freebsd/pkgng.rb +76 -76
  808. data/lib/chef/provider/package/freebsd/port.rb +60 -60
  809. data/lib/chef/provider/package/homebrew.rb +138 -138
  810. data/lib/chef/provider/package/ips.rb +86 -86
  811. data/lib/chef/provider/package/macports.rb +101 -101
  812. data/lib/chef/provider/package/msu.rb +162 -162
  813. data/lib/chef/provider/package/openbsd.rb +139 -139
  814. data/lib/chef/provider/package/pacman.rb +104 -104
  815. data/lib/chef/provider/package/paludis.rb +85 -85
  816. data/lib/chef/provider/package/portage.rb +140 -140
  817. data/lib/chef/provider/package/powershell.rb +114 -114
  818. data/lib/chef/provider/package/rpm.rb +123 -123
  819. data/lib/chef/provider/package/rubygems.rb +591 -591
  820. data/lib/chef/provider/package/smartos.rb +92 -92
  821. data/lib/chef/provider/package/solaris.rb +138 -138
  822. data/lib/chef/provider/package/windows.rb +271 -271
  823. data/lib/chef/provider/package/windows/exe.rb +115 -115
  824. data/lib/chef/provider/package/windows/msi.rb +94 -94
  825. data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +87 -87
  826. data/lib/chef/provider/package/yum.rb +536 -536
  827. data/lib/chef/provider/package/yum/rpm_utils.rb +642 -642
  828. data/lib/chef/provider/package/yum/yum-dump.py +307 -307
  829. data/lib/chef/provider/package/yum/yum_cache.rb +376 -376
  830. data/lib/chef/provider/package/zypper.rb +163 -163
  831. data/lib/chef/provider/powershell_script.rb +223 -223
  832. data/lib/chef/provider/reboot.rb +70 -70
  833. data/lib/chef/provider/registry_key.rb +182 -182
  834. data/lib/chef/provider/remote_directory.rb +283 -283
  835. data/lib/chef/provider/remote_file.rb +53 -53
  836. data/lib/chef/provider/remote_file/cache_control_data.rb +195 -195
  837. data/lib/chef/provider/remote_file/content.rb +81 -81
  838. data/lib/chef/provider/remote_file/fetcher.rb +57 -57
  839. data/lib/chef/provider/remote_file/ftp.rb +172 -172
  840. data/lib/chef/provider/remote_file/http.rb +135 -135
  841. data/lib/chef/provider/remote_file/local_file.rb +60 -60
  842. data/lib/chef/provider/remote_file/network_file.rb +48 -48
  843. data/lib/chef/provider/remote_file/sftp.rb +105 -105
  844. data/lib/chef/provider/resource_update.rb +52 -52
  845. data/lib/chef/provider/route.rb +231 -231
  846. data/lib/chef/provider/ruby_block.rb +44 -44
  847. data/lib/chef/provider/script.rb +121 -121
  848. data/lib/chef/provider/service.rb +259 -259
  849. data/lib/chef/provider/service/aix.rb +129 -129
  850. data/lib/chef/provider/service/aixinit.rb +117 -117
  851. data/lib/chef/provider/service/arch.rb +118 -118
  852. data/lib/chef/provider/service/debian.rb +182 -182
  853. data/lib/chef/provider/service/freebsd.rb +195 -195
  854. data/lib/chef/provider/service/gentoo.rb +71 -71
  855. data/lib/chef/provider/service/init.rb +94 -94
  856. data/lib/chef/provider/service/insserv.rb +59 -59
  857. data/lib/chef/provider/service/invokercd.rb +41 -41
  858. data/lib/chef/provider/service/macosx.rb +250 -250
  859. data/lib/chef/provider/service/openbsd.rb +217 -217
  860. data/lib/chef/provider/service/redhat.rb +126 -126
  861. data/lib/chef/provider/service/simple.rb +176 -176
  862. data/lib/chef/provider/service/solaris.rb +122 -122
  863. data/lib/chef/provider/service/systemd.rb +188 -188
  864. data/lib/chef/provider/service/upstart.rb +261 -261
  865. data/lib/chef/provider/service/windows.rb +313 -313
  866. data/lib/chef/provider/subversion.rb +233 -233
  867. data/lib/chef/provider/support/yum_repo.erb +132 -132
  868. data/lib/chef/provider/systemd_unit.rb +240 -240
  869. data/lib/chef/provider/template.rb +65 -65
  870. data/lib/chef/provider/template/content.rb +70 -70
  871. data/lib/chef/provider/template_finder.rb +62 -62
  872. data/lib/chef/provider/user.rb +220 -220
  873. data/lib/chef/provider/user/aix.rb +99 -99
  874. data/lib/chef/provider/user/dscl.rb +719 -719
  875. data/lib/chef/provider/user/linux.rb +125 -125
  876. data/lib/chef/provider/user/pw.rb +111 -111
  877. data/lib/chef/provider/user/solaris.rb +129 -129
  878. data/lib/chef/provider/user/useradd.rb +158 -158
  879. data/lib/chef/provider/user/windows.rb +125 -125
  880. data/lib/chef/provider/whyrun_safe_ruby_block.rb +32 -32
  881. data/lib/chef/provider/windows_script.rb +75 -75
  882. data/lib/chef/provider/yum_repository.rb +120 -120
  883. data/lib/chef/provider_resolver.rb +172 -172
  884. data/lib/chef/providers.rb +152 -152
  885. data/lib/chef/recipe.rb +108 -108
  886. data/lib/chef/request_id.rb +37 -37
  887. data/lib/chef/reserved_names.rb +9 -9
  888. data/lib/chef/resource.rb +1626 -1626
  889. data/lib/chef/resource/action_class.rb +94 -94
  890. data/lib/chef/resource/apt_package.rb +32 -32
  891. data/lib/chef/resource/apt_repository.rb +46 -46
  892. data/lib/chef/resource/apt_update.rb +33 -33
  893. data/lib/chef/resource/bash.rb +33 -33
  894. data/lib/chef/resource/batch.rb +33 -33
  895. data/lib/chef/resource/bff_package.rb +27 -27
  896. data/lib/chef/resource/breakpoint.rb +32 -32
  897. data/lib/chef/resource/cab_package.rb +44 -44
  898. data/lib/chef/resource/chef_gem.rb +50 -50
  899. data/lib/chef/resource/chocolatey_package.rb +40 -40
  900. data/lib/chef/resource/conditional.rb +135 -135
  901. data/lib/chef/resource/conditional_action_not_nothing.rb +48 -48
  902. data/lib/chef/resource/cookbook_file.rb +49 -49
  903. data/lib/chef/resource/cron.rb +216 -216
  904. data/lib/chef/resource/csh.rb +33 -33
  905. data/lib/chef/resource/deploy.rb +443 -443
  906. data/lib/chef/resource/deploy_revision.rb +31 -31
  907. data/lib/chef/resource/directory.rb +62 -62
  908. data/lib/chef/resource/dnf_package.rb +74 -74
  909. data/lib/chef/resource/dpkg_package.rb +30 -30
  910. data/lib/chef/resource/dsc_resource.rb +129 -129
  911. data/lib/chef/resource/dsc_script.rb +140 -140
  912. data/lib/chef/resource/easy_install_package.rb +32 -32
  913. data/lib/chef/resource/env.rb +65 -65
  914. data/lib/chef/resource/erl_call.rb +85 -85
  915. data/lib/chef/resource/execute.rb +236 -236
  916. data/lib/chef/resource/file.rb +88 -88
  917. data/lib/chef/resource/file/verification.rb +130 -130
  918. data/lib/chef/resource/file/verification/systemd_unit.rb +67 -67
  919. data/lib/chef/resource/freebsd_package.rb +62 -62
  920. data/lib/chef/resource/gem_package.rb +41 -41
  921. data/lib/chef/resource/git.rb +44 -44
  922. data/lib/chef/resource/group.rb +102 -102
  923. data/lib/chef/resource/homebrew_package.rb +34 -34
  924. data/lib/chef/resource/http_request.rb +66 -66
  925. data/lib/chef/resource/ifconfig.rb +147 -147
  926. data/lib/chef/resource/ips_package.rb +34 -34
  927. data/lib/chef/resource/ksh.rb +32 -32
  928. data/lib/chef/resource/launchd.rb +156 -156
  929. data/lib/chef/resource/link.rb +107 -107
  930. data/lib/chef/resource/log.rb +76 -76
  931. data/lib/chef/resource/lwrp_base.rb +124 -124
  932. data/lib/chef/resource/macosx_service.rb +58 -58
  933. data/lib/chef/resource/macports_package.rb +27 -27
  934. data/lib/chef/resource/mdadm.rb +112 -112
  935. data/lib/chef/resource/mount.rb +187 -187
  936. data/lib/chef/resource/msu_package.rb +47 -47
  937. data/lib/chef/resource/ohai.rb +33 -33
  938. data/lib/chef/resource/openbsd_package.rb +35 -35
  939. data/lib/chef/resource/osx_profile.rb +74 -74
  940. data/lib/chef/resource/package.rb +47 -47
  941. data/lib/chef/resource/pacman_package.rb +28 -28
  942. data/lib/chef/resource/paludis_package.rb +33 -33
  943. data/lib/chef/resource/perl.rb +32 -32
  944. data/lib/chef/resource/portage_package.rb +32 -32
  945. data/lib/chef/resource/powershell_package.rb +41 -41
  946. data/lib/chef/resource/powershell_script.rb +50 -50
  947. data/lib/chef/resource/python.rb +31 -31
  948. data/lib/chef/resource/reboot.rb +48 -48
  949. data/lib/chef/resource/registry_key.rb +144 -144
  950. data/lib/chef/resource/remote_directory.rb +122 -122
  951. data/lib/chef/resource/remote_file.rb +158 -158
  952. data/lib/chef/resource/resource_notification.rb +122 -122
  953. data/lib/chef/resource/route.rb +137 -137
  954. data/lib/chef/resource/rpm_package.rb +32 -32
  955. data/lib/chef/resource/ruby.rb +31 -31
  956. data/lib/chef/resource/ruby_block.rb +53 -53
  957. data/lib/chef/resource/scm.rb +179 -179
  958. data/lib/chef/resource/script.rb +74 -74
  959. data/lib/chef/resource/service.rb +217 -217
  960. data/lib/chef/resource/smartos_package.rb +29 -29
  961. data/lib/chef/resource/solaris_package.rb +31 -31
  962. data/lib/chef/resource/subversion.rb +44 -44
  963. data/lib/chef/resource/systemd_unit.rb +63 -63
  964. data/lib/chef/resource/template.rb +215 -215
  965. data/lib/chef/resource/timestamped_deploy.rb +26 -26
  966. data/lib/chef/resource/user.rb +174 -174
  967. data/lib/chef/resource/user/aix_user.rb +31 -31
  968. data/lib/chef/resource/user/dscl_user.rb +31 -31
  969. data/lib/chef/resource/user/linux_user.rb +41 -41
  970. data/lib/chef/resource/user/pw_user.rb +31 -31
  971. data/lib/chef/resource/user/solaris_user.rb +31 -31
  972. data/lib/chef/resource/user/windows_user.rb +31 -31
  973. data/lib/chef/resource/whyrun_safe_ruby_block.rb +24 -24
  974. data/lib/chef/resource/windows_package.rb +55 -55
  975. data/lib/chef/resource/windows_script.rb +65 -65
  976. data/lib/chef/resource/windows_service.rb +71 -71
  977. data/lib/chef/resource/yum_package.rb +61 -61
  978. data/lib/chef/resource/yum_repository.rb +78 -78
  979. data/lib/chef/resource/zypper_package.rb +28 -28
  980. data/lib/chef/resource_builder.rb +156 -156
  981. data/lib/chef/resource_collection.rb +136 -136
  982. data/lib/chef/resource_collection/resource_collection_serialization.rb +59 -59
  983. data/lib/chef/resource_collection/resource_list.rb +100 -100
  984. data/lib/chef/resource_collection/resource_set.rb +173 -173
  985. data/lib/chef/resource_collection/stepable_iterator.rb +122 -122
  986. data/lib/chef/resource_definition.rb +68 -68
  987. data/lib/chef/resource_definition_list.rb +38 -38
  988. data/lib/chef/resource_reporter.rb +338 -338
  989. data/lib/chef/resource_resolver.rb +184 -184
  990. data/lib/chef/resources.rb +101 -101
  991. data/lib/chef/rest.rb +210 -210
  992. data/lib/chef/role.rb +280 -280
  993. data/lib/chef/run_context.rb +681 -681
  994. data/lib/chef/run_context/cookbook_compiler.rb +291 -291
  995. data/lib/chef/run_list.rb +168 -168
  996. data/lib/chef/run_list/run_list_expansion.rb +234 -234
  997. data/lib/chef/run_list/run_list_item.rb +98 -98
  998. data/lib/chef/run_list/versioned_recipe_list.rb +102 -102
  999. data/lib/chef/run_lock.rb +197 -197
  1000. data/lib/chef/run_status.rb +125 -125
  1001. data/lib/chef/runner.rb +143 -143
  1002. data/lib/chef/sandbox.rb +20 -20
  1003. data/lib/chef/scan_access_control.rb +138 -138
  1004. data/lib/chef/search/query.rb +183 -183
  1005. data/lib/chef/server_api.rb +80 -80
  1006. data/lib/chef/server_api_versions.rb +40 -40
  1007. data/lib/chef/shell.rb +327 -327
  1008. data/lib/chef/shell/ext.rb +593 -593
  1009. data/lib/chef/shell/model_wrapper.rb +120 -120
  1010. data/lib/chef/shell/shell_session.rb +299 -299
  1011. data/lib/chef/shell_out.rb +13 -13
  1012. data/lib/chef/tasks/chef_repo.rake +200 -200
  1013. data/lib/chef/user.rb +197 -197
  1014. data/lib/chef/user_v1.rb +328 -328
  1015. data/lib/chef/util/backup.rb +94 -94
  1016. data/lib/chef/util/diff.rb +184 -184
  1017. data/lib/chef/util/dsc/configuration_generator.rb +139 -139
  1018. data/lib/chef/util/dsc/lcm_output_parser.rb +192 -192
  1019. data/lib/chef/util/dsc/local_configuration_manager.rb +151 -151
  1020. data/lib/chef/util/dsc/resource_info.rb +26 -26
  1021. data/lib/chef/util/dsc/resource_store.rb +109 -109
  1022. data/lib/chef/util/editor.rb +91 -91
  1023. data/lib/chef/util/file_edit.rb +100 -100
  1024. data/lib/chef/util/path_helper.rb +25 -25
  1025. data/lib/chef/util/powershell/cmdlet.rb +173 -173
  1026. data/lib/chef/util/powershell/cmdlet_result.rb +61 -61
  1027. data/lib/chef/util/powershell/ps_credential.rb +41 -41
  1028. data/lib/chef/util/selinux.rb +92 -92
  1029. data/lib/chef/util/threaded_job_queue.rb +61 -61
  1030. data/lib/chef/util/windows.rb +24 -24
  1031. data/lib/chef/util/windows/net_group.rb +72 -72
  1032. data/lib/chef/util/windows/net_use.rb +81 -81
  1033. data/lib/chef/util/windows/net_user.rb +164 -164
  1034. data/lib/chef/util/windows/volume.rb +53 -53
  1035. data/lib/chef/version.rb +34 -34
  1036. data/lib/chef/version/platform.rb +44 -44
  1037. data/lib/chef/version_class.rb +75 -75
  1038. data/lib/chef/version_constraint.rb +118 -118
  1039. data/lib/chef/version_constraint/platform.rb +26 -26
  1040. data/lib/chef/whitelist.rb +86 -86
  1041. data/lib/chef/win32/api.rb +372 -372
  1042. data/lib/chef/win32/api/crypto.rb +63 -63
  1043. data/lib/chef/win32/api/error.rb +953 -953
  1044. data/lib/chef/win32/api/file.rb +619 -619
  1045. data/lib/chef/win32/api/installer.rb +165 -165
  1046. data/lib/chef/win32/api/memory.rb +105 -105
  1047. data/lib/chef/win32/api/net.rb +312 -312
  1048. data/lib/chef/win32/api/process.rb +42 -42
  1049. data/lib/chef/win32/api/psapi.rb +51 -51
  1050. data/lib/chef/win32/api/registry.rb +51 -51
  1051. data/lib/chef/win32/api/security.rb +460 -460
  1052. data/lib/chef/win32/api/synchronization.rb +89 -89
  1053. data/lib/chef/win32/api/system.rb +238 -238
  1054. data/lib/chef/win32/api/unicode.rb +135 -135
  1055. data/lib/chef/win32/crypto.rb +50 -50
  1056. data/lib/chef/win32/error.rb +86 -86
  1057. data/lib/chef/win32/eventlog.rb +31 -31
  1058. data/lib/chef/win32/file.rb +216 -216
  1059. data/lib/chef/win32/file/info.rb +99 -99
  1060. data/lib/chef/win32/file/version_info.rb +93 -93
  1061. data/lib/chef/win32/handle.rb +55 -55
  1062. data/lib/chef/win32/memory.rb +101 -101
  1063. data/lib/chef/win32/mutex.rb +116 -116
  1064. data/lib/chef/win32/net.rb +311 -311
  1065. data/lib/chef/win32/process.rb +97 -97
  1066. data/lib/chef/win32/registry.rb +374 -374
  1067. data/lib/chef/win32/security.rb +663 -665
  1068. data/lib/chef/win32/security/ace.rb +123 -123
  1069. data/lib/chef/win32/security/acl.rb +103 -103
  1070. data/lib/chef/win32/security/securable_object.rb +109 -109
  1071. data/lib/chef/win32/security/security_descriptor.rb +93 -93
  1072. data/lib/chef/win32/security/sid.rb +304 -304
  1073. data/lib/chef/win32/security/token.rb +72 -72
  1074. data/lib/chef/win32/system.rb +62 -62
  1075. data/lib/chef/win32/unicode.rb +60 -60
  1076. data/lib/chef/win32/version.rb +158 -158
  1077. data/lib/chef/workstation_config_loader.rb +23 -23
  1078. data/spec/data/apt/chef-integration-test-1.0/debian/changelog +5 -5
  1079. data/spec/data/apt/chef-integration-test-1.0/debian/compat +1 -1
  1080. data/spec/data/apt/chef-integration-test-1.0/debian/control +13 -13
  1081. data/spec/data/apt/chef-integration-test-1.0/debian/copyright +34 -34
  1082. data/spec/data/apt/chef-integration-test-1.0/debian/files +1 -1
  1083. data/spec/data/apt/chef-integration-test-1.0/debian/rules +13 -13
  1084. data/spec/data/apt/chef-integration-test-1.0/debian/source/format +1 -1
  1085. data/spec/data/apt/chef-integration-test-1.1/debian/changelog +11 -11
  1086. data/spec/data/apt/chef-integration-test-1.1/debian/compat +1 -1
  1087. data/spec/data/apt/chef-integration-test-1.1/debian/control +13 -13
  1088. data/spec/data/apt/chef-integration-test-1.1/debian/copyright +34 -34
  1089. data/spec/data/apt/chef-integration-test-1.1/debian/files +1 -1
  1090. data/spec/data/apt/chef-integration-test-1.1/debian/rules +13 -13
  1091. data/spec/data/apt/chef-integration-test-1.1/debian/source/format +1 -1
  1092. data/spec/data/apt/chef-integration-test2-1.0/debian/changelog +5 -5
  1093. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2.debhelper.log +45 -45
  1094. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2.substvars +1 -1
  1095. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/conffiles +1 -1
  1096. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/control +10 -10
  1097. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/md5sums +1 -1
  1098. data/spec/data/apt/chef-integration-test2-1.0/debian/compat +1 -1
  1099. data/spec/data/apt/chef-integration-test2-1.0/debian/conffiles +1 -1
  1100. data/spec/data/apt/chef-integration-test2-1.0/debian/control +13 -13
  1101. data/spec/data/apt/chef-integration-test2-1.0/debian/copyright +34 -34
  1102. data/spec/data/apt/chef-integration-test2-1.0/debian/files +1 -1
  1103. data/spec/data/apt/chef-integration-test2-1.0/debian/rules +13 -13
  1104. data/spec/data/apt/chef-integration-test2-1.0/debian/source/format +1 -1
  1105. data/spec/data/apt/chef-integration-test2_1.0-1.dsc +18 -18
  1106. data/spec/data/apt/chef-integration-test2_1.0-1_amd64.build +91 -91
  1107. data/spec/data/apt/chef-integration-test2_1.0-1_amd64.changes +31 -31
  1108. data/spec/data/apt/chef-integration-test_1.0-1_amd64.changes +22 -22
  1109. data/spec/data/apt/chef-integration-test_1.1-1_amd64.changes +22 -22
  1110. data/spec/data/apt/var/www/apt/conf/distributions +7 -7
  1111. data/spec/data/apt/var/www/apt/conf/incoming +4 -4
  1112. data/spec/data/apt/var/www/apt/conf/pulls +3 -3
  1113. data/spec/data/apt/var/www/apt/db/version +4 -4
  1114. data/spec/data/apt/var/www/apt/dists/sid/Release +19 -19
  1115. data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Packages +16 -16
  1116. data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Release +5 -5
  1117. data/spec/data/bootstrap/encrypted_data_bag_secret +1 -1
  1118. data/spec/data/bootstrap/no_proxy.erb +2 -2
  1119. data/spec/data/bootstrap/secret.erb +9 -9
  1120. data/spec/data/bootstrap/test-hints.erb +12 -12
  1121. data/spec/data/bootstrap/test.erb +1 -1
  1122. data/spec/data/cb_version_cookbooks/tatft/README.rdoc +2 -2
  1123. data/spec/data/cb_version_cookbooks/tatft/attributes/default.rb +1 -1
  1124. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-600hhz-0 +1 -1
  1125. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ahd2gq-0 +1 -1
  1126. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-api8ux-0 +1 -1
  1127. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-b0r1m1-0 +1 -1
  1128. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-bfygsi-0 +1 -1
  1129. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-el14l6-0 +1 -1
  1130. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ivrl3y-0 +1 -1
  1131. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-kkbs85-0 +1 -1
  1132. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ory1ux-0 +1 -1
  1133. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-pgsq76-0 +1 -1
  1134. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ra8uim-0 +1 -1
  1135. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t7k1g-0 +1 -1
  1136. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t8g0sv-0 +1 -1
  1137. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ufy6g3-0 +1 -1
  1138. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-x2d6j9-0 +1 -1
  1139. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-xi0l6h-0 +1 -1
  1140. data/spec/data/client.d_00/00-foo.rb +2 -2
  1141. data/spec/data/client.d_00/01-bar.rb +1 -1
  1142. data/spec/data/client.d_00/bar +1 -1
  1143. data/spec/data/client.d_01/foo/bar.rb +1 -1
  1144. data/spec/data/client.d_02/foo.rb/foo.txt +1 -1
  1145. data/spec/data/config.rb +6 -6
  1146. data/spec/data/cookbooks/angrybash/metadata.rb +2 -2
  1147. data/spec/data/cookbooks/angrybash/recipes/default.rb +8 -8
  1148. data/spec/data/cookbooks/apache2/files/default/apache2_module_conf_generate.pl +2 -2
  1149. data/spec/data/cookbooks/apache2/metadata.rb +2 -2
  1150. data/spec/data/cookbooks/apache2/recipes/default.rb +2 -2
  1151. data/spec/data/cookbooks/borken/metadata.rb +2 -2
  1152. data/spec/data/cookbooks/borken/recipes/default.rb +1 -1
  1153. data/spec/data/cookbooks/borken/templates/default/borken.erb +1 -1
  1154. data/spec/data/cookbooks/chefignore +8 -8
  1155. data/spec/data/cookbooks/ignorken/files/default/not_me.rb +2 -2
  1156. data/spec/data/cookbooks/ignorken/metadata.rb +2 -2
  1157. data/spec/data/cookbooks/ignorken/recipes/ignoreme.rb +1 -1
  1158. data/spec/data/cookbooks/ignorken/templates/ubuntu-12.10/not_me.rb +2 -2
  1159. data/spec/data/cookbooks/java/files/default/java.response +1 -1
  1160. data/spec/data/cookbooks/java/metadata.rb +2 -2
  1161. data/spec/data/cookbooks/name-mismatch-versionnumber/README.md +4 -4
  1162. data/spec/data/cookbooks/name-mismatch-versionnumber/metadata.rb +8 -8
  1163. data/spec/data/cookbooks/name-mismatch-versionnumber/recipes/default.rb +8 -8
  1164. data/spec/data/cookbooks/openldap/attributes/default.rb +16 -16
  1165. data/spec/data/cookbooks/openldap/attributes/smokey.rb +1 -1
  1166. data/spec/data/cookbooks/openldap/definitions/client.rb +5 -5
  1167. data/spec/data/cookbooks/openldap/definitions/server.rb +5 -5
  1168. data/spec/data/cookbooks/openldap/files/default/.dotfile +1 -1
  1169. data/spec/data/cookbooks/openldap/files/default/remotedir/.a_dotdir/.a_dotfile_in_a_dotdir +1 -1
  1170. data/spec/data/cookbooks/openldap/files/default/remotedir/not_a_template.erb +2 -2
  1171. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file1.txt +2 -2
  1172. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file2.txt +2 -2
  1173. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/.a_dotfile +1 -1
  1174. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file1.txt +2 -2
  1175. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file2.txt +2 -2
  1176. data/spec/data/cookbooks/openldap/files/default/remotedir/subdir_with_no_file_just_a_subsubdir/the_subsubdir/some_file.txt +3 -3
  1177. data/spec/data/cookbooks/openldap/libraries/openldap.rb +4 -4
  1178. data/spec/data/cookbooks/openldap/libraries/openldap/version.rb +3 -3
  1179. data/spec/data/cookbooks/openldap/metadata.rb +8 -8
  1180. data/spec/data/cookbooks/openldap/recipes/default.rb +4 -4
  1181. data/spec/data/cookbooks/openldap/recipes/gigantor.rb +3 -3
  1182. data/spec/data/cookbooks/openldap/recipes/one.rb +15 -15
  1183. data/spec/data/cookbooks/openldap/recipes/return.rb +2 -2
  1184. data/spec/data/cookbooks/openldap/templates/default/helper_test.erb +1 -1
  1185. data/spec/data/cookbooks/openldap/templates/default/helpers.erb +14 -14
  1186. data/spec/data/cookbooks/openldap/templates/default/helpers_via_partial_test.erb +1 -1
  1187. data/spec/data/cookbooks/openldap/templates/default/nested_openldap_partials.erb +1 -1
  1188. data/spec/data/cookbooks/openldap/templates/default/nested_partial.erb +1 -1
  1189. data/spec/data/cookbooks/openldap/templates/default/no_windows_line_endings.erb +4 -4
  1190. data/spec/data/cookbooks/openldap/templates/default/openldap_variable_stuff.conf.erb +1 -1
  1191. data/spec/data/cookbooks/openldap/templates/default/test.erb +1 -1
  1192. data/spec/data/cookbooks/preseed/files/default/preseed-file.seed +1 -1
  1193. data/spec/data/cookbooks/preseed/files/default/preseed-template.seed +4 -4
  1194. data/spec/data/cookbooks/preseed/metadata.rb +2 -2
  1195. data/spec/data/cookbooks/preseed/templates/default/preseed-template-variables.seed +1 -1
  1196. data/spec/data/cookbooks/preseed/templates/default/preseed-template.seed +1 -1
  1197. data/spec/data/cookbooks/supports-platform-constraints/metadata.rb +5 -5
  1198. data/spec/data/definitions/test.rb +4 -4
  1199. data/spec/data/environment-config.rb +4 -4
  1200. data/spec/data/file-providers-method-snapshot-chef-11-4.json +127 -127
  1201. data/spec/data/fileedit/hosts +4 -4
  1202. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/README.md +4 -4
  1203. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/metadata.rb +13 -13
  1204. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/recipes/default.rb +8 -8
  1205. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/README.md +4 -4
  1206. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/metadata.rb +9 -9
  1207. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/recipes/default.rb +8 -8
  1208. data/spec/data/kitchen/chefignore +6 -6
  1209. data/spec/data/kitchen/openldap/attributes/default.rb +3 -3
  1210. data/spec/data/kitchen/openldap/attributes/robinson.rb +2 -2
  1211. data/spec/data/kitchen/openldap/definitions/client.rb +3 -3
  1212. data/spec/data/kitchen/openldap/definitions/drewbarrymore.rb +2 -2
  1213. data/spec/data/kitchen/openldap/recipes/gigantor.rb +2 -2
  1214. data/spec/data/kitchen/openldap/recipes/ignoreme.rb +2 -2
  1215. data/spec/data/kitchen/openldap/recipes/woot.rb +3 -3
  1216. data/spec/data/knife_subcommand/test_explicit_category.rb +6 -6
  1217. data/spec/data/knife_subcommand/test_name_mapping.rb +4 -4
  1218. data/spec/data/knife_subcommand/test_yourself.rb +21 -21
  1219. data/spec/data/lwrp/providers/buck_passer.rb +28 -28
  1220. data/spec/data/lwrp/providers/buck_passer_2.rb +26 -26
  1221. data/spec/data/lwrp/providers/embedded_resource_accesses_providers_scope.rb +28 -28
  1222. data/spec/data/lwrp/providers/inline_compiler.rb +26 -26
  1223. data/spec/data/lwrp/providers/monkey_name_printer.rb +5 -5
  1224. data/spec/data/lwrp/providers/paint_drying_watcher.rb +7 -7
  1225. data/spec/data/lwrp/providers/thumb_twiddler.rb +7 -7
  1226. data/spec/data/lwrp/resources/bar.rb +2 -2
  1227. data/spec/data/lwrp/resources/foo.rb +4 -4
  1228. data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +1 -1
  1229. data/spec/data/lwrp_override/providers/buck_passer.rb +5 -5
  1230. data/spec/data/lwrp_override/resources/foo.rb +10 -10
  1231. data/spec/data/mac_users/10.7-8.plist.xml +559 -559
  1232. data/spec/data/mac_users/10.7-8.shadow.xml +11 -11
  1233. data/spec/data/mac_users/10.7.plist.xml +559 -559
  1234. data/spec/data/mac_users/10.7.shadow.xml +11 -11
  1235. data/spec/data/mac_users/10.8.plist.xml +559 -559
  1236. data/spec/data/mac_users/10.8.shadow.xml +21 -21
  1237. data/spec/data/mac_users/10.9.plist.xml +560 -560
  1238. data/spec/data/mac_users/10.9.shadow.xml +21 -21
  1239. data/spec/data/metadata/quick_start/metadata.rb +19 -19
  1240. data/spec/data/nested.json +2 -2
  1241. data/spec/data/nodes/default.rb +15 -15
  1242. data/spec/data/nodes/test.example.com.rb +17 -17
  1243. data/spec/data/nodes/test.rb +15 -15
  1244. data/spec/data/null_config.rb +1 -1
  1245. data/spec/data/object_loader/environments/test.json +7 -7
  1246. data/spec/data/object_loader/environments/test.rb +2 -2
  1247. data/spec/data/object_loader/environments/test_json_class.json +8 -8
  1248. data/spec/data/object_loader/nodes/test.json +7 -7
  1249. data/spec/data/object_loader/nodes/test.rb +2 -2
  1250. data/spec/data/object_loader/nodes/test_json_class.json +8 -8
  1251. data/spec/data/object_loader/roles/test.json +7 -7
  1252. data/spec/data/object_loader/roles/test.rb +2 -2
  1253. data/spec/data/object_loader/roles/test_json_class.json +8 -8
  1254. data/spec/data/partial_one.erb +1 -1
  1255. data/spec/data/prefer_metadata_json/metadata.json +51 -51
  1256. data/spec/data/prefer_metadata_json/metadata.rb +6 -6
  1257. data/spec/data/recipes/test.rb +7 -7
  1258. data/spec/data/run_context/cookbooks/circular-dep1/attributes/default.rb +2 -2
  1259. data/spec/data/run_context/cookbooks/circular-dep1/definitions/circular_dep1_res.rb +1 -1
  1260. data/spec/data/run_context/cookbooks/circular-dep1/libraries/lib.rb +2 -2
  1261. data/spec/data/run_context/cookbooks/circular-dep1/metadata.rb +2 -2
  1262. data/spec/data/run_context/cookbooks/circular-dep1/providers/provider.rb +1 -1
  1263. data/spec/data/run_context/cookbooks/circular-dep1/resources/resource.rb +1 -1
  1264. data/spec/data/run_context/cookbooks/circular-dep2/attributes/default.rb +2 -2
  1265. data/spec/data/run_context/cookbooks/circular-dep2/definitions/circular_dep2_res.rb +1 -1
  1266. data/spec/data/run_context/cookbooks/circular-dep2/libraries/lib.rb +2 -2
  1267. data/spec/data/run_context/cookbooks/circular-dep2/metadata.rb +2 -2
  1268. data/spec/data/run_context/cookbooks/circular-dep2/providers/provider.rb +1 -1
  1269. data/spec/data/run_context/cookbooks/circular-dep2/resources/resource.rb +1 -1
  1270. data/spec/data/run_context/cookbooks/dependency1/attributes/aa_first.rb +2 -2
  1271. data/spec/data/run_context/cookbooks/dependency1/attributes/default.rb +2 -2
  1272. data/spec/data/run_context/cookbooks/dependency1/attributes/zz_last.rb +2 -2
  1273. data/spec/data/run_context/cookbooks/dependency1/definitions/dependency1_res.rb +1 -1
  1274. data/spec/data/run_context/cookbooks/dependency1/libraries/lib.rb +2 -2
  1275. data/spec/data/run_context/cookbooks/dependency1/providers/provider.rb +1 -1
  1276. data/spec/data/run_context/cookbooks/dependency1/resources/resource.rb +1 -1
  1277. data/spec/data/run_context/cookbooks/dependency2/attributes/default.rb +2 -2
  1278. data/spec/data/run_context/cookbooks/dependency2/definitions/dependency2_res.rb +1 -1
  1279. data/spec/data/run_context/cookbooks/dependency2/libraries/lib.rb +2 -2
  1280. data/spec/data/run_context/cookbooks/dependency2/providers/provider.rb +1 -1
  1281. data/spec/data/run_context/cookbooks/dependency2/resources/resource.rb +1 -1
  1282. data/spec/data/run_context/cookbooks/include/recipes/default.rb +24 -24
  1283. data/spec/data/run_context/cookbooks/include/recipes/includee.rb +3 -3
  1284. data/spec/data/run_context/cookbooks/no-default-attr/attributes/server.rb +2 -2
  1285. data/spec/data/run_context/cookbooks/no-default-attr/definitions/no_default-attr_res.rb +1 -1
  1286. data/spec/data/run_context/cookbooks/no-default-attr/providers/provider.rb +1 -1
  1287. data/spec/data/run_context/cookbooks/no-default-attr/resources/resource.rb +1 -1
  1288. data/spec/data/run_context/cookbooks/test-with-circular-deps/attributes/default.rb +2 -2
  1289. data/spec/data/run_context/cookbooks/test-with-circular-deps/definitions/test_with-circular-deps_res.rb +1 -1
  1290. data/spec/data/run_context/cookbooks/test-with-circular-deps/libraries/lib.rb +2 -2
  1291. data/spec/data/run_context/cookbooks/test-with-circular-deps/metadata.rb +2 -2
  1292. data/spec/data/run_context/cookbooks/test-with-circular-deps/providers/provider.rb +1 -1
  1293. data/spec/data/run_context/cookbooks/test-with-circular-deps/resources/resource.rb +1 -1
  1294. data/spec/data/run_context/cookbooks/test-with-deps/attributes/default.rb +2 -2
  1295. data/spec/data/run_context/cookbooks/test-with-deps/definitions/test_with-deps_res.rb +1 -1
  1296. data/spec/data/run_context/cookbooks/test-with-deps/libraries/lib.rb +1 -1
  1297. data/spec/data/run_context/cookbooks/test-with-deps/metadata.rb +3 -3
  1298. data/spec/data/run_context/cookbooks/test-with-deps/providers/provider.rb +1 -1
  1299. data/spec/data/run_context/cookbooks/test-with-deps/resources/resource.rb +1 -1
  1300. data/spec/data/run_context/cookbooks/test/attributes/george.rb +1 -1
  1301. data/spec/data/run_context/cookbooks/test/definitions/new_animals.rb +9 -9
  1302. data/spec/data/run_context/cookbooks/test/definitions/new_cat.rb +5 -5
  1303. data/spec/data/run_context/cookbooks/test/definitions/test_res.rb +1 -1
  1304. data/spec/data/run_context/cookbooks/test/providers/provider.rb +1 -1
  1305. data/spec/data/run_context/cookbooks/test/recipes/default.rb +5 -5
  1306. data/spec/data/run_context/cookbooks/test/recipes/one.rb +7 -7
  1307. data/spec/data/run_context/cookbooks/test/recipes/two.rb +7 -7
  1308. data/spec/data/run_context/cookbooks/test/resources/resource.rb +1 -1
  1309. data/spec/data/run_context/nodes/run_context.rb +5 -5
  1310. data/spec/data/sample_msu1.xml +10 -10
  1311. data/spec/data/sample_msu2.xml +14 -14
  1312. data/spec/data/sample_msu3.xml +16 -16
  1313. data/spec/data/search_queries_to_transform.txt +98 -98
  1314. data/spec/data/shef-config.rb +10 -10
  1315. data/spec/data/ssl/5e707473.0 +18 -18
  1316. data/spec/data/ssl/chef-rspec.cert +27 -27
  1317. data/spec/data/ssl/chef-rspec.key +27 -27
  1318. data/spec/data/ssl/key.pem +15 -15
  1319. data/spec/data/ssl/private_key.pem +27 -27
  1320. data/spec/data/ssl/private_key_with_whitespace.pem +32 -32
  1321. data/spec/data/standalone_cookbook/chefignore +9 -9
  1322. data/spec/data/standalone_cookbook/recipes/default.rb +2 -2
  1323. data/spec/data/trusted_certs/example.crt +22 -22
  1324. data/spec/data/trusted_certs/example_no_cn.crt +36 -36
  1325. data/spec/data/trusted_certs/intermediate.pem +27 -27
  1326. data/spec/data/trusted_certs/opscode.pem +57 -57
  1327. data/spec/data/trusted_certs/root.pem +22 -22
  1328. data/spec/functional/application_spec.rb +58 -58
  1329. data/spec/functional/assets/chefinittest +36 -36
  1330. data/spec/functional/assets/testchefsubsys +10 -10
  1331. data/spec/functional/assets/yumrepo/repodata/repomd.xml +55 -55
  1332. data/spec/functional/audit/rspec_formatter_spec.rb +54 -54
  1333. data/spec/functional/audit/runner_spec.rb +121 -121
  1334. data/spec/functional/dsl/reboot_pending_spec.rb +106 -106
  1335. data/spec/functional/dsl/registry_helper_spec.rb +61 -61
  1336. data/spec/functional/event_loggers/windows_eventlog_spec.rb +104 -104
  1337. data/spec/functional/file_content_management/deploy_strategies_spec.rb +229 -229
  1338. data/spec/functional/http/simple_spec.rb +140 -140
  1339. data/spec/functional/knife/configure_spec.rb +33 -33
  1340. data/spec/functional/knife/cookbook_delete_spec.rb +156 -156
  1341. data/spec/functional/knife/exec_spec.rb +55 -55
  1342. data/spec/functional/knife/rehash_spec.rb +39 -39
  1343. data/spec/functional/knife/smoke_test.rb +42 -42
  1344. data/spec/functional/knife/ssh_spec.rb +284 -284
  1345. data/spec/functional/mixin/powershell_out_spec.rb +43 -43
  1346. data/spec/functional/mixin/shell_out_spec.rb +48 -48
  1347. data/spec/functional/notifications_spec.rb +238 -238
  1348. data/spec/functional/provider/remote_file/cache_control_data_spec.rb +100 -100
  1349. data/spec/functional/provider/whyrun_safe_ruby_block_spec.rb +51 -51
  1350. data/spec/functional/rebooter_spec.rb +105 -105
  1351. data/spec/functional/resource/aix_service_spec.rb +138 -138
  1352. data/spec/functional/resource/aixinit_service_spec.rb +211 -211
  1353. data/spec/functional/resource/base.rb +28 -28
  1354. data/spec/functional/resource/bash_spec.rb +88 -88
  1355. data/spec/functional/resource/batch_spec.rb +34 -34
  1356. data/spec/functional/resource/bff_spec.rb +120 -120
  1357. data/spec/functional/resource/chocolatey_package_spec.rb +125 -125
  1358. data/spec/functional/resource/cookbook_file_spec.rb +81 -81
  1359. data/spec/functional/resource/cron_spec.rb +179 -179
  1360. data/spec/functional/resource/deploy_revision_spec.rb +881 -881
  1361. data/spec/functional/resource/directory_spec.rb +43 -43
  1362. data/spec/functional/resource/dnf_package_spec.rb +686 -686
  1363. data/spec/functional/resource/dpkg_package_spec.rb +339 -339
  1364. data/spec/functional/resource/dsc_resource_spec.rb +90 -90
  1365. data/spec/functional/resource/dsc_script_spec.rb +484 -484
  1366. data/spec/functional/resource/env_spec.rb +192 -192
  1367. data/spec/functional/resource/execute_spec.rb +171 -171
  1368. data/spec/functional/resource/file_spec.rb +167 -167
  1369. data/spec/functional/resource/git_spec.rb +257 -257
  1370. data/spec/functional/resource/group_spec.rb +488 -488
  1371. data/spec/functional/resource/ifconfig_spec.rb +171 -171
  1372. data/spec/functional/resource/link_spec.rb +703 -703
  1373. data/spec/functional/resource/mount_spec.rb +207 -207
  1374. data/spec/functional/resource/msu_package_spec.rb +84 -84
  1375. data/spec/functional/resource/ohai_spec.rb +62 -62
  1376. data/spec/functional/resource/package_spec.rb +386 -386
  1377. data/spec/functional/resource/powershell_script_spec.rb +601 -601
  1378. data/spec/functional/resource/reboot_spec.rb +103 -103
  1379. data/spec/functional/resource/registry_spec.rb +676 -676
  1380. data/spec/functional/resource/remote_directory_spec.rb +220 -220
  1381. data/spec/functional/resource/remote_file_spec.rb +249 -249
  1382. data/spec/functional/resource/rpm_spec.rb +120 -120
  1383. data/spec/functional/resource/template_spec.rb +212 -212
  1384. data/spec/functional/resource/user/dscl_spec.rb +196 -196
  1385. data/spec/functional/resource/user/useradd_spec.rb +709 -709
  1386. data/spec/functional/resource/user/windows_spec.rb +133 -133
  1387. data/spec/functional/resource/windows_package_spec.rb +168 -168
  1388. data/spec/functional/resource/windows_service_spec.rb +102 -102
  1389. data/spec/functional/rest_spec.rb +95 -95
  1390. data/spec/functional/run_lock_spec.rb +473 -473
  1391. data/spec/functional/shell_spec.rb +148 -148
  1392. data/spec/functional/tiny_server_spec.rb +79 -79
  1393. data/spec/functional/util/path_helper_spec.rb +37 -37
  1394. data/spec/functional/util/powershell/cmdlet_spec.rb +111 -111
  1395. data/spec/functional/version_spec.rb +35 -35
  1396. data/spec/functional/win32/crypto_spec.rb +54 -54
  1397. data/spec/functional/win32/registry_spec.rb +624 -624
  1398. data/spec/functional/win32/security_spec.rb +135 -100
  1399. data/spec/functional/win32/service_manager_spec.rb +220 -220
  1400. data/spec/functional/win32/sid_spec.rb +55 -55
  1401. data/spec/functional/win32/version_info_spec.rb +50 -50
  1402. data/spec/functional/win32/versions_spec.rb +117 -117
  1403. data/spec/integration/client/client_spec.rb +535 -535
  1404. data/spec/integration/client/exit_code_spec.rb +245 -245
  1405. data/spec/integration/client/ipv6_spec.rb +134 -134
  1406. data/spec/integration/knife/chef_fs_data_store_spec.rb +556 -556
  1407. data/spec/integration/knife/chef_repo_path_spec.rb +959 -959
  1408. data/spec/integration/knife/chef_repository_file_system_spec.rb +296 -296
  1409. data/spec/integration/knife/chefignore_spec.rb +300 -300
  1410. data/spec/integration/knife/client_bulk_delete_spec.rb +130 -130
  1411. data/spec/integration/knife/client_create_spec.rb +69 -69
  1412. data/spec/integration/knife/client_delete_spec.rb +63 -63
  1413. data/spec/integration/knife/client_key_create_spec.rb +65 -65
  1414. data/spec/integration/knife/client_key_delete_spec.rb +42 -42
  1415. data/spec/integration/knife/client_key_list_spec.rb +60 -60
  1416. data/spec/integration/knife/client_key_show_spec.rb +44 -44
  1417. data/spec/integration/knife/client_list_spec.rb +48 -48
  1418. data/spec/integration/knife/client_show_spec.rb +36 -36
  1419. data/spec/integration/knife/common_options_spec.rb +155 -155
  1420. data/spec/integration/knife/cookbook_api_ipv6_spec.rb +112 -112
  1421. data/spec/integration/knife/cookbook_bulk_delete_spec.rb +64 -64
  1422. data/spec/integration/knife/cookbook_download_spec.rb +95 -95
  1423. data/spec/integration/knife/cookbook_list_spec.rb +54 -54
  1424. data/spec/integration/knife/cookbook_show_spec.rb +159 -159
  1425. data/spec/integration/knife/cookbook_upload_spec.rb +90 -90
  1426. data/spec/integration/knife/data_bag_create_spec.rb +55 -55
  1427. data/spec/integration/knife/data_bag_delete_spec.rb +58 -58
  1428. data/spec/integration/knife/data_bag_from_file_spec.rb +115 -115
  1429. data/spec/integration/knife/data_bag_list_spec.rb +43 -43
  1430. data/spec/integration/knife/data_bag_show_spec.rb +53 -53
  1431. data/spec/integration/knife/delete_spec.rb +1017 -1017
  1432. data/spec/integration/knife/deps_spec.rb +706 -706
  1433. data/spec/integration/knife/diff_spec.rb +602 -602
  1434. data/spec/integration/knife/download_spec.rb +1333 -1333
  1435. data/spec/integration/knife/environment_compare_spec.rb +74 -74
  1436. data/spec/integration/knife/environment_create_spec.rb +40 -40
  1437. data/spec/integration/knife/environment_delete_spec.rb +36 -36
  1438. data/spec/integration/knife/environment_from_file_spec.rb +115 -115
  1439. data/spec/integration/knife/environment_list_spec.rb +41 -41
  1440. data/spec/integration/knife/environment_show_spec.rb +76 -76
  1441. data/spec/integration/knife/list_spec.rb +1059 -1059
  1442. data/spec/integration/knife/node_bulk_delete_spec.rb +51 -51
  1443. data/spec/integration/knife/node_create_spec.rb +46 -46
  1444. data/spec/integration/knife/node_delete_spec.rb +47 -47
  1445. data/spec/integration/knife/node_environment_set_spec.rb +45 -45
  1446. data/spec/integration/knife/node_from_file_spec.rb +58 -58
  1447. data/spec/integration/knife/node_list_spec.rb +44 -44
  1448. data/spec/integration/knife/node_run_list_add_spec.rb +53 -53
  1449. data/spec/integration/knife/node_run_list_remove_spec.rb +35 -35
  1450. data/spec/integration/knife/node_run_list_set_spec.rb +40 -40
  1451. data/spec/integration/knife/node_show_spec.rb +35 -35
  1452. data/spec/integration/knife/raw_spec.rb +244 -244
  1453. data/spec/integration/knife/redirection_spec.rb +52 -52
  1454. data/spec/integration/knife/role_bulk_delete_spec.rb +51 -51
  1455. data/spec/integration/knife/role_create_spec.rb +40 -40
  1456. data/spec/integration/knife/role_delete_spec.rb +47 -47
  1457. data/spec/integration/knife/role_from_file_spec.rb +95 -95
  1458. data/spec/integration/knife/role_list_spec.rb +44 -44
  1459. data/spec/integration/knife/role_show_spec.rb +50 -50
  1460. data/spec/integration/knife/serve_spec.rb +57 -57
  1461. data/spec/integration/knife/show_spec.rb +167 -167
  1462. data/spec/integration/knife/upload_spec.rb +1548 -1548
  1463. data/spec/integration/recipes/accumulator_spec.rb +232 -232
  1464. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +175 -175
  1465. data/spec/integration/recipes/lwrp_spec.rb +53 -53
  1466. data/spec/integration/recipes/noop_resource_spec.rb +24 -24
  1467. data/spec/integration/recipes/notifies_spec.rb +334 -334
  1468. data/spec/integration/recipes/notifying_block_spec.rb +111 -111
  1469. data/spec/integration/recipes/provider_choice.rb +37 -37
  1470. data/spec/integration/recipes/recipe_dsl_spec.rb +1523 -1523
  1471. data/spec/integration/recipes/remote_directory.rb +74 -74
  1472. data/spec/integration/recipes/resource_action_spec.rb +581 -581
  1473. data/spec/integration/recipes/resource_converge_if_changed_spec.rb +496 -496
  1474. data/spec/integration/recipes/resource_load_spec.rb +208 -208
  1475. data/spec/integration/solo/solo_spec.rb +217 -217
  1476. data/spec/rcov.opts +2 -2
  1477. data/spec/scripts/ssl-serve.rb +47 -47
  1478. data/spec/spec_helper.rb +288 -288
  1479. data/spec/stress/win32/file_spec.rb +37 -37
  1480. data/spec/stress/win32/memory_spec.rb +22 -22
  1481. data/spec/stress/win32/security_spec.rb +69 -69
  1482. data/spec/support/chef_helpers.rb +115 -115
  1483. data/spec/support/key_helpers.rb +104 -104
  1484. data/spec/support/lib/chef/provider/easy.rb +35 -35
  1485. data/spec/support/lib/chef/provider/openldap_includer.rb +29 -29
  1486. data/spec/support/lib/chef/provider/snakeoil.rb +42 -42
  1487. data/spec/support/lib/chef/resource/cat.rb +39 -39
  1488. data/spec/support/lib/chef/resource/one_two_three_four.rb +38 -38
  1489. data/spec/support/lib/chef/resource/openldap_includer.rb +28 -28
  1490. data/spec/support/lib/chef/resource/with_state.rb +30 -30
  1491. data/spec/support/lib/chef/resource/zen_follower.rb +35 -35
  1492. data/spec/support/lib/chef/resource/zen_master.rb +42 -42
  1493. data/spec/support/lib/library_load_order.rb +20 -20
  1494. data/spec/support/matchers/leak.rb +98 -98
  1495. data/spec/support/mock/constant.rb +52 -52
  1496. data/spec/support/mock/platform.rb +25 -25
  1497. data/spec/support/platform_helpers.rb +237 -237
  1498. data/spec/support/platforms/prof/gc.rb +51 -51
  1499. data/spec/support/platforms/prof/win32.rb +45 -45
  1500. data/spec/support/platforms/win32/spec_service.rb +59 -59
  1501. data/spec/support/shared/context/client.rb +302 -302
  1502. data/spec/support/shared/context/config.rb +21 -21
  1503. data/spec/support/shared/context/win32.rb +34 -34
  1504. data/spec/support/shared/examples/client.rb +53 -53
  1505. data/spec/support/shared/functional/diff_disabled.rb +10 -10
  1506. data/spec/support/shared/functional/directory_resource.rb +176 -176
  1507. data/spec/support/shared/functional/execute_resource.rb +150 -150
  1508. data/spec/support/shared/functional/file_resource.rb +1050 -1050
  1509. data/spec/support/shared/functional/http.rb +248 -248
  1510. data/spec/support/shared/functional/knife.rb +37 -37
  1511. data/spec/support/shared/functional/securable_resource.rb +547 -547
  1512. data/spec/support/shared/functional/securable_resource_with_reporting.rb +394 -394
  1513. data/spec/support/shared/functional/win32_service.rb +57 -57
  1514. data/spec/support/shared/functional/windows_script.rb +272 -272
  1515. data/spec/support/shared/integration/app_server_support.rb +40 -40
  1516. data/spec/support/shared/integration/integration_helper.rb +154 -154
  1517. data/spec/support/shared/integration/knife_support.rb +185 -185
  1518. data/spec/support/shared/matchers/exit_with_code.rb +32 -32
  1519. data/spec/support/shared/matchers/match_environment_variable.rb +17 -17
  1520. data/spec/support/shared/shared_examples.rb +14 -14
  1521. data/spec/support/shared/unit/api_error_inspector.rb +190 -190
  1522. data/spec/support/shared/unit/api_versioning.rb +77 -77
  1523. data/spec/support/shared/unit/application_dot_d.rb +73 -73
  1524. data/spec/support/shared/unit/execute_resource.rb +170 -170
  1525. data/spec/support/shared/unit/file_system_support.rb +69 -69
  1526. data/spec/support/shared/unit/knife_shared.rb +39 -39
  1527. data/spec/support/shared/unit/mock_shellout.rb +49 -49
  1528. data/spec/support/shared/unit/platform_introspector.rb +189 -189
  1529. data/spec/support/shared/unit/provider/file.rb +845 -845
  1530. data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +402 -402
  1531. data/spec/support/shared/unit/resource/static_provider_resolution.rb +63 -63
  1532. data/spec/support/shared/unit/script_resource.rb +98 -98
  1533. data/spec/support/shared/unit/user_and_client_shared.rb +114 -114
  1534. data/spec/support/shared/unit/windows_script_resource.rb +80 -80
  1535. data/spec/tiny_server.rb +192 -192
  1536. data/spec/unit/api_client/registration_spec.rb +278 -278
  1537. data/spec/unit/api_client_spec.rb +341 -341
  1538. data/spec/unit/api_client_v1_spec.rb +455 -455
  1539. data/spec/unit/application/apply_spec.rb +113 -113
  1540. data/spec/unit/application/client_spec.rb +530 -530
  1541. data/spec/unit/application/exit_code_spec.rb +229 -229
  1542. data/spec/unit/application/knife_spec.rb +229 -229
  1543. data/spec/unit/application/solo_spec.rb +232 -232
  1544. data/spec/unit/application_spec.rb +411 -411
  1545. data/spec/unit/audit/audit_event_proxy_spec.rb +318 -318
  1546. data/spec/unit/audit/audit_reporter_spec.rb +439 -439
  1547. data/spec/unit/audit/control_group_data_spec.rb +482 -482
  1548. data/spec/unit/audit/logger_spec.rb +42 -42
  1549. data/spec/unit/audit/rspec_formatter_spec.rb +29 -29
  1550. data/spec/unit/audit/runner_spec.rb +144 -144
  1551. data/spec/unit/chef_class_spec.rb +110 -110
  1552. data/spec/unit/chef_fs/config_spec.rb +235 -235
  1553. data/spec/unit/chef_fs/data_handler/group_handler_spec.rb +63 -63
  1554. data/spec/unit/chef_fs/diff_spec.rb +328 -328
  1555. data/spec/unit/chef_fs/file_pattern_spec.rb +512 -512
  1556. data/spec/unit/chef_fs/file_system/cookbook_subdir_spec.rb +34 -34
  1557. data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +47 -47
  1558. data/spec/unit/chef_fs/file_system/repository/base_file_spec.rb +126 -126
  1559. data/spec/unit/chef_fs/file_system/repository/directory_spec.rb +175 -175
  1560. data/spec/unit/chef_fs/file_system_spec.rb +148 -148
  1561. data/spec/unit/chef_fs/parallelizer.rb +477 -477
  1562. data/spec/unit/chef_fs/path_util_spec.rb +108 -108
  1563. data/spec/unit/chef_spec.rb +25 -25
  1564. data/spec/unit/client_spec.rb +604 -604
  1565. data/spec/unit/config_fetcher_spec.rb +125 -125
  1566. data/spec/unit/config_spec.rb +31 -31
  1567. data/spec/unit/cookbook/chefignore_spec.rb +49 -49
  1568. data/spec/unit/cookbook/cookbook_version_loader_spec.rb +207 -207
  1569. data/spec/unit/cookbook/file_vendor_spec.rb +112 -112
  1570. data/spec/unit/cookbook/metadata_spec.rb +971 -971
  1571. data/spec/unit/cookbook/synchronizer_spec.rb +539 -539
  1572. data/spec/unit/cookbook/syntax_check_spec.rb +225 -225
  1573. data/spec/unit/cookbook_loader_spec.rb +299 -299
  1574. data/spec/unit/cookbook_manifest_spec.rb +243 -243
  1575. data/spec/unit/cookbook_site_streaming_uploader_spec.rb +203 -203
  1576. data/spec/unit/cookbook_spec.rb +66 -66
  1577. data/spec/unit/cookbook_uploader_spec.rb +199 -199
  1578. data/spec/unit/cookbook_version_file_specificity_spec.rb +576 -576
  1579. data/spec/unit/cookbook_version_spec.rb +359 -359
  1580. data/spec/unit/daemon_spec.rb +183 -183
  1581. data/spec/unit/data_bag_item_spec.rb +388 -388
  1582. data/spec/unit/data_bag_spec.rb +260 -260
  1583. data/spec/unit/data_collector/messages/helpers_spec.rb +193 -193
  1584. data/spec/unit/data_collector/messages_spec.rb +192 -192
  1585. data/spec/unit/data_collector/resource_report_spec.rb +145 -145
  1586. data/spec/unit/data_collector_spec.rb +741 -741
  1587. data/spec/unit/decorator/lazy_array_spec.rb +58 -58
  1588. data/spec/unit/decorator/lazy_spec.rb +39 -39
  1589. data/spec/unit/decorator_spec.rb +142 -142
  1590. data/spec/unit/deprecated_spec.rb +59 -59
  1591. data/spec/unit/deprecation_spec.rb +143 -143
  1592. data/spec/unit/digester_spec.rb +49 -49
  1593. data/spec/unit/dsl/audit_spec.rb +43 -43
  1594. data/spec/unit/dsl/data_query_spec.rb +107 -107
  1595. data/spec/unit/dsl/declare_resource_spec.rb +365 -365
  1596. data/spec/unit/dsl/platform_introspection_spec.rb +129 -129
  1597. data/spec/unit/dsl/reboot_pending_spec.rb +100 -100
  1598. data/spec/unit/dsl/recipe_spec.rb +93 -93
  1599. data/spec/unit/dsl/registry_helper_spec.rb +52 -52
  1600. data/spec/unit/dsl/resources_spec.rb +85 -85
  1601. data/spec/unit/encrypted_data_bag_item/check_encrypted_spec.rb +96 -96
  1602. data/spec/unit/encrypted_data_bag_item_spec.rb +438 -438
  1603. data/spec/unit/environment_spec.rb +470 -470
  1604. data/spec/unit/event_dispatch/dispatcher_spec.rb +122 -122
  1605. data/spec/unit/event_dispatch/dsl_spec.rb +83 -83
  1606. data/spec/unit/exceptions_spec.rb +132 -132
  1607. data/spec/unit/file_access_control_spec.rb +308 -308
  1608. data/spec/unit/file_cache_spec.rb +114 -114
  1609. data/spec/unit/file_content_management/deploy/cp_spec.rb +44 -44
  1610. data/spec/unit/file_content_management/deploy/mv_unix_spec.rb +101 -101
  1611. data/spec/unit/file_content_management/deploy/mv_windows_spec.rb +232 -232
  1612. data/spec/unit/file_content_management/tempfile_spec.rb +115 -115
  1613. data/spec/unit/formatters/base_spec.rb +71 -71
  1614. data/spec/unit/formatters/doc_spec.rb +92 -92
  1615. data/spec/unit/formatters/error_description_spec.rb +141 -141
  1616. data/spec/unit/formatters/error_inspectors/api_error_formatting_spec.rb +76 -76
  1617. data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +265 -265
  1618. data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +126 -126
  1619. data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +43 -43
  1620. data/spec/unit/formatters/error_inspectors/node_load_error_inspector_spec.rb +26 -26
  1621. data/spec/unit/formatters/error_inspectors/registration_error_inspector_spec.rb +26 -26
  1622. data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +191 -191
  1623. data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +91 -91
  1624. data/spec/unit/guard_interpreter/resource_guard_interpreter_spec.rb +155 -155
  1625. data/spec/unit/guard_interpreter_spec.rb +41 -41
  1626. data/spec/unit/handler/json_file_spec.rb +63 -63
  1627. data/spec/unit/handler_spec.rb +302 -302
  1628. data/spec/unit/http/api_versions_spec.rb +69 -69
  1629. data/spec/unit/http/authenticator_spec.rb +80 -80
  1630. data/spec/unit/http/basic_client_spec.rb +72 -72
  1631. data/spec/unit/http/http_request_spec.rb +91 -91
  1632. data/spec/unit/http/json_input_spec.rb +128 -128
  1633. data/spec/unit/http/simple_spec.rb +32 -32
  1634. data/spec/unit/http/socketless_chef_zero_client_spec.rb +173 -173
  1635. data/spec/unit/http/ssl_policies_spec.rb +169 -169
  1636. data/spec/unit/http/validate_content_length_spec.rb +207 -207
  1637. data/spec/unit/http_spec.rb +220 -220
  1638. data/spec/unit/json_compat_spec.rb +105 -105
  1639. data/spec/unit/key_spec.rb +631 -631
  1640. data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +152 -152
  1641. data/spec/unit/knife/bootstrap/client_builder_spec.rb +207 -207
  1642. data/spec/unit/knife/bootstrap_spec.rb +824 -824
  1643. data/spec/unit/knife/client_bulk_delete_spec.rb +166 -166
  1644. data/spec/unit/knife/client_create_spec.rb +186 -186
  1645. data/spec/unit/knife/client_delete_spec.rb +99 -99
  1646. data/spec/unit/knife/client_edit_spec.rb +53 -53
  1647. data/spec/unit/knife/client_list_spec.rb +34 -34
  1648. data/spec/unit/knife/client_reregister_spec.rb +62 -62
  1649. data/spec/unit/knife/client_show_spec.rb +52 -52
  1650. data/spec/unit/knife/configure_client_spec.rb +83 -83
  1651. data/spec/unit/knife/configure_spec.rb +241 -241
  1652. data/spec/unit/knife/cookbook_bulk_delete_spec.rb +87 -87
  1653. data/spec/unit/knife/cookbook_create_spec.rb +261 -261
  1654. data/spec/unit/knife/cookbook_delete_spec.rb +239 -239
  1655. data/spec/unit/knife/cookbook_download_spec.rb +237 -237
  1656. data/spec/unit/knife/cookbook_list_spec.rb +88 -88
  1657. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +65 -65
  1658. data/spec/unit/knife/cookbook_metadata_spec.rb +182 -182
  1659. data/spec/unit/knife/cookbook_show_spec.rb +221 -221
  1660. data/spec/unit/knife/cookbook_site_download_spec.rb +150 -150
  1661. data/spec/unit/knife/cookbook_site_install_spec.rb +200 -200
  1662. data/spec/unit/knife/cookbook_site_share_spec.rb +209 -209
  1663. data/spec/unit/knife/cookbook_site_unshare_spec.rb +77 -77
  1664. data/spec/unit/knife/cookbook_test_spec.rb +84 -84
  1665. data/spec/unit/knife/cookbook_upload_spec.rb +331 -331
  1666. data/spec/unit/knife/core/bootstrap_context_spec.rb +307 -307
  1667. data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +187 -187
  1668. data/spec/unit/knife/core/custom_manifest_loader_spec.rb +41 -41
  1669. data/spec/unit/knife/core/gem_glob_loader_spec.rb +209 -209
  1670. data/spec/unit/knife/core/hashed_command_loader_spec.rb +110 -110
  1671. data/spec/unit/knife/core/node_editor_spec.rb +211 -211
  1672. data/spec/unit/knife/core/object_loader_spec.rb +81 -81
  1673. data/spec/unit/knife/core/subcommand_loader_spec.rb +70 -70
  1674. data/spec/unit/knife/core/ui_spec.rb +629 -629
  1675. data/spec/unit/knife/data_bag_create_spec.rb +129 -129
  1676. data/spec/unit/knife/data_bag_edit_spec.rb +127 -127
  1677. data/spec/unit/knife/data_bag_from_file_spec.rb +173 -173
  1678. data/spec/unit/knife/data_bag_secret_options_spec.rb +165 -165
  1679. data/spec/unit/knife/data_bag_show_spec.rb +124 -124
  1680. data/spec/unit/knife/environment_compare_spec.rb +112 -112
  1681. data/spec/unit/knife/environment_create_spec.rb +91 -91
  1682. data/spec/unit/knife/environment_delete_spec.rb +71 -71
  1683. data/spec/unit/knife/environment_edit_spec.rb +79 -79
  1684. data/spec/unit/knife/environment_from_file_spec.rb +90 -90
  1685. data/spec/unit/knife/environment_list_spec.rb +54 -54
  1686. data/spec/unit/knife/environment_show_spec.rb +52 -52
  1687. data/spec/unit/knife/index_rebuild_spec.rb +125 -125
  1688. data/spec/unit/knife/key_create_spec.rb +223 -223
  1689. data/spec/unit/knife/key_delete_spec.rb +133 -133
  1690. data/spec/unit/knife/key_edit_spec.rb +264 -264
  1691. data/spec/unit/knife/key_helper.rb +74 -74
  1692. data/spec/unit/knife/key_list_spec.rb +216 -216
  1693. data/spec/unit/knife/key_show_spec.rb +126 -126
  1694. data/spec/unit/knife/knife_help.rb +92 -92
  1695. data/spec/unit/knife/node_bulk_delete_spec.rb +94 -94
  1696. data/spec/unit/knife/node_delete_spec.rb +77 -77
  1697. data/spec/unit/knife/node_edit_spec.rb +114 -114
  1698. data/spec/unit/knife/node_environment_set_spec.rb +56 -56
  1699. data/spec/unit/knife/node_from_file_spec.rb +59 -59
  1700. data/spec/unit/knife/node_list_spec.rb +62 -62
  1701. data/spec/unit/knife/node_run_list_add_spec.rb +145 -145
  1702. data/spec/unit/knife/node_run_list_remove_spec.rb +106 -106
  1703. data/spec/unit/knife/node_run_list_set_spec.rb +115 -115
  1704. data/spec/unit/knife/node_show_spec.rb +65 -65
  1705. data/spec/unit/knife/osc_user_create_spec.rb +93 -93
  1706. data/spec/unit/knife/osc_user_delete_spec.rb +44 -44
  1707. data/spec/unit/knife/osc_user_edit_spec.rb +52 -52
  1708. data/spec/unit/knife/osc_user_list_spec.rb +37 -37
  1709. data/spec/unit/knife/osc_user_reregister_spec.rb +58 -58
  1710. data/spec/unit/knife/osc_user_show_spec.rb +46 -46
  1711. data/spec/unit/knife/raw_spec.rb +43 -43
  1712. data/spec/unit/knife/role_bulk_delete_spec.rb +80 -80
  1713. data/spec/unit/knife/role_create_spec.rb +80 -80
  1714. data/spec/unit/knife/role_delete_spec.rb +67 -67
  1715. data/spec/unit/knife/role_edit_spec.rb +77 -77
  1716. data/spec/unit/knife/role_env_run_list_add_spec.rb +217 -217
  1717. data/spec/unit/knife/role_env_run_list_clear_spec.rb +94 -94
  1718. data/spec/unit/knife/role_env_run_list_remove_spec.rb +102 -102
  1719. data/spec/unit/knife/role_env_run_list_replace_spec.rb +105 -105
  1720. data/spec/unit/knife/role_env_run_list_set_spec.rb +99 -99
  1721. data/spec/unit/knife/role_from_file_spec.rb +69 -69
  1722. data/spec/unit/knife/role_list_spec.rb +54 -54
  1723. data/spec/unit/knife/role_run_list_add_spec.rb +179 -179
  1724. data/spec/unit/knife/role_run_list_clear_spec.rb +84 -84
  1725. data/spec/unit/knife/role_run_list_remove_spec.rb +92 -92
  1726. data/spec/unit/knife/role_run_list_replace_spec.rb +98 -98
  1727. data/spec/unit/knife/role_run_list_set_spec.rb +89 -89
  1728. data/spec/unit/knife/role_show_spec.rb +59 -59
  1729. data/spec/unit/knife/ssh_spec.rb +426 -426
  1730. data/spec/unit/knife/ssl_check_spec.rb +256 -256
  1731. data/spec/unit/knife/ssl_fetch_spec.rb +222 -222
  1732. data/spec/unit/knife/status_spec.rb +109 -109
  1733. data/spec/unit/knife/tag_create_spec.rb +23 -23
  1734. data/spec/unit/knife/tag_delete_spec.rb +25 -25
  1735. data/spec/unit/knife/tag_list_spec.rb +23 -23
  1736. data/spec/unit/knife/user_create_spec.rb +214 -214
  1737. data/spec/unit/knife/user_delete_spec.rb +65 -65
  1738. data/spec/unit/knife/user_edit_spec.rb +66 -66
  1739. data/spec/unit/knife/user_list_spec.rb +36 -36
  1740. data/spec/unit/knife/user_reregister_spec.rb +74 -74
  1741. data/spec/unit/knife/user_show_spec.rb +65 -65
  1742. data/spec/unit/knife_spec.rb +561 -561
  1743. data/spec/unit/lib_backcompat_spec.rb +34 -34
  1744. data/spec/unit/log/syslog_spec.rb +53 -53
  1745. data/spec/unit/log/winevt_spec.rb +55 -55
  1746. data/spec/unit/log_spec.rb +24 -24
  1747. data/spec/unit/lwrp_spec.rb +777 -777
  1748. data/spec/unit/mash_spec.rb +51 -51
  1749. data/spec/unit/mixin/api_version_request_handling_spec.rb +126 -126
  1750. data/spec/unit/mixin/checksum_spec.rb +54 -54
  1751. data/spec/unit/mixin/command_spec.rb +107 -107
  1752. data/spec/unit/mixin/convert_to_class_name_spec.rb +54 -54
  1753. data/spec/unit/mixin/deep_merge_spec.rb +342 -342
  1754. data/spec/unit/mixin/deprecation_spec.rb +57 -57
  1755. data/spec/unit/mixin/enforce_ownership_and_permissions_spec.rb +96 -96
  1756. data/spec/unit/mixin/homebrew_user_spec.rb +100 -100
  1757. data/spec/unit/mixin/lazy_module_include.rb +71 -71
  1758. data/spec/unit/mixin/params_validate_spec.rb +410 -410
  1759. data/spec/unit/mixin/path_sanity_spec.rb +92 -92
  1760. data/spec/unit/mixin/powershell_out_spec.rb +94 -94
  1761. data/spec/unit/mixin/powershell_type_coercions_spec.rb +83 -83
  1762. data/spec/unit/mixin/properties_spec.rb +97 -97
  1763. data/spec/unit/mixin/proxified_socket_spec.rb +97 -97
  1764. data/spec/unit/mixin/securable_spec.rb +314 -314
  1765. data/spec/unit/mixin/shell_out_spec.rb +302 -302
  1766. data/spec/unit/mixin/subclass_directive_spec.rb +45 -45
  1767. data/spec/unit/mixin/template_spec.rb +276 -276
  1768. data/spec/unit/mixin/unformatter_spec.rb +61 -61
  1769. data/spec/unit/mixin/uris_spec.rb +57 -57
  1770. data/spec/unit/mixin/versioned_api_spec.rb +107 -107
  1771. data/spec/unit/mixin/which.rb +160 -160
  1772. data/spec/unit/mixin/windows_architecture_helper_spec.rb +85 -85
  1773. data/spec/unit/mixin/xml_escape_spec.rb +54 -54
  1774. data/spec/unit/monkey_patches/uri_spec.rb +34 -34
  1775. data/spec/unit/monologger_spec.rb +45 -45
  1776. data/spec/unit/node/attribute_spec.rb +1244 -1244
  1777. data/spec/unit/node/immutable_collections_spec.rb +214 -214
  1778. data/spec/unit/node/vivid_mash_spec.rb +353 -353
  1779. data/spec/unit/node_map_spec.rb +170 -170
  1780. data/spec/unit/node_spec.rb +1836 -1836
  1781. data/spec/unit/org_spec.rb +196 -196
  1782. data/spec/unit/platform/query_helpers_spec.rb +220 -220
  1783. data/spec/unit/platform_spec.rb +269 -269
  1784. data/spec/unit/policy_builder/dynamic_spec.rb +273 -273
  1785. data/spec/unit/policy_builder/expand_node_object_spec.rb +336 -336
  1786. data/spec/unit/policy_builder/policyfile_spec.rb +795 -795
  1787. data/spec/unit/policy_builder_spec.rb +26 -26
  1788. data/spec/unit/property/state_spec.rb +508 -508
  1789. data/spec/unit/property/validation_spec.rb +720 -720
  1790. data/spec/unit/property_spec.rb +1227 -1227
  1791. data/spec/unit/provider/apt_repository_spec.rb +189 -189
  1792. data/spec/unit/provider/apt_update_spec.rb +114 -114
  1793. data/spec/unit/provider/breakpoint_spec.rb +53 -53
  1794. data/spec/unit/provider/cookbook_file/content_spec.rb +39 -39
  1795. data/spec/unit/provider/cookbook_file_spec.rb +58 -58
  1796. data/spec/unit/provider/cron/unix_spec.rb +139 -139
  1797. data/spec/unit/provider/cron_spec.rb +1010 -1010
  1798. data/spec/unit/provider/deploy/revision_spec.rb +110 -110
  1799. data/spec/unit/provider/deploy/timestamped_spec.rb +40 -40
  1800. data/spec/unit/provider/deploy_spec.rb +641 -641
  1801. data/spec/unit/provider/directory_spec.rb +300 -300
  1802. data/spec/unit/provider/dsc_resource_spec.rb +343 -343
  1803. data/spec/unit/provider/dsc_script_spec.rb +173 -173
  1804. data/spec/unit/provider/env/windows_spec.rb +103 -103
  1805. data/spec/unit/provider/env_spec.rb +310 -310
  1806. data/spec/unit/provider/erl_call_spec.rb +85 -85
  1807. data/spec/unit/provider/execute_spec.rb +242 -242
  1808. data/spec/unit/provider/file/content_spec.rb +114 -114
  1809. data/spec/unit/provider/file_spec.rb +56 -56
  1810. data/spec/unit/provider/git_spec.rb +727 -727
  1811. data/spec/unit/provider/group/dscl_spec.rb +331 -331
  1812. data/spec/unit/provider/group/gpasswd_spec.rb +116 -116
  1813. data/spec/unit/provider/group/groupadd_spec.rb +194 -194
  1814. data/spec/unit/provider/group/groupmod_spec.rb +133 -133
  1815. data/spec/unit/provider/group/pw_spec.rb +138 -138
  1816. data/spec/unit/provider/group/suse_spec.rb +90 -90
  1817. data/spec/unit/provider/group/usermod_spec.rb +115 -115
  1818. data/spec/unit/provider/group/windows_spec.rb +109 -109
  1819. data/spec/unit/provider/group_spec.rb +286 -286
  1820. data/spec/unit/provider/http_request_spec.rb +159 -159
  1821. data/spec/unit/provider/ifconfig/aix_spec.rb +180 -180
  1822. data/spec/unit/provider/ifconfig/debian_spec.rb +332 -332
  1823. data/spec/unit/provider/ifconfig/redhat_spec.rb +73 -73
  1824. data/spec/unit/provider/ifconfig_spec.rb +194 -194
  1825. data/spec/unit/provider/launchd_spec.rb +268 -268
  1826. data/spec/unit/provider/link_spec.rb +407 -407
  1827. data/spec/unit/provider/log_spec.rb +89 -89
  1828. data/spec/unit/provider/mdadm_spec.rb +140 -140
  1829. data/spec/unit/provider/mount/aix_spec.rb +237 -237
  1830. data/spec/unit/provider/mount/mount_spec.rb +474 -474
  1831. data/spec/unit/provider/mount/solaris_spec.rb +822 -822
  1832. data/spec/unit/provider/mount/windows_spec.rb +149 -149
  1833. data/spec/unit/provider/mount_spec.rb +191 -191
  1834. data/spec/unit/provider/ohai_spec.rb +84 -84
  1835. data/spec/unit/provider/osx_profile_spec.rb +255 -255
  1836. data/spec/unit/provider/package/aix_spec.rb +185 -185
  1837. data/spec/unit/provider/package/apt_spec.rb +481 -481
  1838. data/spec/unit/provider/package/cab_spec.rb +272 -272
  1839. data/spec/unit/provider/package/chocolatey_spec.rb +489 -489
  1840. data/spec/unit/provider/package/dnf/python_helper_spec.rb +29 -29
  1841. data/spec/unit/provider/package/dpkg_spec.rb +287 -287
  1842. data/spec/unit/provider/package/easy_install_spec.rb +114 -114
  1843. data/spec/unit/provider/package/freebsd/pkg_spec.rb +274 -274
  1844. data/spec/unit/provider/package/freebsd/pkgng_spec.rb +148 -148
  1845. data/spec/unit/provider/package/freebsd/port_spec.rb +163 -163
  1846. data/spec/unit/provider/package/homebrew_spec.rb +292 -292
  1847. data/spec/unit/provider/package/ips_spec.rb +233 -233
  1848. data/spec/unit/provider/package/macports_spec.rb +203 -203
  1849. data/spec/unit/provider/package/msu_spec.rb +283 -283
  1850. data/spec/unit/provider/package/openbsd_spec.rb +132 -132
  1851. data/spec/unit/provider/package/pacman_spec.rb +194 -194
  1852. data/spec/unit/provider/package/paludis_spec.rb +134 -134
  1853. data/spec/unit/provider/package/portage_spec.rb +315 -315
  1854. data/spec/unit/provider/package/powershell_spec.rb +337 -337
  1855. data/spec/unit/provider/package/rpm_spec.rb +429 -429
  1856. data/spec/unit/provider/package/rubygems_spec.rb +824 -824
  1857. data/spec/unit/provider/package/smartos_spec.rb +110 -110
  1858. data/spec/unit/provider/package/solaris_spec.rb +167 -167
  1859. data/spec/unit/provider/package/windows/exe_spec.rb +201 -201
  1860. data/spec/unit/provider/package/windows/msi_spec.rb +168 -168
  1861. data/spec/unit/provider/package/windows_spec.rb +443 -443
  1862. data/spec/unit/provider/package/yum/yum_cache_spec.rb +27 -27
  1863. data/spec/unit/provider/package/yum_spec.rb +2294 -2294
  1864. data/spec/unit/provider/package/zypper_spec.rb +348 -348
  1865. data/spec/unit/provider/package_spec.rb +949 -949
  1866. data/spec/unit/provider/powershell_script_spec.rb +106 -106
  1867. data/spec/unit/provider/registry_key_spec.rb +407 -407
  1868. data/spec/unit/provider/remote_directory_spec.rb +236 -236
  1869. data/spec/unit/provider/remote_file/cache_control_data_spec.rb +245 -245
  1870. data/spec/unit/provider/remote_file/content_spec.rb +253 -253
  1871. data/spec/unit/provider/remote_file/fetcher_spec.rb +94 -94
  1872. data/spec/unit/provider/remote_file/ftp_spec.rb +217 -217
  1873. data/spec/unit/provider/remote_file/http_spec.rb +322 -322
  1874. data/spec/unit/provider/remote_file/local_file_spec.rb +105 -105
  1875. data/spec/unit/provider/remote_file/network_file_spec.rb +45 -45
  1876. data/spec/unit/provider/remote_file/sftp_spec.rb +150 -150
  1877. data/spec/unit/provider/remote_file_spec.rb +61 -61
  1878. data/spec/unit/provider/route_spec.rb +248 -248
  1879. data/spec/unit/provider/ruby_block_spec.rb +45 -45
  1880. data/spec/unit/provider/script_spec.rb +157 -157
  1881. data/spec/unit/provider/service/aix_service_spec.rb +195 -195
  1882. data/spec/unit/provider/service/aixinit_service_spec.rb +272 -272
  1883. data/spec/unit/provider/service/arch_service_spec.rb +324 -324
  1884. data/spec/unit/provider/service/debian_service_spec.rb +375 -375
  1885. data/spec/unit/provider/service/freebsd_service_spec.rb +617 -617
  1886. data/spec/unit/provider/service/gentoo_service_spec.rb +144 -144
  1887. data/spec/unit/provider/service/init_service_spec.rb +235 -235
  1888. data/spec/unit/provider/service/insserv_service_spec.rb +75 -75
  1889. data/spec/unit/provider/service/invokercd_service_spec.rb +211 -211
  1890. data/spec/unit/provider/service/macosx_spec.rb +335 -335
  1891. data/spec/unit/provider/service/openbsd_service_spec.rb +549 -549
  1892. data/spec/unit/provider/service/redhat_spec.rb +250 -250
  1893. data/spec/unit/provider/service/simple_service_spec.rb +169 -169
  1894. data/spec/unit/provider/service/solaris_smf_service_spec.rb +255 -255
  1895. data/spec/unit/provider/service/systemd_service_spec.rb +370 -370
  1896. data/spec/unit/provider/service/upstart_service_spec.rb +364 -364
  1897. data/spec/unit/provider/service/windows_spec.rb +463 -463
  1898. data/spec/unit/provider/service_spec.rb +168 -168
  1899. data/spec/unit/provider/subversion_spec.rb +361 -361
  1900. data/spec/unit/provider/systemd_unit_spec.rb +885 -885
  1901. data/spec/unit/provider/template/content_spec.rb +169 -169
  1902. data/spec/unit/provider/template_spec.rb +89 -89
  1903. data/spec/unit/provider/user/dscl_spec.rb +902 -902
  1904. data/spec/unit/provider/user/linux_spec.rb +112 -112
  1905. data/spec/unit/provider/user/pw_spec.rb +255 -255
  1906. data/spec/unit/provider/user/solaris_spec.rb +178 -178
  1907. data/spec/unit/provider/user/windows_spec.rb +185 -185
  1908. data/spec/unit/provider/user_spec.rb +478 -478
  1909. data/spec/unit/provider/whyrun_safe_ruby_block_spec.rb +46 -46
  1910. data/spec/unit/provider/yum_repository_spec.rb +35 -35
  1911. data/spec/unit/provider_resolver_spec.rb +939 -939
  1912. data/spec/unit/provider_spec.rb +198 -198
  1913. data/spec/unit/pure_application_spec.rb +32 -32
  1914. data/spec/unit/recipe_spec.rb +758 -758
  1915. data/spec/unit/resource/apt_package_spec.rb +38 -38
  1916. data/spec/unit/resource/apt_repository_spec.rb +50 -50
  1917. data/spec/unit/resource/apt_update_spec.rb +50 -50
  1918. data/spec/unit/resource/bash_spec.rb +40 -40
  1919. data/spec/unit/resource/batch_spec.rb +49 -49
  1920. data/spec/unit/resource/breakpoint_spec.rb +47 -47
  1921. data/spec/unit/resource/cab_package_spec.rb +38 -38
  1922. data/spec/unit/resource/chef_gem_spec.rb +157 -157
  1923. data/spec/unit/resource/chocolatey_package_spec.rb +79 -79
  1924. data/spec/unit/resource/conditional_action_not_nothing_spec.rb +45 -45
  1925. data/spec/unit/resource/conditional_spec.rb +254 -254
  1926. data/spec/unit/resource/cookbook_file_spec.rb +88 -88
  1927. data/spec/unit/resource/cron_spec.rb +186 -186
  1928. data/spec/unit/resource/csh_spec.rb +40 -40
  1929. data/spec/unit/resource/deploy_revision_spec.rb +42 -42
  1930. data/spec/unit/resource/deploy_spec.rb +283 -283
  1931. data/spec/unit/resource/directory_spec.rb +82 -82
  1932. data/spec/unit/resource/dnf_package_spec.rb +99 -99
  1933. data/spec/unit/resource/dpkg_package_spec.rb +32 -32
  1934. data/spec/unit/resource/dsc_resource_spec.rb +102 -102
  1935. data/spec/unit/resource/dsc_script_spec.rb +134 -134
  1936. data/spec/unit/resource/easy_install_package_spec.rb +39 -39
  1937. data/spec/unit/resource/env_spec.rb +85 -85
  1938. data/spec/unit/resource/erl_call_spec.rb +81 -81
  1939. data/spec/unit/resource/execute_spec.rb +249 -249
  1940. data/spec/unit/resource/file/verification/systemd_unit_spec.rb +103 -103
  1941. data/spec/unit/resource/file/verification_spec.rb +139 -139
  1942. data/spec/unit/resource/file_spec.rb +130 -130
  1943. data/spec/unit/resource/freebsd_package_spec.rb +87 -87
  1944. data/spec/unit/resource/gem_package_spec.rb +42 -42
  1945. data/spec/unit/resource/git_spec.rb +50 -50
  1946. data/spec/unit/resource/group_spec.rb +162 -162
  1947. data/spec/unit/resource/homebrew_package_spec.rb +50 -50
  1948. data/spec/unit/resource/http_request_spec.rb +59 -59
  1949. data/spec/unit/resource/ifconfig_spec.rb +109 -109
  1950. data/spec/unit/resource/ips_package_spec.rb +40 -40
  1951. data/spec/unit/resource/ksh_spec.rb +40 -40
  1952. data/spec/unit/resource/launchd_spec.rb +32 -32
  1953. data/spec/unit/resource/link_spec.rb +134 -134
  1954. data/spec/unit/resource/log_spec.rb +73 -73
  1955. data/spec/unit/resource/macports_package_spec.rb +32 -32
  1956. data/spec/unit/resource/mdadm_spec.rb +107 -107
  1957. data/spec/unit/resource/mount_spec.rb +215 -215
  1958. data/spec/unit/resource/msu_package_spec.rb +49 -49
  1959. data/spec/unit/resource/ohai_spec.rb +61 -61
  1960. data/spec/unit/resource/openbsd_package_spec.rb +48 -48
  1961. data/spec/unit/resource/osx_profile_spec.rb +62 -62
  1962. data/spec/unit/resource/package_spec.rb +98 -98
  1963. data/spec/unit/resource/pacman_package_spec.rb +32 -32
  1964. data/spec/unit/resource/perl_spec.rb +40 -40
  1965. data/spec/unit/resource/portage_package_spec.rb +38 -38
  1966. data/spec/unit/resource/powershell_package_spec.rb +68 -68
  1967. data/spec/unit/resource/powershell_script_spec.rb +136 -136
  1968. data/spec/unit/resource/python_spec.rb +40 -40
  1969. data/spec/unit/resource/registry_key_spec.rb +215 -215
  1970. data/spec/unit/resource/remote_directory_spec.rb +97 -97
  1971. data/spec/unit/resource/remote_file_spec.rb +207 -207
  1972. data/spec/unit/resource/resource_notification_spec.rb +169 -169
  1973. data/spec/unit/resource/route_spec.rb +107 -107
  1974. data/spec/unit/resource/rpm_package_spec.rb +46 -46
  1975. data/spec/unit/resource/ruby_block_spec.rb +61 -61
  1976. data/spec/unit/resource/ruby_spec.rb +40 -40
  1977. data/spec/unit/resource/scm_spec.rb +193 -193
  1978. data/spec/unit/resource/script_spec.rb +44 -44
  1979. data/spec/unit/resource/service_spec.rb +179 -179
  1980. data/spec/unit/resource/smartos_package_spec.rb +33 -33
  1981. data/spec/unit/resource/solaris_package_spec.rb +42 -42
  1982. data/spec/unit/resource/subversion_spec.rb +71 -71
  1983. data/spec/unit/resource/systemd_unit_spec.rb +133 -133
  1984. data/spec/unit/resource/template_spec.rb +210 -210
  1985. data/spec/unit/resource/timestamped_deploy_spec.rb +32 -32
  1986. data/spec/unit/resource/user_spec.rb +133 -133
  1987. data/spec/unit/resource/windows_package_spec.rb +95 -95
  1988. data/spec/unit/resource/windows_service_spec.rb +49 -49
  1989. data/spec/unit/resource/yum_package_spec.rb +150 -150
  1990. data/spec/unit/resource/yum_repository_spec.rb +49 -49
  1991. data/spec/unit/resource_builder_spec.rb +1 -1
  1992. data/spec/unit/resource_collection/resource_list_spec.rb +137 -137
  1993. data/spec/unit/resource_collection/resource_set_spec.rb +199 -199
  1994. data/spec/unit/resource_collection/stepable_iterator_spec.rb +144 -144
  1995. data/spec/unit/resource_collection_spec.rb +399 -399
  1996. data/spec/unit/resource_definition_spec.rb +117 -117
  1997. data/spec/unit/resource_reporter_spec.rb +782 -782
  1998. data/spec/unit/resource_resolver_spec.rb +52 -52
  1999. data/spec/unit/resource_spec.rb +1141 -1141
  2000. data/spec/unit/rest/auth_credentials_spec.rb +292 -292
  2001. data/spec/unit/rest_spec.rb +753 -753
  2002. data/spec/unit/role_spec.rb +358 -358
  2003. data/spec/unit/run_context/child_run_context_spec.rb +133 -133
  2004. data/spec/unit/run_context/cookbook_compiler_spec.rb +226 -226
  2005. data/spec/unit/run_context_spec.rb +241 -241
  2006. data/spec/unit/run_list/run_list_expansion_spec.rb +144 -144
  2007. data/spec/unit/run_list/run_list_item_spec.rb +117 -117
  2008. data/spec/unit/run_list/versioned_recipe_list_spec.rb +194 -194
  2009. data/spec/unit/run_list_spec.rb +312 -312
  2010. data/spec/unit/run_lock_spec.rb +140 -140
  2011. data/spec/unit/run_status_spec.rb +144 -144
  2012. data/spec/unit/runner_spec.rb +412 -412
  2013. data/spec/unit/scan_access_control_spec.rb +183 -183
  2014. data/spec/unit/search/query_spec.rb +290 -290
  2015. data/spec/unit/server_api_spec.rb +50 -50
  2016. data/spec/unit/server_api_versions_spec.rb +44 -44
  2017. data/spec/unit/shell/model_wrapper_spec.rb +96 -96
  2018. data/spec/unit/shell/shell_ext_spec.rb +153 -153
  2019. data/spec/unit/shell/shell_session_spec.rb +195 -195
  2020. data/spec/unit/shell_out_spec.rb +18 -18
  2021. data/spec/unit/shell_spec.rb +162 -162
  2022. data/spec/unit/user_spec.rb +275 -275
  2023. data/spec/unit/user_v1_spec.rb +583 -583
  2024. data/spec/unit/util/backup_spec.rb +141 -141
  2025. data/spec/unit/util/diff_spec.rb +576 -576
  2026. data/spec/unit/util/dsc/configuration_generator_spec.rb +193 -193
  2027. data/spec/unit/util/dsc/lcm_output_parser_spec.rb +248 -248
  2028. data/spec/unit/util/dsc/local_configuration_manager_spec.rb +200 -200
  2029. data/spec/unit/util/dsc/resource_store.rb +78 -78
  2030. data/spec/unit/util/editor_spec.rb +152 -152
  2031. data/spec/unit/util/file_edit_spec.rb +224 -224
  2032. data/spec/unit/util/powershell/cmdlet_spec.rb +106 -106
  2033. data/spec/unit/util/powershell/ps_credential_spec.rb +44 -44
  2034. data/spec/unit/util/selinux_spec.rb +160 -160
  2035. data/spec/unit/util/threaded_job_queue_spec.rb +51 -51
  2036. data/spec/unit/version/platform_spec.rb +60 -60
  2037. data/spec/unit/version_class_spec.rb +171 -171
  2038. data/spec/unit/version_constraint/platform_spec.rb +45 -45
  2039. data/spec/unit/version_constraint_spec.rb +179 -179
  2040. data/spec/unit/win32/error_spec.rb +67 -67
  2041. data/spec/unit/win32/registry_spec.rb +394 -394
  2042. data/spec/unit/win32/security_spec.rb +66 -66
  2043. data/spec/unit/windows_service_spec.rb +116 -116
  2044. data/tasks/announce.rb +58 -58
  2045. data/tasks/bin/bundle-platform +20 -20
  2046. data/tasks/bin/bundle-platform.bat +2 -2
  2047. data/tasks/bin/bundler_patch.rb +27 -27
  2048. data/tasks/bin/create-override-gemfile +110 -110
  2049. data/tasks/bin/gem-version-diff +37 -37
  2050. data/tasks/bin/run_external_test +47 -47
  2051. data/tasks/bundle.rb +97 -97
  2052. data/tasks/bundle_util.rb +110 -110
  2053. data/tasks/cbgb.rb +84 -84
  2054. data/tasks/changelog.rb +31 -31
  2055. data/tasks/dependencies.rb +151 -151
  2056. data/tasks/gemfile_util.rb +390 -390
  2057. data/tasks/maintainers.rb +211 -211
  2058. data/tasks/rspec.rb +90 -90
  2059. data/tasks/templates/prerelease.md.erb +26 -26
  2060. data/tasks/templates/release.md.erb +26 -26
  2061. metadata +4 -4
@@ -1,170 +1,170 @@
1
- #
2
- # Author:: Lamont Granquist (<lamont@chef.io>)
3
- # Copyright:: Copyright 2014-2016, Chef Software, Inc.
4
- # License:: Apache License, Version 2.0
5
- #
6
- # Licensed under the Apache License, Version 2.0 (the "License");
7
- # you may not use this file except in compliance with the License.
8
- # You may obtain a copy of the License at
9
- #
10
- # http://www.apache.org/licenses/LICENSE-2.0
11
- #
12
- # Unless required by applicable law or agreed to in writing, software
13
- # distributed under the License is distributed on an "AS IS" BASIS,
14
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- # See the License for the specific language governing permissions and
16
- # limitations under the License.
17
- #
18
-
19
- require "spec_helper"
20
- require "chef/node_map"
21
-
22
- describe Chef::NodeMap do
23
-
24
- let(:node_map) { Chef::NodeMap.new }
25
-
26
- let(:node) { Chef::Node.new }
27
-
28
- describe "with a bad filter name" do
29
- it "should raise an error" do
30
- expect { node_map.set(node, :thing, on_platform_family: "rhel") }.to raise_error(ArgumentError)
31
- end
32
- end
33
-
34
- describe "when no matchers are set at all" do
35
- before do
36
- node_map.set(:thing, :foo)
37
- end
38
-
39
- it "returns the value" do
40
- expect(node_map.get(node, :thing)).to eql(:foo)
41
- end
42
-
43
- it "returns nil for keys that do not exist" do
44
- expect(node_map.get(node, :other_thing)).to eql(nil)
45
- end
46
- end
47
-
48
- describe "filtering by os" do
49
- before do
50
- node_map.set(:thing, :foo, os: ["windows"])
51
- node_map.set(:thing, :bar, os: "linux")
52
- end
53
- it "returns the correct value for windows" do
54
- allow(node).to receive(:[]).with(:os).and_return("windows")
55
- expect(node_map.get(node, :thing)).to eql(:foo)
56
- end
57
- it "returns the correct value for linux" do
58
- allow(node).to receive(:[]).with(:os).and_return("linux")
59
- expect(node_map.get(node, :thing)).to eql(:bar)
60
- end
61
- it "returns nil for a non-matching os" do
62
- allow(node).to receive(:[]).with(:os).and_return("freebsd")
63
- expect(node_map.get(node, :thing)).to eql(nil)
64
- end
65
- end
66
-
67
- describe "rejecting an os" do
68
- before do
69
- node_map.set(:thing, :foo, os: "!windows")
70
- end
71
- it "returns nil for windows" do
72
- allow(node).to receive(:[]).with(:os).and_return("windows")
73
- expect(node_map.get(node, :thing)).to eql(nil)
74
- end
75
- it "returns the correct value for linux" do
76
- allow(node).to receive(:[]).with(:os).and_return("linux")
77
- expect(node_map.get(node, :thing)).to eql(:foo)
78
- end
79
- end
80
-
81
- describe "filtering by os and platform_family" do
82
- before do
83
- node_map.set(:thing, :bar, os: "linux", platform_family: "rhel")
84
- end
85
-
86
- it "returns the correct value when both match" do
87
- allow(node).to receive(:[]).with(:os).and_return("linux")
88
- allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
89
- expect(node_map.get(node, :thing)).to eql(:bar)
90
- end
91
-
92
- it "returns nil for a non-matching os" do
93
- allow(node).to receive(:[]).with(:os).and_return("freebsd")
94
- expect(node_map.get(node, :thing)).to eql(nil)
95
- end
96
-
97
- it "returns nil when the platform_family does not match" do
98
- allow(node).to receive(:[]).with(:os).and_return("linux")
99
- allow(node).to receive(:[]).with(:platform_family).and_return("debian")
100
- expect(node_map.get(node, :thing)).to eql(nil)
101
- end
102
- end
103
-
104
- describe "with a block doing platform_version checks" do
105
- before do
106
- node_map.set(:thing, :foo, platform_family: "rhel") do |node|
107
- node[:platform_version].to_i >= 7
108
- end
109
- end
110
-
111
- it "returns the value when the node matches" do
112
- allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
113
- allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
114
- expect(node_map.get(node, :thing)).to eql(:foo)
115
- end
116
-
117
- it "returns nil when the block does not match" do
118
- allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
119
- allow(node).to receive(:[]).with(:platform_version).and_return("6.4")
120
- expect(node_map.get(node, :thing)).to eql(nil)
121
- end
122
-
123
- it "returns nil when the platform_family filter does not match" do
124
- allow(node).to receive(:[]).with(:platform_family).and_return("debian")
125
- allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
126
- expect(node_map.get(node, :thing)).to eql(nil)
127
- end
128
-
129
- it "returns nil when both do not match" do
130
- allow(node).to receive(:[]).with(:platform_family).and_return("debian")
131
- allow(node).to receive(:[]).with(:platform_version).and_return("6.0")
132
- expect(node_map.get(node, :thing)).to eql(nil)
133
- end
134
-
135
- context "when there is a less specific definition" do
136
- before do
137
- node_map.set(:thing, :bar, platform_family: "rhel")
138
- end
139
-
140
- it "returns the value when the node matches" do
141
- allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
142
- allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
143
- expect(node_map.get(node, :thing)).to eql(:foo)
144
- end
145
- end
146
- end
147
-
148
- describe "resource back-compat testing" do
149
- before :each do
150
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
151
- end
152
-
153
- it "should handle :on_platforms => :all" do
154
- node_map.set(:chef_gem, :foo, :on_platforms => :all)
155
- allow(node).to receive(:[]).with(:platform).and_return("windows")
156
- expect(node_map.get(node, :chef_gem)).to eql(:foo)
157
- end
158
- it "should handle :on_platforms => [ 'windows' ]" do
159
- node_map.set(:dsc_script, :foo, :on_platforms => [ "windows" ])
160
- allow(node).to receive(:[]).with(:platform).and_return("windows")
161
- expect(node_map.get(node, :dsc_script)).to eql(:foo)
162
- end
163
- it "should handle :on_platform => :all" do
164
- node_map.set(:link, :foo, :on_platform => :all)
165
- allow(node).to receive(:[]).with(:platform).and_return("windows")
166
- expect(node_map.get(node, :link)).to eql(:foo)
167
- end
168
- end
169
-
170
- end
1
+ #
2
+ # Author:: Lamont Granquist (<lamont@chef.io>)
3
+ # Copyright:: Copyright 2014-2016, Chef Software, Inc.
4
+ # License:: Apache License, Version 2.0
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+ #
18
+
19
+ require "spec_helper"
20
+ require "chef/node_map"
21
+
22
+ describe Chef::NodeMap do
23
+
24
+ let(:node_map) { Chef::NodeMap.new }
25
+
26
+ let(:node) { Chef::Node.new }
27
+
28
+ describe "with a bad filter name" do
29
+ it "should raise an error" do
30
+ expect { node_map.set(node, :thing, on_platform_family: "rhel") }.to raise_error(ArgumentError)
31
+ end
32
+ end
33
+
34
+ describe "when no matchers are set at all" do
35
+ before do
36
+ node_map.set(:thing, :foo)
37
+ end
38
+
39
+ it "returns the value" do
40
+ expect(node_map.get(node, :thing)).to eql(:foo)
41
+ end
42
+
43
+ it "returns nil for keys that do not exist" do
44
+ expect(node_map.get(node, :other_thing)).to eql(nil)
45
+ end
46
+ end
47
+
48
+ describe "filtering by os" do
49
+ before do
50
+ node_map.set(:thing, :foo, os: ["windows"])
51
+ node_map.set(:thing, :bar, os: "linux")
52
+ end
53
+ it "returns the correct value for windows" do
54
+ allow(node).to receive(:[]).with(:os).and_return("windows")
55
+ expect(node_map.get(node, :thing)).to eql(:foo)
56
+ end
57
+ it "returns the correct value for linux" do
58
+ allow(node).to receive(:[]).with(:os).and_return("linux")
59
+ expect(node_map.get(node, :thing)).to eql(:bar)
60
+ end
61
+ it "returns nil for a non-matching os" do
62
+ allow(node).to receive(:[]).with(:os).and_return("freebsd")
63
+ expect(node_map.get(node, :thing)).to eql(nil)
64
+ end
65
+ end
66
+
67
+ describe "rejecting an os" do
68
+ before do
69
+ node_map.set(:thing, :foo, os: "!windows")
70
+ end
71
+ it "returns nil for windows" do
72
+ allow(node).to receive(:[]).with(:os).and_return("windows")
73
+ expect(node_map.get(node, :thing)).to eql(nil)
74
+ end
75
+ it "returns the correct value for linux" do
76
+ allow(node).to receive(:[]).with(:os).and_return("linux")
77
+ expect(node_map.get(node, :thing)).to eql(:foo)
78
+ end
79
+ end
80
+
81
+ describe "filtering by os and platform_family" do
82
+ before do
83
+ node_map.set(:thing, :bar, os: "linux", platform_family: "rhel")
84
+ end
85
+
86
+ it "returns the correct value when both match" do
87
+ allow(node).to receive(:[]).with(:os).and_return("linux")
88
+ allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
89
+ expect(node_map.get(node, :thing)).to eql(:bar)
90
+ end
91
+
92
+ it "returns nil for a non-matching os" do
93
+ allow(node).to receive(:[]).with(:os).and_return("freebsd")
94
+ expect(node_map.get(node, :thing)).to eql(nil)
95
+ end
96
+
97
+ it "returns nil when the platform_family does not match" do
98
+ allow(node).to receive(:[]).with(:os).and_return("linux")
99
+ allow(node).to receive(:[]).with(:platform_family).and_return("debian")
100
+ expect(node_map.get(node, :thing)).to eql(nil)
101
+ end
102
+ end
103
+
104
+ describe "with a block doing platform_version checks" do
105
+ before do
106
+ node_map.set(:thing, :foo, platform_family: "rhel") do |node|
107
+ node[:platform_version].to_i >= 7
108
+ end
109
+ end
110
+
111
+ it "returns the value when the node matches" do
112
+ allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
113
+ allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
114
+ expect(node_map.get(node, :thing)).to eql(:foo)
115
+ end
116
+
117
+ it "returns nil when the block does not match" do
118
+ allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
119
+ allow(node).to receive(:[]).with(:platform_version).and_return("6.4")
120
+ expect(node_map.get(node, :thing)).to eql(nil)
121
+ end
122
+
123
+ it "returns nil when the platform_family filter does not match" do
124
+ allow(node).to receive(:[]).with(:platform_family).and_return("debian")
125
+ allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
126
+ expect(node_map.get(node, :thing)).to eql(nil)
127
+ end
128
+
129
+ it "returns nil when both do not match" do
130
+ allow(node).to receive(:[]).with(:platform_family).and_return("debian")
131
+ allow(node).to receive(:[]).with(:platform_version).and_return("6.0")
132
+ expect(node_map.get(node, :thing)).to eql(nil)
133
+ end
134
+
135
+ context "when there is a less specific definition" do
136
+ before do
137
+ node_map.set(:thing, :bar, platform_family: "rhel")
138
+ end
139
+
140
+ it "returns the value when the node matches" do
141
+ allow(node).to receive(:[]).with(:platform_family).and_return("rhel")
142
+ allow(node).to receive(:[]).with(:platform_version).and_return("7.0")
143
+ expect(node_map.get(node, :thing)).to eql(:foo)
144
+ end
145
+ end
146
+ end
147
+
148
+ describe "resource back-compat testing" do
149
+ before :each do
150
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
151
+ end
152
+
153
+ it "should handle :on_platforms => :all" do
154
+ node_map.set(:chef_gem, :foo, :on_platforms => :all)
155
+ allow(node).to receive(:[]).with(:platform).and_return("windows")
156
+ expect(node_map.get(node, :chef_gem)).to eql(:foo)
157
+ end
158
+ it "should handle :on_platforms => [ 'windows' ]" do
159
+ node_map.set(:dsc_script, :foo, :on_platforms => [ "windows" ])
160
+ allow(node).to receive(:[]).with(:platform).and_return("windows")
161
+ expect(node_map.get(node, :dsc_script)).to eql(:foo)
162
+ end
163
+ it "should handle :on_platform => :all" do
164
+ node_map.set(:link, :foo, :on_platform => :all)
165
+ allow(node).to receive(:[]).with(:platform).and_return("windows")
166
+ expect(node_map.get(node, :link)).to eql(:foo)
167
+ end
168
+ end
169
+
170
+ end
@@ -1,1836 +1,1836 @@
1
- #
2
- # Author:: Adam Jacob (<adam@chef.io>)
3
- # Copyright:: Copyright 2008-2016, 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 an environment with chef_environment(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 you to set an attribute via method_missing" do
242
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
243
- expect { node.sunshine = "is bright" }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
244
- end
245
-
246
- it "does not allow modification of node attributes via hash methods" do
247
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
248
- node.default["h4sh"] = { foo: "bar" }
249
- expect { node["h4sh"].delete("foo") }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
250
- expect { node.h4sh.delete("foo") }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
251
- end
252
-
253
- it "does not allow modification of node attributes via array methods" do
254
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
255
- node.default["array"] = []
256
- expect { node["array"] << "boom" }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
257
- expect { node.array << "boom" }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
258
- end
259
-
260
- it "returns merged immutable attributes for arrays" do
261
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
262
- node.default["array"] = []
263
- expect( node["array"].class ).to eql(Chef::Node::ImmutableArray)
264
- expect( node.array.class ).to eql(Chef::Node::ImmutableArray)
265
- end
266
-
267
- it "returns merged immutable attributes for hashes" do
268
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
269
- node.default["h4sh"] = {}
270
- expect( node["h4sh"].class ).to eql(Chef::Node::ImmutableMash)
271
- expect( node.h4sh.class ).to eql(Chef::Node::ImmutableMash)
272
- end
273
-
274
- it "should allow you get get an attribute via method_missing" do
275
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
276
- node.default.sunshine = "is bright"
277
- expect(node.sunshine).to eql("is bright")
278
- end
279
-
280
- describe "normal attributes" do
281
- it "should allow you to set an attribute with set, without pre-declaring a hash" do
282
- node.normal[:snoopy][:is_a_puppy] = true
283
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
284
- end
285
-
286
- it "should allow you to set an attribute with set_unless with method_missing but emit a deprecation warning" do
287
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
288
- node.normal_unless.snoopy.is_a_puppy = false
289
- expect(node[:snoopy][:is_a_puppy]).to eq(false)
290
- end
291
-
292
- it "should allow you to set an attribute with set_unless" do
293
- node.normal_unless[:snoopy][:is_a_puppy] = false
294
- expect(node[:snoopy][:is_a_puppy]).to eq(false)
295
- end
296
-
297
- it "should not allow you to set an attribute with set_unless if it already exists" do
298
- node.normal[:snoopy][:is_a_puppy] = true
299
- node.normal_unless[:snoopy][:is_a_puppy] = false
300
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
301
- end
302
-
303
- it "should allow you to set an attribute with set_unless if is a nil value" do
304
- node.attributes.normal = { snoopy: { is_a_puppy: nil } }
305
- node.normal_unless[:snoopy][:is_a_puppy] = false
306
- expect(node[:snoopy][:is_a_puppy]).to eq(false)
307
- end
308
-
309
- it "should allow you to set a value after a set_unless" do
310
- # this tests for set_unless_present state bleeding between statements CHEF-3806
311
- node.normal_unless[:snoopy][:is_a_puppy] = false
312
- node.normal[:snoopy][:is_a_puppy] = true
313
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
314
- end
315
-
316
- it "should let you set a value after a 'dangling' set_unless" do
317
- # this tests for set_unless_present state bleeding between statements CHEF-3806
318
- node.normal[:snoopy][:is_a_puppy] = "what"
319
- node.normal_unless[:snoopy][:is_a_puppy]
320
- node.normal[:snoopy][:is_a_puppy] = true
321
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
322
- end
323
-
324
- it "auto-vivifies attributes created via method syntax" do
325
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
326
- node.normal.fuu.bahrr.baz = "qux"
327
- expect(node.fuu.bahrr.baz).to eq("qux")
328
- end
329
-
330
- it "should let you use tag as a convience method for the tags attribute" do
331
- node.normal["tags"] = %w{one two}
332
- node.tag("three", "four")
333
- expect(node["tags"]).to eq(%w{one two three four})
334
- end
335
-
336
- it "set is a deprecated alias for normal" do
337
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
338
- expect(Chef).to receive(:deprecated).with(:attributes, /set is deprecated/)
339
- node.set[:snoopy][:is_a_puppy] = true
340
- expect(node.normal[:snoopy][:is_a_puppy]).to eq(true)
341
- end
342
-
343
- it "set_unless is a deprecated alias for normal_unless" do
344
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
345
- expect(Chef).to receive(:deprecated).with(:attributes, /set_unless is deprecated/)
346
- node.set_unless[:snoopy][:is_a_puppy] = false
347
- expect(node.normal[:snoopy][:is_a_puppy]).to eq(false)
348
- end
349
-
350
- it "normal_unless sets a value even if default or override attrs are set" do
351
- node.default[:decontamination] = true
352
- node.override[:decontamination] = false
353
- node.normal_unless[:decontamination] = "foo"
354
- expect(node.normal[:decontamination]).to eql("foo")
355
- end
356
-
357
- it "default_unless sets a value even if normal or override attrs are set" do
358
- node.normal[:decontamination] = true
359
- node.override[:decontamination] = false
360
- node.default_unless[:decontamination] = "foo"
361
- expect(node.default[:decontamination]).to eql("foo")
362
- end
363
-
364
- it "override_unless sets a value even if default or normal attrs are set" do
365
- node.default[:decontamination] = true
366
- node.normal[:decontamination] = false
367
- node.override_unless[:decontamination] = "foo"
368
- expect(node.override[:decontamination]).to eql("foo")
369
- end
370
- end
371
-
372
- describe "default attributes" do
373
- it "should be set with default, without pre-declaring a hash" do
374
- node.default[:snoopy][:is_a_puppy] = true
375
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
376
- end
377
-
378
- it "should allow you to set with default_unless without pre-declaring a hash" do
379
- node.default_unless[:snoopy][:is_a_puppy] = false
380
- expect(node[:snoopy][:is_a_puppy]).to eq(false)
381
- end
382
-
383
- it "should not allow you to set an attribute with default_unless if it already exists" do
384
- node.default[:snoopy][:is_a_puppy] = true
385
- node.default_unless[:snoopy][:is_a_puppy] = false
386
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
387
- end
388
-
389
- it "should allow you to set a value after a default_unless" do
390
- # this tests for set_unless_present state bleeding between statements CHEF-3806
391
- node.default_unless[:snoopy][:is_a_puppy] = false
392
- node.default[:snoopy][:is_a_puppy] = true
393
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
394
- end
395
-
396
- it "should allow you to set a value after a 'dangling' default_unless" do
397
- # this tests for set_unless_present state bleeding between statements CHEF-3806
398
- node.default[:snoopy][:is_a_puppy] = "what"
399
- node.default_unless[:snoopy][:is_a_puppy]
400
- node.default[:snoopy][:is_a_puppy] = true
401
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
402
- end
403
-
404
- it "does not exhibit chef/chef/issues/5005 bug" do
405
- node.env_default["a"]["r1"]["g"]["u"] = "u1"
406
- node.default_unless["a"]["r1"]["g"]["r"] = "r"
407
- expect(node["a"]["r1"]["g"]["u"]).to eql("u1")
408
- end
409
-
410
- it "auto-vivifies attributes created via method syntax" do
411
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
412
- node.default.fuu.bahrr.baz = "qux"
413
- expect(node.fuu.bahrr.baz).to eq("qux")
414
- end
415
-
416
- it "default_unless correctly resets the deep merge cache" do
417
- node.normal["tags"] = [] # this sets our top-level breadcrumb
418
- node.default_unless["foo"]["bar"] = "NK-19V"
419
- expect(node["foo"]["bar"]).to eql("NK-19V")
420
- node.default_unless["foo"]["baz"] = "NK-33"
421
- expect(node["foo"]["baz"]).to eql("NK-33")
422
- end
423
-
424
- it "normal_unless correctly resets the deep merge cache" do
425
- node.normal["tags"] = [] # this sets our top-level breadcrumb
426
- node.normal_unless["foo"]["bar"] = "NK-19V"
427
- expect(node["foo"]["bar"]).to eql("NK-19V")
428
- node.normal_unless["foo"]["baz"] = "NK-33"
429
- expect(node["foo"]["baz"]).to eql("NK-33")
430
- end
431
-
432
- it "override_unless correctly resets the deep merge cache" do
433
- node.normal["tags"] = [] # this sets our top-level breadcrumb
434
- node.override_unless["foo"]["bar"] = "NK-19V"
435
- expect(node["foo"]["bar"]).to eql("NK-19V")
436
- node.override_unless["foo"]["baz"] = "NK-33"
437
- expect(node["foo"]["baz"]).to eql("NK-33")
438
- end
439
- end
440
-
441
- describe "override attributes" do
442
- it "should be set with override, without pre-declaring a hash" do
443
- node.override[:snoopy][:is_a_puppy] = true
444
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
445
- end
446
-
447
- it "should allow you to set with override_unless without pre-declaring a hash" do
448
- node.override_unless[:snoopy][:is_a_puppy] = false
449
- expect(node[:snoopy][:is_a_puppy]).to eq(false)
450
- end
451
-
452
- it "should not allow you to set an attribute with override_unless if it already exists" do
453
- node.override[:snoopy][:is_a_puppy] = true
454
- node.override_unless[:snoopy][:is_a_puppy] = false
455
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
456
- end
457
-
458
- it "should allow you to set a value after an override_unless" do
459
- # this tests for set_unless_present state bleeding between statements CHEF-3806
460
- node.override_unless[:snoopy][:is_a_puppy] = false
461
- node.override[:snoopy][:is_a_puppy] = true
462
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
463
- end
464
-
465
- it "should allow you to set a value after a 'dangling' override_unless" do
466
- # this tests for set_unless_present state bleeding between statements CHEF-3806
467
- node.override_unless[:snoopy][:is_a_puppy] = "what"
468
- node.override_unless[:snoopy][:is_a_puppy]
469
- node.override[:snoopy][:is_a_puppy] = true
470
- expect(node[:snoopy][:is_a_puppy]).to eq(true)
471
- end
472
-
473
- it "auto-vivifies attributes created via method syntax" do
474
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
475
- node.override.fuu.bahrr.baz = "qux"
476
- expect(node.fuu.bahrr.baz).to eq("qux")
477
- end
478
- end
479
-
480
- describe "globally deleting attributes" do
481
- context "with hash values" do
482
- before do
483
- node.role_default["mysql"]["server"]["port"] = 1234
484
- node.normal["mysql"]["server"]["port"] = 2345
485
- node.override["mysql"]["server"]["port"] = 3456
486
- end
487
-
488
- it "deletes all the values and returns the value with the highest precidence" do
489
- expect( node.rm("mysql", "server", "port") ).to eql(3456)
490
- expect( node["mysql"]["server"]["port"] ).to be_nil
491
- expect( node["mysql"]["server"] ).to eql({})
492
- end
493
-
494
- it "deletes nested things correctly" do
495
- node.default["mysql"]["client"]["client_setting"] = "foo"
496
- expect( node.rm("mysql", "server") ).to eql( { "port" => 3456 } )
497
- expect( node["mysql"] ).to eql( { "client" => { "client_setting" => "foo" } } )
498
- end
499
-
500
- it "returns nil if the node attribute does not exist" do
501
- expect( node.rm("no", "such", "thing") ).to be_nil
502
- end
503
-
504
- it "can delete the entire tree" do
505
- expect( node.rm("mysql") ).to eql({ "server" => { "port" => 3456 } })
506
- end
507
- end
508
-
509
- context "when trying to delete through a thing that isn't an array-like or hash-like object" do
510
- before do
511
- node.default["mysql"] = true
512
- end
513
-
514
- it "returns nil when you're two levels deeper" do
515
- expect( node.rm("mysql", "server", "port") ).to eql(nil)
516
- end
517
-
518
- it "returns nil when you're one level deeper" do
519
- expect( node.rm("mysql", "server") ).to eql(nil)
520
- end
521
-
522
- it "correctly deletes at the top level" do
523
- expect( node.rm("mysql") ).to eql(true)
524
- end
525
- end
526
-
527
- context "with array indexes" do
528
- before do
529
- node.role_default["mysql"]["server"][0]["port"] = 1234
530
- node.normal["mysql"]["server"][0]["port"] = 2345
531
- node.override["mysql"]["server"][0]["port"] = 3456
532
- node.override["mysql"]["server"][1]["port"] = 3456
533
- end
534
-
535
- it "deletes the array element" do
536
- expect( node.rm("mysql", "server", 0, "port") ).to eql(3456)
537
- expect( node["mysql"]["server"][0]["port"] ).to be_nil
538
- expect( node["mysql"]["server"][1]["port"] ).to eql(3456)
539
- end
540
- end
541
-
542
- context "with real arrays" do
543
- before do
544
- node.role_default["mysql"]["server"] = [ {
545
- "port" => 1234,
546
- } ]
547
- node.normal["mysql"]["server"] = [ {
548
- "port" => 2345,
549
- } ]
550
- node.override["mysql"]["server"] = [ {
551
- "port" => 3456,
552
- } ]
553
- end
554
-
555
- it "deletes the array element" do
556
- expect( node.rm("mysql", "server", 0, "port") ).to eql(3456)
557
- expect( node["mysql"]["server"][0]["port"] ).to be_nil
558
- end
559
-
560
- it "when mistaking arrays for hashes, it considers the value removed and does nothing" do
561
- node.rm("mysql", "server", "port")
562
- expect(node["mysql"]["server"][0]["port"]).to eql(3456)
563
- end
564
- end
565
- end
566
-
567
- describe "granular deleting attributes" do
568
- context "when only defaults exist" do
569
- before do
570
- node.role_default["mysql"]["server"]["port"] = 1234
571
- node.default["mysql"]["server"]["port"] = 2345
572
- node.force_default["mysql"]["server"]["port"] = 3456
573
- end
574
-
575
- it "returns the deleted values" do
576
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
577
- end
578
-
579
- it "returns nil for the combined attribues" do
580
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
581
- expect( node["mysql"]["server"]["port"] ).to eql(nil)
582
- end
583
-
584
- it "returns an empty hash for the default attrs" do
585
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
586
- # this auto-vivifies, should it?
587
- expect( node.default_attrs["mysql"]["server"]["port"] ).to eql({})
588
- end
589
-
590
- it "returns an empty hash after the last key is deleted" do
591
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
592
- expect( node["mysql"]["server"] ).to eql({})
593
- end
594
- end
595
-
596
- context "when trying to delete through a thing that isn't an array-like or hash-like object" do
597
- before do
598
- node.default["mysql"] = true
599
- end
600
-
601
- it "returns nil when you're two levels deeper" do
602
- expect( node.rm_default("mysql", "server", "port") ).to eql(nil)
603
- end
604
-
605
- it "returns nil when you're one level deeper" do
606
- expect( node.rm_default("mysql", "server") ).to eql(nil)
607
- end
608
-
609
- it "correctly deletes at the top level" do
610
- expect( node.rm_default("mysql") ).to eql(true)
611
- end
612
- end
613
-
614
- context "when a higher precedence exists" do
615
- before do
616
- node.role_default["mysql"]["server"]["port"] = 1234
617
- node.default["mysql"]["server"]["port"] = 2345
618
- node.force_default["mysql"]["server"]["port"] = 3456
619
-
620
- node.override["mysql"]["server"]["port"] = 9999
621
- end
622
-
623
- it "returns the deleted values" do
624
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
625
- end
626
-
627
- it "returns the higher precedence values after the delete" do
628
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
629
- expect( node["mysql"]["server"]["port"] ).to eql(9999)
630
- end
631
-
632
- it "returns an empty has for the default attrs" do
633
- expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
634
- # this auto-vivifies, should it?
635
- expect( node.default_attrs["mysql"]["server"]["port"] ).to eql({})
636
- end
637
- end
638
-
639
- context "when a lower precedence exists" do
640
- before do
641
- node.default["mysql"]["server"]["port"] = 2345
642
- node.override["mysql"]["server"]["port"] = 9999
643
- node.role_override["mysql"]["server"]["port"] = 9876
644
- node.force_override["mysql"]["server"]["port"] = 6669
645
- end
646
-
647
- it "returns the deleted values" do
648
- expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
649
- end
650
-
651
- it "returns the lower precedence levels after the delete" do
652
- expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
653
- expect( node["mysql"]["server"]["port"] ).to eql(2345)
654
- end
655
-
656
- it "returns an empty has for the override attrs" do
657
- expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
658
- # this auto-vivifies, should it?
659
- expect( node.override_attrs["mysql"]["server"]["port"] ).to eql({})
660
- end
661
- end
662
-
663
- it "rm_default returns nil on deleting non-existent values" do
664
- expect( node.rm_default("no", "such", "thing") ).to be_nil
665
- end
666
-
667
- it "rm_normal returns nil on deleting non-existent values" do
668
- expect( node.rm_normal("no", "such", "thing") ).to be_nil
669
- end
670
-
671
- it "rm_override returns nil on deleting non-existent values" do
672
- expect( node.rm_override("no", "such", "thing") ).to be_nil
673
- end
674
- end
675
-
676
- describe "granular replacing attributes" do
677
- it "removes everything at the level of the last key" do
678
- node.default["mysql"]["server"]["port"] = 2345
679
-
680
- node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
681
-
682
- expect( node["mysql"]["server"] ).to eql({ "data_dir" => "/my_raid_volume/lib/mysql" })
683
- end
684
-
685
- it "replaces a value at the cookbook sub-level of the atributes only" do
686
- node.default["mysql"]["server"]["port"] = 2345
687
- node.default["mysql"]["server"]["service_name"] = "fancypants-sql"
688
- node.role_default["mysql"]["server"]["port"] = 1234
689
- node.force_default["mysql"]["server"]["port"] = 3456
690
-
691
- node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
692
-
693
- expect( node["mysql"]["server"]["port"] ).to eql(3456)
694
- expect( node["mysql"]["server"]["service_name"] ).to be_nil
695
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
696
- expect( node["mysql"]["server"] ).to eql({ "port" => 3456, "data_dir" => "/my_raid_volume/lib/mysql" })
697
- end
698
-
699
- it "higher precedence values aren't removed" do
700
- node.role_default["mysql"]["server"]["port"] = 1234
701
- node.default["mysql"]["server"]["port"] = 2345
702
- node.force_default["mysql"]["server"]["port"] = 3456
703
- node.override["mysql"]["server"]["service_name"] = "fancypants-sql"
704
-
705
- node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
706
-
707
- expect( node["mysql"]["server"]["port"] ).to eql(3456)
708
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
709
- expect( node["mysql"]["server"] ).to eql({ "service_name" => "fancypants-sql", "port" => 3456, "data_dir" => "/my_raid_volume/lib/mysql" })
710
- end
711
- end
712
-
713
- describe "granular force replacing attributes" do
714
- it "removes everything at the level of the last key" do
715
- node.force_default["mysql"]["server"]["port"] = 2345
716
-
717
- node.force_default!["mysql"]["server"] = {
718
- "data_dir" => "/my_raid_volume/lib/mysql",
719
- }
720
-
721
- expect( node["mysql"]["server"] ).to eql({
722
- "data_dir" => "/my_raid_volume/lib/mysql",
723
- })
724
- end
725
-
726
- it "removes all values from the precedence level when setting" do
727
- node.role_default["mysql"]["server"]["port"] = 1234
728
- node.default["mysql"]["server"]["port"] = 2345
729
- node.force_default["mysql"]["server"]["port"] = 3456
730
-
731
- node.force_default!["mysql"]["server"] = {
732
- "data_dir" => "/my_raid_volume/lib/mysql",
733
- }
734
-
735
- expect( node["mysql"]["server"]["port"] ).to be_nil
736
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
737
- expect( node["mysql"]["server"] ).to eql({
738
- "data_dir" => "/my_raid_volume/lib/mysql",
739
- })
740
- end
741
-
742
- it "higher precedence levels are not removed" do
743
- node.role_default["mysql"]["server"]["port"] = 1234
744
- node.default["mysql"]["server"]["port"] = 2345
745
- node.force_default["mysql"]["server"]["port"] = 3456
746
- node.override["mysql"]["server"]["service_name"] = "fancypants-sql"
747
-
748
- node.force_default!["mysql"]["server"] = {
749
- "data_dir" => "/my_raid_volume/lib/mysql",
750
- }
751
-
752
- expect( node["mysql"]["server"]["port"] ).to be_nil
753
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
754
- expect( node["mysql"]["server"] ).to eql({
755
- "service_name" => "fancypants-sql",
756
- "data_dir" => "/my_raid_volume/lib/mysql",
757
- })
758
- end
759
-
760
- it "will autovivify" do
761
- node.force_default!["mysql"]["server"] = {
762
- "data_dir" => "/my_raid_volume/lib/mysql",
763
- }
764
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
765
- end
766
-
767
- it "lower precedence levels aren't removed" do
768
- node.role_override["mysql"]["server"]["port"] = 1234
769
- node.override["mysql"]["server"]["port"] = 2345
770
- node.force_override["mysql"]["server"]["port"] = 3456
771
- node.default["mysql"]["server"]["service_name"] = "fancypants-sql"
772
-
773
- node.force_override!["mysql"]["server"] = {
774
- "data_dir" => "/my_raid_volume/lib/mysql",
775
- }
776
-
777
- expect( node["mysql"]["server"]["port"] ).to be_nil
778
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
779
- expect( node["mysql"]["server"] ).to eql({
780
- "service_name" => "fancypants-sql",
781
- "data_dir" => "/my_raid_volume/lib/mysql",
782
- })
783
- end
784
-
785
- it "when overwriting a non-hash/array" do
786
- node.override["mysql"] = false
787
- node.force_override["mysql"] = true
788
- node.force_override!["mysql"]["server"] = {
789
- "data_dir" => "/my_raid_volume/lib/mysql",
790
- }
791
- expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
792
- end
793
-
794
- it "when overwriting an array with a hash" do
795
- node.force_override["mysql"][0] = true
796
- node.force_override!["mysql"]["server"] = {
797
- "data_dir" => "/my_raid_volume/lib/mysql",
798
- }
799
- expect( node["mysql"]["server"] ).to eql({
800
- "data_dir" => "/my_raid_volume/lib/mysql",
801
- })
802
- end
803
- end
804
-
805
- # In Chef-12.0 there is a deep_merge cache on the top level attribute which had a bug
806
- # where it cached node[:foo] separate from node['foo']. These tests exercise those edge conditions.
807
- #
808
- # https://github.com/chef/chef/issues/2700
809
- # https://github.com/chef/chef/issues/2712
810
- # https://github.com/chef/chef/issues/2745
811
- #
812
- describe "deep merge attribute cache edge conditions" do
813
- it "does not error with complicated attribute substitution" do
814
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
815
- node.default["chef_attribute_hell"]["attr1"] = "attribute1"
816
- node.default["chef_attribute_hell"]["attr2"] = "#{node.chef_attribute_hell.attr1}/attr2"
817
- expect { node.default["chef_attribute_hell"]["attr3"] = "#{node.chef_attribute_hell.attr2}/attr3" }.not_to raise_error
818
- end
819
-
820
- it "caches both strings and symbols correctly" do
821
- node.force_default[:solr][:version] = "4.10.2"
822
- node.force_default[:solr][:data_dir] = "/opt/solr-#{node['solr'][:version]}/example/solr"
823
- node.force_default[:solr][:xms] = "512M"
824
- expect(node[:solr][:xms]).to eql("512M")
825
- expect(node["solr"][:xms]).to eql("512M")
826
- end
827
-
828
- it "method interpolation syntax also works" do
829
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
830
- node.default["passenger"]["version"] = "4.0.57"
831
- node.default["passenger"]["root_path"] = "passenger-#{node['passenger']['version']}"
832
- node.default["passenger"]["root_path_2"] = "passenger-#{node.passenger['version']}"
833
- expect(node["passenger"]["root_path_2"]).to eql("passenger-4.0.57")
834
- expect(node[:passenger]["root_path_2"]).to eql("passenger-4.0.57")
835
- end
836
- end
837
-
838
- it "should raise an ArgumentError if you ask for an attribute that doesn't exist via method_missing" do
839
- Chef::Config[:treat_deprecation_warnings_as_errors] = false
840
- expect { node.sunshine }.to raise_error(NoMethodError)
841
- end
842
-
843
- it "should allow you to iterate over attributes with each_attribute" do
844
- node.default.sunshine = "is bright"
845
- node.default.canada = "is a nice place"
846
- seen_attributes = Hash.new
847
- node.each_attribute do |a, v|
848
- seen_attributes[a] = v
849
- end
850
- expect(seen_attributes).to have_key("sunshine")
851
- expect(seen_attributes).to have_key("canada")
852
- expect(seen_attributes["sunshine"]).to eq("is bright")
853
- expect(seen_attributes["canada"]).to eq("is a nice place")
854
- end
855
-
856
- describe "functional attribute API" do
857
- # deeper functional testing of this API is in the VividMash spec tests
858
- it "should have an exist? function" do
859
- node.default["foo"]["bar"] = "baz"
860
- expect(node.exist?("foo", "bar")).to be true
861
- expect(node.exist?("bar", "foo")).to be false
862
- end
863
-
864
- it "should have a read function" do
865
- node.override["foo"]["bar"] = "baz"
866
- expect(node.read("foo", "bar")).to eql("baz")
867
- expect(node.read("bar", "foo")).to eql(nil)
868
- end
869
-
870
- it "should have a read! function" do
871
- node.override["foo"]["bar"] = "baz"
872
- expect(node.read!("foo", "bar")).to eql("baz")
873
- expect { node.read!("bar", "foo") }.to raise_error(Chef::Exceptions::NoSuchAttribute)
874
- end
875
-
876
- it "delegates write(:level) to node.level.write()" do
877
- node.write(:default, "foo", "bar", "baz")
878
- expect(node.default["foo"]["bar"]).to eql("baz")
879
- end
880
-
881
- it "delegates write!(:level) to node.level.write!()" do
882
- node.write!(:default, "foo", "bar", "baz")
883
- expect(node.default["foo"]["bar"]).to eql("baz")
884
- node.default["bar"] = true
885
- expect { node.write!(:default, "bar", "foo", "baz") }.to raise_error(Chef::Exceptions::AttributeTypeMismatch)
886
- end
887
-
888
- it "delegates unlink(:level) to node.level.unlink()" do
889
- node.default["foo"]["bar"] = "baz"
890
- expect(node.unlink(:default, "foo", "bar")).to eql("baz")
891
- expect(node.unlink(:default, "bar", "foo")).to eql(nil)
892
- end
893
-
894
- it "delegates unlink!(:level) to node.level.unlink!()" do
895
- node.default["foo"]["bar"] = "baz"
896
- expect(node.unlink!(:default, "foo", "bar")).to eql("baz")
897
- expect { node.unlink!(:default, "bar", "foo") }.to raise_error(Chef::Exceptions::NoSuchAttribute)
898
- end
899
- end
900
- end
901
-
902
- describe "consuming json" do
903
-
904
- before do
905
- @ohai_data = { :platform => "foo", :platform_version => "bar" }
906
- end
907
-
908
- it "consumes the run list portion of a collection of attributes and returns the remainder" do
909
- attrs = { "run_list" => [ "role[base]", "recipe[chef::server]" ], "foo" => "bar" }
910
- expect(node.consume_run_list(attrs)).to eq({ "foo" => "bar" })
911
- expect(node.run_list).to eq([ "role[base]", "recipe[chef::server]" ])
912
- end
913
-
914
- it "sets the node chef_environment" do
915
- attrs = { "chef_environment" => "foo_environment", "bar" => "baz" }
916
- expect(node.consume_chef_environment(attrs)).to eq({ "bar" => "baz" })
917
- expect(node.chef_environment).to eq("foo_environment")
918
- expect(node["chef_environment"]).to be nil
919
- end
920
-
921
- it "should overwrites the run list with the run list it consumes" do
922
- node.consume_run_list "recipes" => %w{one two}
923
- node.consume_run_list "recipes" => [ "three" ]
924
- expect(node.run_list).to eq([ "three" ])
925
- end
926
-
927
- it "should not add duplicate recipes from the json attributes" do
928
- node.run_list << "one"
929
- node.consume_run_list "recipes" => %w{one two three}
930
- expect(node.run_list).to eq(%w{one two three})
931
- end
932
-
933
- it "doesn't change the run list if no run_list is specified in the json" do
934
- node.run_list << "role[database]"
935
- node.consume_run_list "foo" => "bar"
936
- expect(node.run_list).to eq(["role[database]"])
937
- end
938
-
939
- it "raises an exception if you provide both recipe and run_list attributes, since this is ambiguous" do
940
- expect { node.consume_run_list "recipes" => "stuff", "run_list" => "other_stuff" }.to raise_error(Chef::Exceptions::AmbiguousRunlistSpecification)
941
- end
942
-
943
- it "should add json attributes to the node" do
944
- node.consume_external_attrs(@ohai_data, { "one" => "two", "three" => "four" })
945
- expect(node["one"]).to eql("two")
946
- expect(node["three"]).to eql("four")
947
- end
948
-
949
- it "should set the tags attribute to an empty array if it is not already defined" do
950
- node.consume_external_attrs(@ohai_data, {})
951
- expect(node.tags).to eql([])
952
- end
953
-
954
- it "should not set the tags attribute to an empty array if it is already defined" do
955
- node.tag("radiohead")
956
- node.consume_external_attrs(@ohai_data, {})
957
- expect(node.tags).to eql([ "radiohead" ])
958
- end
959
-
960
- it "should set the tags attribute to an empty array if it is nil" do
961
- node.attributes.normal = { "tags" => nil }
962
- node.consume_external_attrs(@ohai_data, {})
963
- expect(node.tags).to eql([])
964
- end
965
-
966
- it "should return an array if it is fed a string" do
967
- node.normal[:tags] = "string"
968
- node.consume_external_attrs(@ohai_data, {})
969
- expect(node.tags).to eql(["string"])
970
- end
971
-
972
- it "should return an array if it is fed a hash" do
973
- node.normal[:tags] = {}
974
- node.consume_external_attrs(@ohai_data, {})
975
- expect(node.tags).to eql([])
976
- end
977
-
978
- it "deep merges attributes instead of overwriting them" do
979
- node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "four" } })
980
- expect(node["one"].to_hash).to eq({ "two" => { "three" => "four" } })
981
- node.consume_external_attrs(@ohai_data, "one" => { "abc" => "123" })
982
- node.consume_external_attrs(@ohai_data, "one" => { "two" => { "foo" => "bar" } })
983
- expect(node["one"].to_hash).to eq({ "two" => { "three" => "four", "foo" => "bar" }, "abc" => "123" })
984
- end
985
-
986
- it "gives attributes from JSON priority when deep merging" do
987
- node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "four" } })
988
- expect(node["one"].to_hash).to eq({ "two" => { "three" => "four" } })
989
- node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "forty-two" } })
990
- expect(node["one"].to_hash).to eq({ "two" => { "three" => "forty-two" } })
991
- end
992
-
993
- end
994
-
995
- describe "preparing for a chef client run" do
996
- before do
997
- @ohai_data = { :platform => "foobuntu", :platform_version => "23.42" }
998
- end
999
-
1000
- it "sets its platform according to platform detection" do
1001
- node.consume_external_attrs(@ohai_data, {})
1002
- expect(node.automatic_attrs[:platform]).to eq("foobuntu")
1003
- expect(node.automatic_attrs[:platform_version]).to eq("23.42")
1004
- end
1005
-
1006
- it "consumes the run list from provided json attributes" do
1007
- node.consume_external_attrs(@ohai_data, { "run_list" => ["recipe[unicorn]"] })
1008
- expect(node.run_list).to eq(["recipe[unicorn]"])
1009
- end
1010
-
1011
- it "saves non-runlist json attrs for later" do
1012
- expansion = Chef::RunList::RunListExpansion.new("_default", [])
1013
- allow(node.run_list).to receive(:expand).and_return(expansion)
1014
- node.consume_external_attrs(@ohai_data, { "foo" => "bar" })
1015
- node.expand!
1016
- expect(node.normal_attrs).to eq({ "foo" => "bar", "tags" => [] })
1017
- end
1018
-
1019
- end
1020
-
1021
- describe "when expanding its run list and merging attributes" do
1022
- before do
1023
- @environment = Chef::Environment.new.tap do |e|
1024
- e.name("rspec_env")
1025
- e.default_attributes("env default key" => "env default value")
1026
- e.override_attributes("env override key" => "env override value")
1027
- end
1028
- expect(Chef::Environment).to receive(:load).with("rspec_env").and_return(@environment)
1029
- @expansion = Chef::RunList::RunListExpansion.new("rspec_env", [])
1030
- node.chef_environment("rspec_env")
1031
- allow(node.run_list).to receive(:expand).and_return(@expansion)
1032
- end
1033
-
1034
- it "sets the 'recipes' automatic attribute to the recipes in the expanded run_list" do
1035
- @expansion.recipes << "recipe[chef::client]" << "recipe[nginx::default]"
1036
- node.expand!
1037
- expect(node.automatic_attrs[:recipes]).to eq(["recipe[chef::client]", "recipe[nginx::default]"])
1038
- end
1039
-
1040
- it "sets the 'roles' automatic attribute to the expanded role list" do
1041
- @expansion.instance_variable_set(:@applied_roles, { "arf" => nil, "countersnark" => nil })
1042
- node.expand!
1043
- expect(node.automatic_attrs[:roles].sort).to eq(%w{arf countersnark})
1044
- end
1045
-
1046
- it "applies default attributes from the environment as environment defaults" do
1047
- node.expand!
1048
- expect(node.attributes.env_default["env default key"]).to eq("env default value")
1049
- end
1050
-
1051
- it "applies override attributes from the environment as env overrides" do
1052
- node.expand!
1053
- expect(node.attributes.env_override["env override key"]).to eq("env override value")
1054
- end
1055
-
1056
- it "applies default attributes from roles as role defaults" do
1057
- @expansion.default_attrs["role default key"] = "role default value"
1058
- node.expand!
1059
- expect(node.attributes.role_default["role default key"]).to eq("role default value")
1060
- end
1061
-
1062
- it "applies override attributes from roles as role overrides" do
1063
- @expansion.override_attrs["role override key"] = "role override value"
1064
- node.expand!
1065
- expect(node.attributes.role_override["role override key"]).to eq("role override value")
1066
- end
1067
- end
1068
-
1069
- describe "loaded_recipe" do
1070
- it "should not add a recipe that is already in the recipes list" do
1071
- node.automatic_attrs[:recipes] = [ "nginx::module" ]
1072
- node.loaded_recipe(:nginx, "module")
1073
- expect(node.automatic_attrs[:recipes].length).to eq(1)
1074
- end
1075
-
1076
- it "should add a recipe that is not already in the recipes list" do
1077
- node.automatic_attrs[:recipes] = [ "nginx::other_module" ]
1078
- node.loaded_recipe(:nginx, "module")
1079
- expect(node.automatic_attrs[:recipes].length).to eq(2)
1080
- expect(node.recipe?("nginx::module")).to be true
1081
- expect(node.recipe?("nginx::other_module")).to be true
1082
- end
1083
- end
1084
-
1085
- describe "when querying for recipes in the run list" do
1086
- context "when a recipe is in the top level run list" do
1087
- before do
1088
- node.run_list << "recipe[nginx::module]"
1089
- end
1090
-
1091
- it "finds the recipe" do
1092
- expect(node.recipe?("nginx::module")).to be true
1093
- end
1094
-
1095
- it "does not find a recipe not in the run list" do
1096
- expect(node.recipe?("nginx::other_module")).to be false
1097
- end
1098
- end
1099
- context "when a recipe is in the expanded run list only" do
1100
- before do
1101
- node.run_list << "role[base]"
1102
- node.automatic_attrs[:recipes] = [ "nginx::module" ]
1103
- end
1104
-
1105
- it "finds a recipe in the expanded run list" do
1106
- expect(node.recipe?("nginx::module")).to be true
1107
- end
1108
-
1109
- it "does not find a recipe that's not in the run list" do
1110
- expect(node.recipe?("nginx::other_module")).to be false
1111
- end
1112
- end
1113
- end
1114
-
1115
- describe "when clearing computed state at the beginning of a run" do
1116
- before do
1117
- node.default[:foo] = "default"
1118
- node.normal[:foo] = "normal"
1119
- node.override[:foo] = "override"
1120
- node.reset_defaults_and_overrides
1121
- end
1122
-
1123
- it "removes default attributes" do
1124
- expect(node.default).to be_empty
1125
- end
1126
-
1127
- it "removes override attributes" do
1128
- expect(node.override).to be_empty
1129
- end
1130
-
1131
- it "leaves normal level attributes untouched" do
1132
- expect(node[:foo]).to eq("normal")
1133
- end
1134
-
1135
- end
1136
-
1137
- describe "when merging environment attributes" do
1138
- before do
1139
- node.chef_environment = "rspec"
1140
- @expansion = Chef::RunList::RunListExpansion.new("rspec", [])
1141
- @expansion.default_attrs.replace({ :default => "from role", :d_role => "role only" })
1142
- @expansion.override_attrs.replace({ :override => "from role", :o_role => "role only" })
1143
-
1144
- @environment = Chef::Environment.new
1145
- @environment.default_attributes = { :default => "from env", :d_env => "env only" }
1146
- @environment.override_attributes = { :override => "from env", :o_env => "env only" }
1147
- allow(Chef::Environment).to receive(:load).and_return(@environment)
1148
- node.apply_expansion_attributes(@expansion)
1149
- end
1150
-
1151
- it "does not nuke role-only default attrs" do
1152
- expect(node[:d_role]).to eq("role only")
1153
- end
1154
-
1155
- it "does not nuke role-only override attrs" do
1156
- expect(node[:o_role]).to eq("role only")
1157
- end
1158
-
1159
- it "does not nuke env-only default attrs" do
1160
- expect(node[:o_env]).to eq("env only")
1161
- end
1162
-
1163
- it "does not nuke role-only override attrs" do
1164
- expect(node[:o_env]).to eq("env only")
1165
- end
1166
-
1167
- it "gives role defaults precedence over env defaults" do
1168
- expect(node[:default]).to eq("from role")
1169
- end
1170
-
1171
- it "gives env overrides precedence over role overrides" do
1172
- expect(node[:override]).to eq("from env")
1173
- end
1174
- end
1175
-
1176
- describe "when evaluating attributes files" do
1177
- before do
1178
- @cookbook_repo = File.expand_path(File.join(CHEF_SPEC_DATA, "cookbooks"))
1179
- @cookbook_loader = Chef::CookbookLoader.new(@cookbook_repo)
1180
- @cookbook_loader.load_cookbooks
1181
-
1182
- @cookbook_collection = Chef::CookbookCollection.new(@cookbook_loader.cookbooks_by_name)
1183
-
1184
- @events = Chef::EventDispatch::Dispatcher.new
1185
- @run_context = Chef::RunContext.new(node, @cookbook_collection, @events)
1186
-
1187
- node.include_attribute("openldap::default")
1188
- node.include_attribute("openldap::smokey")
1189
- end
1190
-
1191
- it "sets attributes from the files" do
1192
- expect(node["ldap_server"]).to eql("ops1prod")
1193
- expect(node["ldap_basedn"]).to eql("dc=hjksolutions,dc=com")
1194
- expect(node["ldap_replication_password"]).to eql("forsure")
1195
- expect(node["smokey"]).to eql("robinson")
1196
- end
1197
-
1198
- it "gives a sensible error when attempting to load a missing attributes file" do
1199
- expect { node.include_attribute("nope-this::doesnt-exist") }.to raise_error(Chef::Exceptions::CookbookNotFound)
1200
- end
1201
- end
1202
-
1203
- describe "roles" do
1204
- it "should allow you to query whether or not it has a recipe applied with role?" do
1205
- node.run_list << "role[sunrise]"
1206
- expect(node.role?("sunrise")).to eql(true)
1207
- expect(node.role?("not at home")).to eql(false)
1208
- end
1209
-
1210
- it "should allow you to set roles with arguments" do
1211
- node.run_list << "role[one]"
1212
- node.run_list << "role[two]"
1213
- expect(node.role?("one")).to eql(true)
1214
- expect(node.role?("two")).to eql(true)
1215
- end
1216
- end
1217
-
1218
- describe "run_list" do
1219
- it "should have a Chef::RunList of recipes and roles that should be applied" do
1220
- expect(node.run_list).to be_a_kind_of(Chef::RunList)
1221
- end
1222
-
1223
- it "should allow you to query the run list with arguments" do
1224
- node.run_list "recipe[baz]"
1225
- expect(node.run_list?("recipe[baz]")).to eql(true)
1226
- end
1227
-
1228
- it "should allow you to set the run list with arguments" do
1229
- node.run_list "recipe[baz]", "role[foo]"
1230
- expect(node.run_list?("recipe[baz]")).to eql(true)
1231
- expect(node.run_list?("role[foo]")).to eql(true)
1232
- end
1233
- end
1234
-
1235
- describe "from file" do
1236
- it "should load a node from a ruby file" do
1237
- node.from_file(File.expand_path(File.join(CHEF_SPEC_DATA, "nodes", "test.rb")))
1238
- expect(node.name).to eql("test.example.com-short")
1239
- expect(node["sunshine"]).to eql("in")
1240
- expect(node["something"]).to eql("else")
1241
- expect(node.run_list).to eq(["operations-master", "operations-monitoring"])
1242
- end
1243
-
1244
- it "should raise an exception if the file cannot be found or read" do
1245
- expect { node.from_file("/tmp/monkeydiving") }.to raise_error(IOError)
1246
- end
1247
- end
1248
-
1249
- describe "update_from!" do
1250
- before(:each) do
1251
- node.name("orig")
1252
- node.chef_environment("dev")
1253
- node.default_attrs = { "one" => { "two" => "three", "four" => "five", "eight" => "nine" } }
1254
- node.override_attrs = { "one" => { "two" => "three", "four" => "six" } }
1255
- node.normal_attrs = { "one" => { "two" => "seven" } }
1256
- node.run_list << "role[marxist]"
1257
- node.run_list << "role[leninist]"
1258
- node.run_list << "recipe[stalinist]"
1259
-
1260
- @example = Chef::Node.new()
1261
- @example.name("newname")
1262
- @example.chef_environment("prod")
1263
- @example.default_attrs = { "alpha" => { "bravo" => "charlie", "delta" => "echo" } }
1264
- @example.override_attrs = { "alpha" => { "bravo" => "foxtrot", "delta" => "golf" } }
1265
- @example.normal_attrs = { "alpha" => { "bravo" => "hotel" } }
1266
- @example.run_list << "role[comedy]"
1267
- @example.run_list << "role[drama]"
1268
- @example.run_list << "recipe[mystery]"
1269
- end
1270
-
1271
- it "allows update of everything except name" do
1272
- node.update_from!(@example)
1273
- expect(node.name).to eq("orig")
1274
- expect(node.chef_environment).to eq(@example.chef_environment)
1275
- expect(node.default_attrs).to eq(@example.default_attrs)
1276
- expect(node.override_attrs).to eq(@example.override_attrs)
1277
- expect(node.normal_attrs).to eq(@example.normal_attrs)
1278
- expect(node.run_list).to eq(@example.run_list)
1279
- end
1280
-
1281
- it "should not update the name of the node" do
1282
- expect(node).not_to receive(:name).with(@example.name)
1283
- node.update_from!(@example)
1284
- end
1285
- end
1286
-
1287
- describe "to_hash" do
1288
- it "should serialize itself as a hash" do
1289
- node.chef_environment("dev")
1290
- node.default_attrs = { "one" => { "two" => "three", "four" => "five", "eight" => "nine" } }
1291
- node.override_attrs = { "one" => { "two" => "three", "four" => "six" } }
1292
- node.normal_attrs = { "one" => { "two" => "seven" } }
1293
- node.run_list << "role[marxist]"
1294
- node.run_list << "role[leninist]"
1295
- node.run_list << "recipe[stalinist]"
1296
- h = node.to_hash
1297
- expect(h["one"]["two"]).to eq("three")
1298
- expect(h["one"]["four"]).to eq("six")
1299
- expect(h["one"]["eight"]).to eq("nine")
1300
- expect(h["role"]).to be_include("marxist")
1301
- expect(h["role"]).to be_include("leninist")
1302
- expect(h["run_list"]).to be_include("role[marxist]")
1303
- expect(h["run_list"]).to be_include("role[leninist]")
1304
- expect(h["run_list"]).to be_include("recipe[stalinist]")
1305
- expect(h["chef_environment"]).to eq("dev")
1306
- end
1307
-
1308
- it "should return an empty array for empty run_list" do
1309
- expect(node.to_hash["run_list"]).to eq([])
1310
- end
1311
- end
1312
-
1313
- describe "converting to or from json" do
1314
- it "should serialize itself as json", :json => true do
1315
- node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1316
- json = Chef::JSONCompat.to_json(node)
1317
- expect(json).to match(/json_class/)
1318
- expect(json).to match(/name/)
1319
- expect(json).to match(/chef_environment/)
1320
- expect(json).to match(/normal/)
1321
- expect(json).to match(/default/)
1322
- expect(json).to match(/override/)
1323
- expect(json).to match(/run_list/)
1324
- end
1325
-
1326
- it "should serialize valid json with a run list", :json => true do
1327
- #This test came about because activesupport mucks with Chef json serialization
1328
- #Test should pass with and without Activesupport
1329
- node.run_list << { "type" => "role", "name" => "Cthulu" }
1330
- node.run_list << { "type" => "role", "name" => "Hastur" }
1331
- json = Chef::JSONCompat.to_json(node)
1332
- expect(json).to match(/\"run_list\":\[\"role\[Cthulu\]\",\"role\[Hastur\]\"\]/)
1333
- end
1334
-
1335
- it "should serialize the correct run list", :json => true do
1336
- node.run_list << "role[marxist]"
1337
- node.run_list << "role[leninist]"
1338
- node.override_runlist << "role[stalinist]"
1339
- expect(node.run_list).to be_include("role[stalinist]")
1340
- json = Chef::JSONCompat.to_json(node)
1341
- expect(json).to match(/\"run_list\":\[\"role\[marxist\]\",\"role\[leninist\]\"\]/)
1342
- end
1343
-
1344
- it "merges the override components into a combined override object" do
1345
- node.attributes.role_override["role override"] = "role override"
1346
- node.attributes.env_override["env override"] = "env override"
1347
- node_for_json = node.for_json
1348
- expect(node_for_json["override"]["role override"]).to eq("role override")
1349
- expect(node_for_json["override"]["env override"]).to eq("env override")
1350
- end
1351
-
1352
- it "merges the default components into a combined default object" do
1353
- node.attributes.role_default["role default"] = "role default"
1354
- node.attributes.env_default["env default"] = "env default"
1355
- node_for_json = node.for_json
1356
- expect(node_for_json["default"]["role default"]).to eq("role default")
1357
- expect(node_for_json["default"]["env default"]).to eq("env default")
1358
- end
1359
-
1360
- it "should deserialize itself from json", :json => true do
1361
- node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1362
- json = Chef::JSONCompat.to_json(node)
1363
- serialized_node = Chef::Node.from_hash(Chef::JSONCompat.parse(json))
1364
- expect(serialized_node).to be_a_kind_of(Chef::Node)
1365
- expect(serialized_node.name).to eql(node.name)
1366
- expect(serialized_node.chef_environment).to eql(node.chef_environment)
1367
- node.each_attribute do |k, v|
1368
- expect(serialized_node[k]).to eql(v)
1369
- end
1370
- expect(serialized_node.run_list).to eq(node.run_list)
1371
- end
1372
-
1373
- context "when policyfile attributes are not present" do
1374
-
1375
- it "does not have a policy_name key in the json" do
1376
- expect(node.for_json.keys).to_not include("policy_name")
1377
- end
1378
-
1379
- it "does not have a policy_group key in the json" do
1380
- expect(node.for_json.keys).to_not include("policy_name")
1381
- end
1382
- end
1383
-
1384
- context "when policyfile attributes are present" do
1385
-
1386
- before do
1387
- node.policy_name = "my-application"
1388
- node.policy_group = "staging"
1389
- end
1390
-
1391
- it "includes policy_name key in the json" do
1392
- expect(node.for_json).to have_key("policy_name")
1393
- expect(node.for_json["policy_name"]).to eq("my-application")
1394
- end
1395
-
1396
- it "includes a policy_group key in the json" do
1397
- expect(node.for_json).to have_key("policy_group")
1398
- expect(node.for_json["policy_group"]).to eq("staging")
1399
- end
1400
-
1401
- it "parses policyfile attributes from JSON" do
1402
- round_tripped_node = Chef::Node.from_hash(node.for_json)
1403
-
1404
- expect(round_tripped_node.policy_name).to eq("my-application")
1405
- expect(round_tripped_node.policy_group).to eq("staging")
1406
- end
1407
-
1408
- end
1409
-
1410
- include_examples "to_json equivalent to Chef::JSONCompat.to_json" do
1411
- let(:jsonable) do
1412
- node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1413
- node
1414
- end
1415
- end
1416
- end
1417
-
1418
- describe "to_s" do
1419
- it "should turn into a string like node[name]" do
1420
- node.name("airplane")
1421
- expect(node.to_s).to eql("node[airplane]")
1422
- end
1423
- end
1424
-
1425
- describe "api model" do
1426
- before(:each) do
1427
- @rest = double("Chef::ServerAPI")
1428
- allow(Chef::ServerAPI).to receive(:new).and_return(@rest)
1429
- @query = double("Chef::Search::Query")
1430
- allow(Chef::Search::Query).to receive(:new).and_return(@query)
1431
- end
1432
-
1433
- describe "list" do
1434
- describe "inflated" do
1435
- it "should return a hash of node names and objects" do
1436
- n1 = double("Chef::Node", :name => "one")
1437
- allow(n1).to receive(:kind_of?).with(Chef::Node) { true }
1438
- expect(@query).to receive(:search).with(:node).and_yield(n1)
1439
- r = Chef::Node.list(true)
1440
- expect(r["one"]).to eq(n1)
1441
- end
1442
- end
1443
-
1444
- it "should return a hash of node names and urls" do
1445
- expect(@rest).to receive(:get).and_return({ "one" => "http://foo" })
1446
- r = Chef::Node.list
1447
- expect(r["one"]).to eq("http://foo")
1448
- end
1449
- end
1450
-
1451
- describe "load" do
1452
- it "should load a node by name" do
1453
- node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1454
- json = Chef::JSONCompat.to_json(node)
1455
- parsed = Chef::JSONCompat.parse(json)
1456
- expect(@rest).to receive(:get).with("nodes/test.example.com").and_return(parsed)
1457
- serialized_node = Chef::Node.load("test.example.com")
1458
- expect(serialized_node).to be_a_kind_of(Chef::Node)
1459
- expect(serialized_node.name).to eql(node.name)
1460
- end
1461
- end
1462
-
1463
- describe "destroy" do
1464
- it "should destroy a node" do
1465
- expect(@rest).to receive(:delete).with("nodes/monkey").and_return("foo")
1466
- node.name("monkey")
1467
- node.destroy
1468
- end
1469
- end
1470
-
1471
- describe "save" do
1472
- it "should update a node if it already exists" do
1473
- node.name("monkey")
1474
- allow(node).to receive(:data_for_save).and_return({})
1475
- expect(@rest).to receive(:put).with("nodes/monkey", {}).and_return("foo")
1476
- node.save
1477
- end
1478
-
1479
- it "should not try and create if it can update" do
1480
- node.name("monkey")
1481
- allow(node).to receive(:data_for_save).and_return({})
1482
- expect(@rest).to receive(:put).with("nodes/monkey", {}).and_return("foo")
1483
- expect(@rest).not_to receive(:post)
1484
- node.save
1485
- end
1486
-
1487
- it "should create if it cannot update" do
1488
- node.name("monkey")
1489
- allow(node).to receive(:data_for_save).and_return({})
1490
- exception = double("404 error", :code => "404")
1491
- expect(@rest).to receive(:put).and_raise(Net::HTTPServerException.new("foo", exception))
1492
- expect(@rest).to receive(:post).with("nodes", {})
1493
- node.save
1494
- end
1495
-
1496
- describe "when whyrun mode is enabled" do
1497
- before do
1498
- Chef::Config[:why_run] = true
1499
- end
1500
- after do
1501
- Chef::Config[:why_run] = false
1502
- end
1503
- it "should not save" do
1504
- node.name("monkey")
1505
- expect(@rest).not_to receive(:put)
1506
- expect(@rest).not_to receive(:post)
1507
- node.save
1508
- end
1509
- end
1510
-
1511
- context "with whitelisted attributes configured" do
1512
- it "should only save whitelisted attributes (and subattributes)" do
1513
- Chef::Config[:automatic_attribute_whitelist] = [
1514
- ["filesystem", "/dev/disk0s2"],
1515
- "network/interfaces/eth0",
1516
- ]
1517
-
1518
- data = {
1519
- "automatic" => {
1520
- "filesystem" => {
1521
- "/dev/disk0s2" => { "size" => "10mb" },
1522
- "map - autohome" => { "size" => "10mb" },
1523
- },
1524
- "network" => {
1525
- "interfaces" => {
1526
- "eth0" => {},
1527
- "eth1" => {},
1528
- },
1529
- },
1530
- },
1531
- "default" => {}, "normal" => {}, "override" => {}
1532
- }
1533
-
1534
- selected_data = {
1535
- "automatic" => {
1536
- "filesystem" => {
1537
- "/dev/disk0s2" => { "size" => "10mb" },
1538
- },
1539
- "network" => {
1540
- "interfaces" => {
1541
- "eth0" => {},
1542
- },
1543
- },
1544
- },
1545
- "default" => {}, "normal" => {}, "override" => {}
1546
- }
1547
-
1548
- node.name("picky-monkey")
1549
- allow(node).to receive(:for_json).and_return(data)
1550
- expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1551
- node.save
1552
- end
1553
-
1554
- it "should save false-y whitelisted attributes" do
1555
- Chef::Config[:default_attribute_whitelist] = [
1556
- "foo/bar/baz",
1557
- ]
1558
-
1559
- data = {
1560
- "default" => {
1561
- "foo" => {
1562
- "bar" => {
1563
- "baz" => false,
1564
- },
1565
- "other" => {
1566
- "stuff" => true,
1567
- },
1568
- },
1569
- },
1570
- }
1571
-
1572
- selected_data = {
1573
- "default" => {
1574
- "foo" => {
1575
- "bar" => {
1576
- "baz" => false,
1577
- },
1578
- },
1579
- },
1580
- }
1581
-
1582
- node.name("falsey-monkey")
1583
- allow(node).to receive(:for_json).and_return(data)
1584
- expect(@rest).to receive(:put).with("nodes/falsey-monkey", selected_data).and_return("foo")
1585
- node.save
1586
- end
1587
-
1588
- it "should not save any attributes if the whitelist is empty" do
1589
- Chef::Config[:automatic_attribute_whitelist] = []
1590
-
1591
- data = {
1592
- "automatic" => {
1593
- "filesystem" => {
1594
- "/dev/disk0s2" => { "size" => "10mb" },
1595
- "map - autohome" => { "size" => "10mb" },
1596
- },
1597
- },
1598
- "default" => {}, "normal" => {}, "override" => {}
1599
- }
1600
-
1601
- selected_data = {
1602
- "automatic" => {}, "default" => {}, "normal" => {}, "override" => {}
1603
- }
1604
-
1605
- node.name("picky-monkey")
1606
- allow(node).to receive(:for_json).and_return(data)
1607
- expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1608
- node.save
1609
- end
1610
- end
1611
-
1612
- context "when policyfile attributes are present" do
1613
-
1614
- before do
1615
- node.name("example-node")
1616
- node.policy_name = "my-application"
1617
- node.policy_group = "staging"
1618
- end
1619
-
1620
- context "and the server supports policyfile attributes in node JSON" do
1621
-
1622
- it "creates the object normally" do
1623
- expect(@rest).to receive(:post).with("nodes", node.for_json)
1624
- node.create
1625
- end
1626
-
1627
- it "saves the node object normally" do
1628
- expect(@rest).to receive(:put).with("nodes/example-node", node.for_json)
1629
- node.save
1630
- end
1631
- end
1632
-
1633
- # Chef Server before 12.3
1634
- context "and the Chef Server does not support policyfile attributes in node JSON" do
1635
-
1636
- let(:response_body) { %q[{"error":["Invalid key policy_name in request body"]}] }
1637
-
1638
- let(:response) do
1639
- Net::HTTPResponse.send(:response_class, "400").new("1.0", "400", "Bad Request").tap do |r|
1640
- allow(r).to receive(:body).and_return(response_body)
1641
- end
1642
- end
1643
-
1644
- let(:http_exception) do
1645
- begin
1646
- response.error!
1647
- rescue => e
1648
- e
1649
- end
1650
- end
1651
-
1652
- let(:trimmed_node) do
1653
- node.for_json.tap do |j|
1654
- j.delete("policy_name")
1655
- j.delete("policy_group")
1656
- end
1657
-
1658
- end
1659
-
1660
- context "on Chef Client 13 and later" do
1661
-
1662
- # Though we normally attempt to provide compatibility with chef
1663
- # server one major version back, policyfiles were beta when we
1664
- # added the policyfile attributes to the node JSON, therefore
1665
- # policyfile users need to be on 12.3 minimum when upgrading Chef
1666
- # Client to 13+
1667
- it "lets the 400 pass through", chef: ">= 13" do
1668
- expect { node.save }.to raise_error(http_exception)
1669
- end
1670
-
1671
- end
1672
-
1673
- context "when the node exists" do
1674
-
1675
- it "falls back to saving without policyfile attributes" do
1676
- expect(@rest).to receive(:put).with("nodes/example-node", node.for_json).and_raise(http_exception)
1677
- expect(@rest).to receive(:put).with("nodes/example-node", trimmed_node).and_return(@node)
1678
- expect { node.save }.to_not raise_error
1679
- end
1680
-
1681
- end
1682
-
1683
- context "when the node doesn't exist" do
1684
-
1685
- let(:response_404) do
1686
- Net::HTTPResponse.send(:response_class, "404").new("1.0", "404", "Not Found")
1687
- end
1688
-
1689
- let(:http_exception_404) do
1690
- begin
1691
- response_404.error!
1692
- rescue => e
1693
- e
1694
- end
1695
- end
1696
-
1697
- it "falls back to saving without policyfile attributes" do
1698
- expect(@rest).to receive(:put).with("nodes/example-node", node.for_json).and_raise(http_exception)
1699
- expect(@rest).to receive(:put).with("nodes/example-node", trimmed_node).and_raise(http_exception_404)
1700
- expect(@rest).to receive(:post).with("nodes", trimmed_node).and_return(@node)
1701
- node.save
1702
- end
1703
-
1704
- it "creates the node without policyfile attributes" do
1705
- expect(@rest).to receive(:post).with("nodes", node.for_json).and_raise(http_exception)
1706
- expect(@rest).to receive(:post).with("nodes", trimmed_node).and_return(@node)
1707
- node.create
1708
- end
1709
- end
1710
-
1711
- end
1712
-
1713
- end
1714
-
1715
- end
1716
- end
1717
-
1718
- describe "method_missing handling" do
1719
- it "should have an #empty? method via Chef::Node::Attribute" do
1720
- node.default["foo"] = "bar"
1721
- expect(node.empty?).to be false
1722
- end
1723
-
1724
- it "it should correctly implement #respond_to?" do
1725
- expect(node.respond_to?(:empty?)).to be true
1726
- end
1727
-
1728
- it "it should correctly retrieve the method with #method" do
1729
- expect(node.method(:empty?)).to be_kind_of(Method)
1730
- end
1731
- end
1732
-
1733
- describe "path tracking via __path__" do
1734
- it "works through hash keys" do
1735
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1736
- expect(node["foo"]["bar"].__path__).to eql(%w{foo bar})
1737
- end
1738
-
1739
- it "works through the default level" do
1740
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1741
- expect(node.default["foo"]["bar"].__path__).to eql(%w{foo bar})
1742
- end
1743
-
1744
- it "works through arrays" do
1745
- node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1746
- expect(node["foo"][0].__path__).to eql(["foo", 0])
1747
- expect(node["foo"][0]["bar"].__path__).to eql(["foo", 0, "bar"])
1748
- end
1749
-
1750
- it "works through arrays at the default level" do
1751
- node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1752
- expect(node.default["foo"][0].__path__).to eql(["foo", 0])
1753
- expect(node.default["foo"][0]["bar"].__path__).to eql(["foo", 0, "bar"])
1754
- end
1755
-
1756
- # if we set __path__ in the initializer we'd get this wrong, this is why we
1757
- # update the path on every #[] or #[]= operator
1758
- it "works on access when the node has been rearranged" do
1759
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1760
- a = node.default["foo"]
1761
- node.default["fizz"] = a
1762
- expect(node["fizz"]["bar"].__path__).to eql(%w{fizz bar})
1763
- expect(node["foo"]["bar"].__path__).to eql(%w{foo bar})
1764
- end
1765
-
1766
- # We have a problem because the __path__ is stored on in each node, but the
1767
- # node can be wired up at multiple locations in the tree via pointers. One
1768
- # solution would be to deep-dup the value in `#[]=(key, value)` and fix the
1769
- # __path__ on all the dup'd nodes. The problem is that this would create an
1770
- # unusual situation where after assignment, you couldn't mutate the thing you
1771
- # hand a handle on. I'm not entirely positive this behavior is the correct
1772
- # thing to support, but it is more hash-like (although if we start with a hash
1773
- # then convert_value does its thing and we *do* get dup'd on assignment). This
1774
- # behavior likely makes any implementation of a deep merge cache built over the
1775
- # top of __path__ tracking have edge conditions where it will fail.
1776
- #
1777
- # Removing this support would be a breaking change. The test is included here
1778
- # because it seems most likely that someone would break this behavior while trying
1779
- # to fix __path__ behavior.
1780
- it "does not dup in the background when a node is assigned" do
1781
- # get a handle on a vividmash (can't be a hash or else we convert_value it)
1782
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1783
- a = node.default["foo"]
1784
- # assign that somewhere else in the tree
1785
- node.default["fizz"] = a
1786
- # now upate the source
1787
- a["duptest"] = true
1788
- # the tree should have been updated
1789
- expect(node.default["fizz"]["duptest"]).to be true
1790
- expect(node["fizz"]["duptest"]).to be true
1791
- end
1792
- end
1793
-
1794
- describe "root tracking via __root__" do
1795
- it "works through hash keys" do
1796
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1797
- expect(node["foo"]["bar"].__root__).to eql(node.attributes)
1798
- end
1799
-
1800
- it "works through the default level" do
1801
- node.default["foo"] = { "bar" => { "baz" => "qux" } }
1802
- expect(node.default["foo"]["bar"].__root__).to eql(node.attributes)
1803
- end
1804
-
1805
- it "works through arrays" do
1806
- node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1807
- expect(node["foo"][0].__root__).to eql(node.attributes)
1808
- expect(node["foo"][0]["bar"].__root__).to eql(node.attributes)
1809
- end
1810
-
1811
- it "works through arrays at the default level" do
1812
- node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1813
- expect(node.default["foo"][0].__root__).to eql(node.attributes)
1814
- expect(node.default["foo"][0]["bar"].__root__).to eql(node.attributes)
1815
- end
1816
- end
1817
-
1818
- describe "ways of abusing Chef 12 node state" do
1819
- # these tests abuse the top_level_breadcrumb state in Chef 12
1820
- it "derived attributes work correctly" do
1821
- node.default["v1"] = 1
1822
- expect(node["a"]).to eql(nil)
1823
- node.default["a"] = node["v1"]
1824
- expect(node["a"]).to eql(1)
1825
- end
1826
-
1827
- it "works when saving nodes to variables" do
1828
- a = node.default["a"]
1829
- expect(node["a"]).to eql({})
1830
- node.default["b"] = 0
1831
- a["key"] = 1
1832
-
1833
- expect(node["a"]["key"]).to eql(1)
1834
- end
1835
- end
1836
- end
1
+ #
2
+ # Author:: Adam Jacob (<adam@chef.io>)
3
+ # Copyright:: Copyright 2008-2016, 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 an environment with chef_environment(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 you to set an attribute via method_missing" do
242
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
243
+ expect { node.sunshine = "is bright" }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
244
+ end
245
+
246
+ it "does not allow modification of node attributes via hash methods" do
247
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
248
+ node.default["h4sh"] = { foo: "bar" }
249
+ expect { node["h4sh"].delete("foo") }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
250
+ expect { node.h4sh.delete("foo") }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
251
+ end
252
+
253
+ it "does not allow modification of node attributes via array methods" do
254
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
255
+ node.default["array"] = []
256
+ expect { node["array"] << "boom" }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
257
+ expect { node.array << "boom" }.to raise_error(Chef::Exceptions::ImmutableAttributeModification)
258
+ end
259
+
260
+ it "returns merged immutable attributes for arrays" do
261
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
262
+ node.default["array"] = []
263
+ expect( node["array"].class ).to eql(Chef::Node::ImmutableArray)
264
+ expect( node.array.class ).to eql(Chef::Node::ImmutableArray)
265
+ end
266
+
267
+ it "returns merged immutable attributes for hashes" do
268
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
269
+ node.default["h4sh"] = {}
270
+ expect( node["h4sh"].class ).to eql(Chef::Node::ImmutableMash)
271
+ expect( node.h4sh.class ).to eql(Chef::Node::ImmutableMash)
272
+ end
273
+
274
+ it "should allow you get get an attribute via method_missing" do
275
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
276
+ node.default.sunshine = "is bright"
277
+ expect(node.sunshine).to eql("is bright")
278
+ end
279
+
280
+ describe "normal attributes" do
281
+ it "should allow you to set an attribute with set, without pre-declaring a hash" do
282
+ node.normal[:snoopy][:is_a_puppy] = true
283
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
284
+ end
285
+
286
+ it "should allow you to set an attribute with set_unless with method_missing but emit a deprecation warning" do
287
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
288
+ node.normal_unless.snoopy.is_a_puppy = false
289
+ expect(node[:snoopy][:is_a_puppy]).to eq(false)
290
+ end
291
+
292
+ it "should allow you to set an attribute with set_unless" do
293
+ node.normal_unless[:snoopy][:is_a_puppy] = false
294
+ expect(node[:snoopy][:is_a_puppy]).to eq(false)
295
+ end
296
+
297
+ it "should not allow you to set an attribute with set_unless if it already exists" do
298
+ node.normal[:snoopy][:is_a_puppy] = true
299
+ node.normal_unless[:snoopy][:is_a_puppy] = false
300
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
301
+ end
302
+
303
+ it "should allow you to set an attribute with set_unless if is a nil value" do
304
+ node.attributes.normal = { snoopy: { is_a_puppy: nil } }
305
+ node.normal_unless[:snoopy][:is_a_puppy] = false
306
+ expect(node[:snoopy][:is_a_puppy]).to eq(false)
307
+ end
308
+
309
+ it "should allow you to set a value after a set_unless" do
310
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
311
+ node.normal_unless[:snoopy][:is_a_puppy] = false
312
+ node.normal[:snoopy][:is_a_puppy] = true
313
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
314
+ end
315
+
316
+ it "should let you set a value after a 'dangling' set_unless" do
317
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
318
+ node.normal[:snoopy][:is_a_puppy] = "what"
319
+ node.normal_unless[:snoopy][:is_a_puppy]
320
+ node.normal[:snoopy][:is_a_puppy] = true
321
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
322
+ end
323
+
324
+ it "auto-vivifies attributes created via method syntax" do
325
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
326
+ node.normal.fuu.bahrr.baz = "qux"
327
+ expect(node.fuu.bahrr.baz).to eq("qux")
328
+ end
329
+
330
+ it "should let you use tag as a convience method for the tags attribute" do
331
+ node.normal["tags"] = %w{one two}
332
+ node.tag("three", "four")
333
+ expect(node["tags"]).to eq(%w{one two three four})
334
+ end
335
+
336
+ it "set is a deprecated alias for normal" do
337
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
338
+ expect(Chef).to receive(:deprecated).with(:attributes, /set is deprecated/)
339
+ node.set[:snoopy][:is_a_puppy] = true
340
+ expect(node.normal[:snoopy][:is_a_puppy]).to eq(true)
341
+ end
342
+
343
+ it "set_unless is a deprecated alias for normal_unless" do
344
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
345
+ expect(Chef).to receive(:deprecated).with(:attributes, /set_unless is deprecated/)
346
+ node.set_unless[:snoopy][:is_a_puppy] = false
347
+ expect(node.normal[:snoopy][:is_a_puppy]).to eq(false)
348
+ end
349
+
350
+ it "normal_unless sets a value even if default or override attrs are set" do
351
+ node.default[:decontamination] = true
352
+ node.override[:decontamination] = false
353
+ node.normal_unless[:decontamination] = "foo"
354
+ expect(node.normal[:decontamination]).to eql("foo")
355
+ end
356
+
357
+ it "default_unless sets a value even if normal or override attrs are set" do
358
+ node.normal[:decontamination] = true
359
+ node.override[:decontamination] = false
360
+ node.default_unless[:decontamination] = "foo"
361
+ expect(node.default[:decontamination]).to eql("foo")
362
+ end
363
+
364
+ it "override_unless sets a value even if default or normal attrs are set" do
365
+ node.default[:decontamination] = true
366
+ node.normal[:decontamination] = false
367
+ node.override_unless[:decontamination] = "foo"
368
+ expect(node.override[:decontamination]).to eql("foo")
369
+ end
370
+ end
371
+
372
+ describe "default attributes" do
373
+ it "should be set with default, without pre-declaring a hash" do
374
+ node.default[:snoopy][:is_a_puppy] = true
375
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
376
+ end
377
+
378
+ it "should allow you to set with default_unless without pre-declaring a hash" do
379
+ node.default_unless[:snoopy][:is_a_puppy] = false
380
+ expect(node[:snoopy][:is_a_puppy]).to eq(false)
381
+ end
382
+
383
+ it "should not allow you to set an attribute with default_unless if it already exists" do
384
+ node.default[:snoopy][:is_a_puppy] = true
385
+ node.default_unless[:snoopy][:is_a_puppy] = false
386
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
387
+ end
388
+
389
+ it "should allow you to set a value after a default_unless" do
390
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
391
+ node.default_unless[:snoopy][:is_a_puppy] = false
392
+ node.default[:snoopy][:is_a_puppy] = true
393
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
394
+ end
395
+
396
+ it "should allow you to set a value after a 'dangling' default_unless" do
397
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
398
+ node.default[:snoopy][:is_a_puppy] = "what"
399
+ node.default_unless[:snoopy][:is_a_puppy]
400
+ node.default[:snoopy][:is_a_puppy] = true
401
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
402
+ end
403
+
404
+ it "does not exhibit chef/chef/issues/5005 bug" do
405
+ node.env_default["a"]["r1"]["g"]["u"] = "u1"
406
+ node.default_unless["a"]["r1"]["g"]["r"] = "r"
407
+ expect(node["a"]["r1"]["g"]["u"]).to eql("u1")
408
+ end
409
+
410
+ it "auto-vivifies attributes created via method syntax" do
411
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
412
+ node.default.fuu.bahrr.baz = "qux"
413
+ expect(node.fuu.bahrr.baz).to eq("qux")
414
+ end
415
+
416
+ it "default_unless correctly resets the deep merge cache" do
417
+ node.normal["tags"] = [] # this sets our top-level breadcrumb
418
+ node.default_unless["foo"]["bar"] = "NK-19V"
419
+ expect(node["foo"]["bar"]).to eql("NK-19V")
420
+ node.default_unless["foo"]["baz"] = "NK-33"
421
+ expect(node["foo"]["baz"]).to eql("NK-33")
422
+ end
423
+
424
+ it "normal_unless correctly resets the deep merge cache" do
425
+ node.normal["tags"] = [] # this sets our top-level breadcrumb
426
+ node.normal_unless["foo"]["bar"] = "NK-19V"
427
+ expect(node["foo"]["bar"]).to eql("NK-19V")
428
+ node.normal_unless["foo"]["baz"] = "NK-33"
429
+ expect(node["foo"]["baz"]).to eql("NK-33")
430
+ end
431
+
432
+ it "override_unless correctly resets the deep merge cache" do
433
+ node.normal["tags"] = [] # this sets our top-level breadcrumb
434
+ node.override_unless["foo"]["bar"] = "NK-19V"
435
+ expect(node["foo"]["bar"]).to eql("NK-19V")
436
+ node.override_unless["foo"]["baz"] = "NK-33"
437
+ expect(node["foo"]["baz"]).to eql("NK-33")
438
+ end
439
+ end
440
+
441
+ describe "override attributes" do
442
+ it "should be set with override, without pre-declaring a hash" do
443
+ node.override[:snoopy][:is_a_puppy] = true
444
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
445
+ end
446
+
447
+ it "should allow you to set with override_unless without pre-declaring a hash" do
448
+ node.override_unless[:snoopy][:is_a_puppy] = false
449
+ expect(node[:snoopy][:is_a_puppy]).to eq(false)
450
+ end
451
+
452
+ it "should not allow you to set an attribute with override_unless if it already exists" do
453
+ node.override[:snoopy][:is_a_puppy] = true
454
+ node.override_unless[:snoopy][:is_a_puppy] = false
455
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
456
+ end
457
+
458
+ it "should allow you to set a value after an override_unless" do
459
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
460
+ node.override_unless[:snoopy][:is_a_puppy] = false
461
+ node.override[:snoopy][:is_a_puppy] = true
462
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
463
+ end
464
+
465
+ it "should allow you to set a value after a 'dangling' override_unless" do
466
+ # this tests for set_unless_present state bleeding between statements CHEF-3806
467
+ node.override_unless[:snoopy][:is_a_puppy] = "what"
468
+ node.override_unless[:snoopy][:is_a_puppy]
469
+ node.override[:snoopy][:is_a_puppy] = true
470
+ expect(node[:snoopy][:is_a_puppy]).to eq(true)
471
+ end
472
+
473
+ it "auto-vivifies attributes created via method syntax" do
474
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
475
+ node.override.fuu.bahrr.baz = "qux"
476
+ expect(node.fuu.bahrr.baz).to eq("qux")
477
+ end
478
+ end
479
+
480
+ describe "globally deleting attributes" do
481
+ context "with hash values" do
482
+ before do
483
+ node.role_default["mysql"]["server"]["port"] = 1234
484
+ node.normal["mysql"]["server"]["port"] = 2345
485
+ node.override["mysql"]["server"]["port"] = 3456
486
+ end
487
+
488
+ it "deletes all the values and returns the value with the highest precidence" do
489
+ expect( node.rm("mysql", "server", "port") ).to eql(3456)
490
+ expect( node["mysql"]["server"]["port"] ).to be_nil
491
+ expect( node["mysql"]["server"] ).to eql({})
492
+ end
493
+
494
+ it "deletes nested things correctly" do
495
+ node.default["mysql"]["client"]["client_setting"] = "foo"
496
+ expect( node.rm("mysql", "server") ).to eql( { "port" => 3456 } )
497
+ expect( node["mysql"] ).to eql( { "client" => { "client_setting" => "foo" } } )
498
+ end
499
+
500
+ it "returns nil if the node attribute does not exist" do
501
+ expect( node.rm("no", "such", "thing") ).to be_nil
502
+ end
503
+
504
+ it "can delete the entire tree" do
505
+ expect( node.rm("mysql") ).to eql({ "server" => { "port" => 3456 } })
506
+ end
507
+ end
508
+
509
+ context "when trying to delete through a thing that isn't an array-like or hash-like object" do
510
+ before do
511
+ node.default["mysql"] = true
512
+ end
513
+
514
+ it "returns nil when you're two levels deeper" do
515
+ expect( node.rm("mysql", "server", "port") ).to eql(nil)
516
+ end
517
+
518
+ it "returns nil when you're one level deeper" do
519
+ expect( node.rm("mysql", "server") ).to eql(nil)
520
+ end
521
+
522
+ it "correctly deletes at the top level" do
523
+ expect( node.rm("mysql") ).to eql(true)
524
+ end
525
+ end
526
+
527
+ context "with array indexes" do
528
+ before do
529
+ node.role_default["mysql"]["server"][0]["port"] = 1234
530
+ node.normal["mysql"]["server"][0]["port"] = 2345
531
+ node.override["mysql"]["server"][0]["port"] = 3456
532
+ node.override["mysql"]["server"][1]["port"] = 3456
533
+ end
534
+
535
+ it "deletes the array element" do
536
+ expect( node.rm("mysql", "server", 0, "port") ).to eql(3456)
537
+ expect( node["mysql"]["server"][0]["port"] ).to be_nil
538
+ expect( node["mysql"]["server"][1]["port"] ).to eql(3456)
539
+ end
540
+ end
541
+
542
+ context "with real arrays" do
543
+ before do
544
+ node.role_default["mysql"]["server"] = [ {
545
+ "port" => 1234,
546
+ } ]
547
+ node.normal["mysql"]["server"] = [ {
548
+ "port" => 2345,
549
+ } ]
550
+ node.override["mysql"]["server"] = [ {
551
+ "port" => 3456,
552
+ } ]
553
+ end
554
+
555
+ it "deletes the array element" do
556
+ expect( node.rm("mysql", "server", 0, "port") ).to eql(3456)
557
+ expect( node["mysql"]["server"][0]["port"] ).to be_nil
558
+ end
559
+
560
+ it "when mistaking arrays for hashes, it considers the value removed and does nothing" do
561
+ node.rm("mysql", "server", "port")
562
+ expect(node["mysql"]["server"][0]["port"]).to eql(3456)
563
+ end
564
+ end
565
+ end
566
+
567
+ describe "granular deleting attributes" do
568
+ context "when only defaults exist" do
569
+ before do
570
+ node.role_default["mysql"]["server"]["port"] = 1234
571
+ node.default["mysql"]["server"]["port"] = 2345
572
+ node.force_default["mysql"]["server"]["port"] = 3456
573
+ end
574
+
575
+ it "returns the deleted values" do
576
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
577
+ end
578
+
579
+ it "returns nil for the combined attribues" do
580
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
581
+ expect( node["mysql"]["server"]["port"] ).to eql(nil)
582
+ end
583
+
584
+ it "returns an empty hash for the default attrs" do
585
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
586
+ # this auto-vivifies, should it?
587
+ expect( node.default_attrs["mysql"]["server"]["port"] ).to eql({})
588
+ end
589
+
590
+ it "returns an empty hash after the last key is deleted" do
591
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
592
+ expect( node["mysql"]["server"] ).to eql({})
593
+ end
594
+ end
595
+
596
+ context "when trying to delete through a thing that isn't an array-like or hash-like object" do
597
+ before do
598
+ node.default["mysql"] = true
599
+ end
600
+
601
+ it "returns nil when you're two levels deeper" do
602
+ expect( node.rm_default("mysql", "server", "port") ).to eql(nil)
603
+ end
604
+
605
+ it "returns nil when you're one level deeper" do
606
+ expect( node.rm_default("mysql", "server") ).to eql(nil)
607
+ end
608
+
609
+ it "correctly deletes at the top level" do
610
+ expect( node.rm_default("mysql") ).to eql(true)
611
+ end
612
+ end
613
+
614
+ context "when a higher precedence exists" do
615
+ before do
616
+ node.role_default["mysql"]["server"]["port"] = 1234
617
+ node.default["mysql"]["server"]["port"] = 2345
618
+ node.force_default["mysql"]["server"]["port"] = 3456
619
+
620
+ node.override["mysql"]["server"]["port"] = 9999
621
+ end
622
+
623
+ it "returns the deleted values" do
624
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
625
+ end
626
+
627
+ it "returns the higher precedence values after the delete" do
628
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
629
+ expect( node["mysql"]["server"]["port"] ).to eql(9999)
630
+ end
631
+
632
+ it "returns an empty has for the default attrs" do
633
+ expect( node.rm_default("mysql", "server", "port") ).to eql(3456)
634
+ # this auto-vivifies, should it?
635
+ expect( node.default_attrs["mysql"]["server"]["port"] ).to eql({})
636
+ end
637
+ end
638
+
639
+ context "when a lower precedence exists" do
640
+ before do
641
+ node.default["mysql"]["server"]["port"] = 2345
642
+ node.override["mysql"]["server"]["port"] = 9999
643
+ node.role_override["mysql"]["server"]["port"] = 9876
644
+ node.force_override["mysql"]["server"]["port"] = 6669
645
+ end
646
+
647
+ it "returns the deleted values" do
648
+ expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
649
+ end
650
+
651
+ it "returns the lower precedence levels after the delete" do
652
+ expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
653
+ expect( node["mysql"]["server"]["port"] ).to eql(2345)
654
+ end
655
+
656
+ it "returns an empty has for the override attrs" do
657
+ expect( node.rm_override("mysql", "server", "port") ).to eql(6669)
658
+ # this auto-vivifies, should it?
659
+ expect( node.override_attrs["mysql"]["server"]["port"] ).to eql({})
660
+ end
661
+ end
662
+
663
+ it "rm_default returns nil on deleting non-existent values" do
664
+ expect( node.rm_default("no", "such", "thing") ).to be_nil
665
+ end
666
+
667
+ it "rm_normal returns nil on deleting non-existent values" do
668
+ expect( node.rm_normal("no", "such", "thing") ).to be_nil
669
+ end
670
+
671
+ it "rm_override returns nil on deleting non-existent values" do
672
+ expect( node.rm_override("no", "such", "thing") ).to be_nil
673
+ end
674
+ end
675
+
676
+ describe "granular replacing attributes" do
677
+ it "removes everything at the level of the last key" do
678
+ node.default["mysql"]["server"]["port"] = 2345
679
+
680
+ node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
681
+
682
+ expect( node["mysql"]["server"] ).to eql({ "data_dir" => "/my_raid_volume/lib/mysql" })
683
+ end
684
+
685
+ it "replaces a value at the cookbook sub-level of the atributes only" do
686
+ node.default["mysql"]["server"]["port"] = 2345
687
+ node.default["mysql"]["server"]["service_name"] = "fancypants-sql"
688
+ node.role_default["mysql"]["server"]["port"] = 1234
689
+ node.force_default["mysql"]["server"]["port"] = 3456
690
+
691
+ node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
692
+
693
+ expect( node["mysql"]["server"]["port"] ).to eql(3456)
694
+ expect( node["mysql"]["server"]["service_name"] ).to be_nil
695
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
696
+ expect( node["mysql"]["server"] ).to eql({ "port" => 3456, "data_dir" => "/my_raid_volume/lib/mysql" })
697
+ end
698
+
699
+ it "higher precedence values aren't removed" do
700
+ node.role_default["mysql"]["server"]["port"] = 1234
701
+ node.default["mysql"]["server"]["port"] = 2345
702
+ node.force_default["mysql"]["server"]["port"] = 3456
703
+ node.override["mysql"]["server"]["service_name"] = "fancypants-sql"
704
+
705
+ node.default!["mysql"]["server"] = { "data_dir" => "/my_raid_volume/lib/mysql" }
706
+
707
+ expect( node["mysql"]["server"]["port"] ).to eql(3456)
708
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
709
+ expect( node["mysql"]["server"] ).to eql({ "service_name" => "fancypants-sql", "port" => 3456, "data_dir" => "/my_raid_volume/lib/mysql" })
710
+ end
711
+ end
712
+
713
+ describe "granular force replacing attributes" do
714
+ it "removes everything at the level of the last key" do
715
+ node.force_default["mysql"]["server"]["port"] = 2345
716
+
717
+ node.force_default!["mysql"]["server"] = {
718
+ "data_dir" => "/my_raid_volume/lib/mysql",
719
+ }
720
+
721
+ expect( node["mysql"]["server"] ).to eql({
722
+ "data_dir" => "/my_raid_volume/lib/mysql",
723
+ })
724
+ end
725
+
726
+ it "removes all values from the precedence level when setting" do
727
+ node.role_default["mysql"]["server"]["port"] = 1234
728
+ node.default["mysql"]["server"]["port"] = 2345
729
+ node.force_default["mysql"]["server"]["port"] = 3456
730
+
731
+ node.force_default!["mysql"]["server"] = {
732
+ "data_dir" => "/my_raid_volume/lib/mysql",
733
+ }
734
+
735
+ expect( node["mysql"]["server"]["port"] ).to be_nil
736
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
737
+ expect( node["mysql"]["server"] ).to eql({
738
+ "data_dir" => "/my_raid_volume/lib/mysql",
739
+ })
740
+ end
741
+
742
+ it "higher precedence levels are not removed" do
743
+ node.role_default["mysql"]["server"]["port"] = 1234
744
+ node.default["mysql"]["server"]["port"] = 2345
745
+ node.force_default["mysql"]["server"]["port"] = 3456
746
+ node.override["mysql"]["server"]["service_name"] = "fancypants-sql"
747
+
748
+ node.force_default!["mysql"]["server"] = {
749
+ "data_dir" => "/my_raid_volume/lib/mysql",
750
+ }
751
+
752
+ expect( node["mysql"]["server"]["port"] ).to be_nil
753
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
754
+ expect( node["mysql"]["server"] ).to eql({
755
+ "service_name" => "fancypants-sql",
756
+ "data_dir" => "/my_raid_volume/lib/mysql",
757
+ })
758
+ end
759
+
760
+ it "will autovivify" do
761
+ node.force_default!["mysql"]["server"] = {
762
+ "data_dir" => "/my_raid_volume/lib/mysql",
763
+ }
764
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
765
+ end
766
+
767
+ it "lower precedence levels aren't removed" do
768
+ node.role_override["mysql"]["server"]["port"] = 1234
769
+ node.override["mysql"]["server"]["port"] = 2345
770
+ node.force_override["mysql"]["server"]["port"] = 3456
771
+ node.default["mysql"]["server"]["service_name"] = "fancypants-sql"
772
+
773
+ node.force_override!["mysql"]["server"] = {
774
+ "data_dir" => "/my_raid_volume/lib/mysql",
775
+ }
776
+
777
+ expect( node["mysql"]["server"]["port"] ).to be_nil
778
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
779
+ expect( node["mysql"]["server"] ).to eql({
780
+ "service_name" => "fancypants-sql",
781
+ "data_dir" => "/my_raid_volume/lib/mysql",
782
+ })
783
+ end
784
+
785
+ it "when overwriting a non-hash/array" do
786
+ node.override["mysql"] = false
787
+ node.force_override["mysql"] = true
788
+ node.force_override!["mysql"]["server"] = {
789
+ "data_dir" => "/my_raid_volume/lib/mysql",
790
+ }
791
+ expect( node["mysql"]["server"]["data_dir"] ).to eql("/my_raid_volume/lib/mysql")
792
+ end
793
+
794
+ it "when overwriting an array with a hash" do
795
+ node.force_override["mysql"][0] = true
796
+ node.force_override!["mysql"]["server"] = {
797
+ "data_dir" => "/my_raid_volume/lib/mysql",
798
+ }
799
+ expect( node["mysql"]["server"] ).to eql({
800
+ "data_dir" => "/my_raid_volume/lib/mysql",
801
+ })
802
+ end
803
+ end
804
+
805
+ # In Chef-12.0 there is a deep_merge cache on the top level attribute which had a bug
806
+ # where it cached node[:foo] separate from node['foo']. These tests exercise those edge conditions.
807
+ #
808
+ # https://github.com/chef/chef/issues/2700
809
+ # https://github.com/chef/chef/issues/2712
810
+ # https://github.com/chef/chef/issues/2745
811
+ #
812
+ describe "deep merge attribute cache edge conditions" do
813
+ it "does not error with complicated attribute substitution" do
814
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
815
+ node.default["chef_attribute_hell"]["attr1"] = "attribute1"
816
+ node.default["chef_attribute_hell"]["attr2"] = "#{node.chef_attribute_hell.attr1}/attr2"
817
+ expect { node.default["chef_attribute_hell"]["attr3"] = "#{node.chef_attribute_hell.attr2}/attr3" }.not_to raise_error
818
+ end
819
+
820
+ it "caches both strings and symbols correctly" do
821
+ node.force_default[:solr][:version] = "4.10.2"
822
+ node.force_default[:solr][:data_dir] = "/opt/solr-#{node['solr'][:version]}/example/solr"
823
+ node.force_default[:solr][:xms] = "512M"
824
+ expect(node[:solr][:xms]).to eql("512M")
825
+ expect(node["solr"][:xms]).to eql("512M")
826
+ end
827
+
828
+ it "method interpolation syntax also works" do
829
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
830
+ node.default["passenger"]["version"] = "4.0.57"
831
+ node.default["passenger"]["root_path"] = "passenger-#{node['passenger']['version']}"
832
+ node.default["passenger"]["root_path_2"] = "passenger-#{node.passenger['version']}"
833
+ expect(node["passenger"]["root_path_2"]).to eql("passenger-4.0.57")
834
+ expect(node[:passenger]["root_path_2"]).to eql("passenger-4.0.57")
835
+ end
836
+ end
837
+
838
+ it "should raise an ArgumentError if you ask for an attribute that doesn't exist via method_missing" do
839
+ Chef::Config[:treat_deprecation_warnings_as_errors] = false
840
+ expect { node.sunshine }.to raise_error(NoMethodError)
841
+ end
842
+
843
+ it "should allow you to iterate over attributes with each_attribute" do
844
+ node.default.sunshine = "is bright"
845
+ node.default.canada = "is a nice place"
846
+ seen_attributes = Hash.new
847
+ node.each_attribute do |a, v|
848
+ seen_attributes[a] = v
849
+ end
850
+ expect(seen_attributes).to have_key("sunshine")
851
+ expect(seen_attributes).to have_key("canada")
852
+ expect(seen_attributes["sunshine"]).to eq("is bright")
853
+ expect(seen_attributes["canada"]).to eq("is a nice place")
854
+ end
855
+
856
+ describe "functional attribute API" do
857
+ # deeper functional testing of this API is in the VividMash spec tests
858
+ it "should have an exist? function" do
859
+ node.default["foo"]["bar"] = "baz"
860
+ expect(node.exist?("foo", "bar")).to be true
861
+ expect(node.exist?("bar", "foo")).to be false
862
+ end
863
+
864
+ it "should have a read function" do
865
+ node.override["foo"]["bar"] = "baz"
866
+ expect(node.read("foo", "bar")).to eql("baz")
867
+ expect(node.read("bar", "foo")).to eql(nil)
868
+ end
869
+
870
+ it "should have a read! function" do
871
+ node.override["foo"]["bar"] = "baz"
872
+ expect(node.read!("foo", "bar")).to eql("baz")
873
+ expect { node.read!("bar", "foo") }.to raise_error(Chef::Exceptions::NoSuchAttribute)
874
+ end
875
+
876
+ it "delegates write(:level) to node.level.write()" do
877
+ node.write(:default, "foo", "bar", "baz")
878
+ expect(node.default["foo"]["bar"]).to eql("baz")
879
+ end
880
+
881
+ it "delegates write!(:level) to node.level.write!()" do
882
+ node.write!(:default, "foo", "bar", "baz")
883
+ expect(node.default["foo"]["bar"]).to eql("baz")
884
+ node.default["bar"] = true
885
+ expect { node.write!(:default, "bar", "foo", "baz") }.to raise_error(Chef::Exceptions::AttributeTypeMismatch)
886
+ end
887
+
888
+ it "delegates unlink(:level) to node.level.unlink()" do
889
+ node.default["foo"]["bar"] = "baz"
890
+ expect(node.unlink(:default, "foo", "bar")).to eql("baz")
891
+ expect(node.unlink(:default, "bar", "foo")).to eql(nil)
892
+ end
893
+
894
+ it "delegates unlink!(:level) to node.level.unlink!()" do
895
+ node.default["foo"]["bar"] = "baz"
896
+ expect(node.unlink!(:default, "foo", "bar")).to eql("baz")
897
+ expect { node.unlink!(:default, "bar", "foo") }.to raise_error(Chef::Exceptions::NoSuchAttribute)
898
+ end
899
+ end
900
+ end
901
+
902
+ describe "consuming json" do
903
+
904
+ before do
905
+ @ohai_data = { :platform => "foo", :platform_version => "bar" }
906
+ end
907
+
908
+ it "consumes the run list portion of a collection of attributes and returns the remainder" do
909
+ attrs = { "run_list" => [ "role[base]", "recipe[chef::server]" ], "foo" => "bar" }
910
+ expect(node.consume_run_list(attrs)).to eq({ "foo" => "bar" })
911
+ expect(node.run_list).to eq([ "role[base]", "recipe[chef::server]" ])
912
+ end
913
+
914
+ it "sets the node chef_environment" do
915
+ attrs = { "chef_environment" => "foo_environment", "bar" => "baz" }
916
+ expect(node.consume_chef_environment(attrs)).to eq({ "bar" => "baz" })
917
+ expect(node.chef_environment).to eq("foo_environment")
918
+ expect(node["chef_environment"]).to be nil
919
+ end
920
+
921
+ it "should overwrites the run list with the run list it consumes" do
922
+ node.consume_run_list "recipes" => %w{one two}
923
+ node.consume_run_list "recipes" => [ "three" ]
924
+ expect(node.run_list).to eq([ "three" ])
925
+ end
926
+
927
+ it "should not add duplicate recipes from the json attributes" do
928
+ node.run_list << "one"
929
+ node.consume_run_list "recipes" => %w{one two three}
930
+ expect(node.run_list).to eq(%w{one two three})
931
+ end
932
+
933
+ it "doesn't change the run list if no run_list is specified in the json" do
934
+ node.run_list << "role[database]"
935
+ node.consume_run_list "foo" => "bar"
936
+ expect(node.run_list).to eq(["role[database]"])
937
+ end
938
+
939
+ it "raises an exception if you provide both recipe and run_list attributes, since this is ambiguous" do
940
+ expect { node.consume_run_list "recipes" => "stuff", "run_list" => "other_stuff" }.to raise_error(Chef::Exceptions::AmbiguousRunlistSpecification)
941
+ end
942
+
943
+ it "should add json attributes to the node" do
944
+ node.consume_external_attrs(@ohai_data, { "one" => "two", "three" => "four" })
945
+ expect(node["one"]).to eql("two")
946
+ expect(node["three"]).to eql("four")
947
+ end
948
+
949
+ it "should set the tags attribute to an empty array if it is not already defined" do
950
+ node.consume_external_attrs(@ohai_data, {})
951
+ expect(node.tags).to eql([])
952
+ end
953
+
954
+ it "should not set the tags attribute to an empty array if it is already defined" do
955
+ node.tag("radiohead")
956
+ node.consume_external_attrs(@ohai_data, {})
957
+ expect(node.tags).to eql([ "radiohead" ])
958
+ end
959
+
960
+ it "should set the tags attribute to an empty array if it is nil" do
961
+ node.attributes.normal = { "tags" => nil }
962
+ node.consume_external_attrs(@ohai_data, {})
963
+ expect(node.tags).to eql([])
964
+ end
965
+
966
+ it "should return an array if it is fed a string" do
967
+ node.normal[:tags] = "string"
968
+ node.consume_external_attrs(@ohai_data, {})
969
+ expect(node.tags).to eql(["string"])
970
+ end
971
+
972
+ it "should return an array if it is fed a hash" do
973
+ node.normal[:tags] = {}
974
+ node.consume_external_attrs(@ohai_data, {})
975
+ expect(node.tags).to eql([])
976
+ end
977
+
978
+ it "deep merges attributes instead of overwriting them" do
979
+ node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "four" } })
980
+ expect(node["one"].to_hash).to eq({ "two" => { "three" => "four" } })
981
+ node.consume_external_attrs(@ohai_data, "one" => { "abc" => "123" })
982
+ node.consume_external_attrs(@ohai_data, "one" => { "two" => { "foo" => "bar" } })
983
+ expect(node["one"].to_hash).to eq({ "two" => { "three" => "four", "foo" => "bar" }, "abc" => "123" })
984
+ end
985
+
986
+ it "gives attributes from JSON priority when deep merging" do
987
+ node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "four" } })
988
+ expect(node["one"].to_hash).to eq({ "two" => { "three" => "four" } })
989
+ node.consume_external_attrs(@ohai_data, "one" => { "two" => { "three" => "forty-two" } })
990
+ expect(node["one"].to_hash).to eq({ "two" => { "three" => "forty-two" } })
991
+ end
992
+
993
+ end
994
+
995
+ describe "preparing for a chef client run" do
996
+ before do
997
+ @ohai_data = { :platform => "foobuntu", :platform_version => "23.42" }
998
+ end
999
+
1000
+ it "sets its platform according to platform detection" do
1001
+ node.consume_external_attrs(@ohai_data, {})
1002
+ expect(node.automatic_attrs[:platform]).to eq("foobuntu")
1003
+ expect(node.automatic_attrs[:platform_version]).to eq("23.42")
1004
+ end
1005
+
1006
+ it "consumes the run list from provided json attributes" do
1007
+ node.consume_external_attrs(@ohai_data, { "run_list" => ["recipe[unicorn]"] })
1008
+ expect(node.run_list).to eq(["recipe[unicorn]"])
1009
+ end
1010
+
1011
+ it "saves non-runlist json attrs for later" do
1012
+ expansion = Chef::RunList::RunListExpansion.new("_default", [])
1013
+ allow(node.run_list).to receive(:expand).and_return(expansion)
1014
+ node.consume_external_attrs(@ohai_data, { "foo" => "bar" })
1015
+ node.expand!
1016
+ expect(node.normal_attrs).to eq({ "foo" => "bar", "tags" => [] })
1017
+ end
1018
+
1019
+ end
1020
+
1021
+ describe "when expanding its run list and merging attributes" do
1022
+ before do
1023
+ @environment = Chef::Environment.new.tap do |e|
1024
+ e.name("rspec_env")
1025
+ e.default_attributes("env default key" => "env default value")
1026
+ e.override_attributes("env override key" => "env override value")
1027
+ end
1028
+ expect(Chef::Environment).to receive(:load).with("rspec_env").and_return(@environment)
1029
+ @expansion = Chef::RunList::RunListExpansion.new("rspec_env", [])
1030
+ node.chef_environment("rspec_env")
1031
+ allow(node.run_list).to receive(:expand).and_return(@expansion)
1032
+ end
1033
+
1034
+ it "sets the 'recipes' automatic attribute to the recipes in the expanded run_list" do
1035
+ @expansion.recipes << "recipe[chef::client]" << "recipe[nginx::default]"
1036
+ node.expand!
1037
+ expect(node.automatic_attrs[:recipes]).to eq(["recipe[chef::client]", "recipe[nginx::default]"])
1038
+ end
1039
+
1040
+ it "sets the 'roles' automatic attribute to the expanded role list" do
1041
+ @expansion.instance_variable_set(:@applied_roles, { "arf" => nil, "countersnark" => nil })
1042
+ node.expand!
1043
+ expect(node.automatic_attrs[:roles].sort).to eq(%w{arf countersnark})
1044
+ end
1045
+
1046
+ it "applies default attributes from the environment as environment defaults" do
1047
+ node.expand!
1048
+ expect(node.attributes.env_default["env default key"]).to eq("env default value")
1049
+ end
1050
+
1051
+ it "applies override attributes from the environment as env overrides" do
1052
+ node.expand!
1053
+ expect(node.attributes.env_override["env override key"]).to eq("env override value")
1054
+ end
1055
+
1056
+ it "applies default attributes from roles as role defaults" do
1057
+ @expansion.default_attrs["role default key"] = "role default value"
1058
+ node.expand!
1059
+ expect(node.attributes.role_default["role default key"]).to eq("role default value")
1060
+ end
1061
+
1062
+ it "applies override attributes from roles as role overrides" do
1063
+ @expansion.override_attrs["role override key"] = "role override value"
1064
+ node.expand!
1065
+ expect(node.attributes.role_override["role override key"]).to eq("role override value")
1066
+ end
1067
+ end
1068
+
1069
+ describe "loaded_recipe" do
1070
+ it "should not add a recipe that is already in the recipes list" do
1071
+ node.automatic_attrs[:recipes] = [ "nginx::module" ]
1072
+ node.loaded_recipe(:nginx, "module")
1073
+ expect(node.automatic_attrs[:recipes].length).to eq(1)
1074
+ end
1075
+
1076
+ it "should add a recipe that is not already in the recipes list" do
1077
+ node.automatic_attrs[:recipes] = [ "nginx::other_module" ]
1078
+ node.loaded_recipe(:nginx, "module")
1079
+ expect(node.automatic_attrs[:recipes].length).to eq(2)
1080
+ expect(node.recipe?("nginx::module")).to be true
1081
+ expect(node.recipe?("nginx::other_module")).to be true
1082
+ end
1083
+ end
1084
+
1085
+ describe "when querying for recipes in the run list" do
1086
+ context "when a recipe is in the top level run list" do
1087
+ before do
1088
+ node.run_list << "recipe[nginx::module]"
1089
+ end
1090
+
1091
+ it "finds the recipe" do
1092
+ expect(node.recipe?("nginx::module")).to be true
1093
+ end
1094
+
1095
+ it "does not find a recipe not in the run list" do
1096
+ expect(node.recipe?("nginx::other_module")).to be false
1097
+ end
1098
+ end
1099
+ context "when a recipe is in the expanded run list only" do
1100
+ before do
1101
+ node.run_list << "role[base]"
1102
+ node.automatic_attrs[:recipes] = [ "nginx::module" ]
1103
+ end
1104
+
1105
+ it "finds a recipe in the expanded run list" do
1106
+ expect(node.recipe?("nginx::module")).to be true
1107
+ end
1108
+
1109
+ it "does not find a recipe that's not in the run list" do
1110
+ expect(node.recipe?("nginx::other_module")).to be false
1111
+ end
1112
+ end
1113
+ end
1114
+
1115
+ describe "when clearing computed state at the beginning of a run" do
1116
+ before do
1117
+ node.default[:foo] = "default"
1118
+ node.normal[:foo] = "normal"
1119
+ node.override[:foo] = "override"
1120
+ node.reset_defaults_and_overrides
1121
+ end
1122
+
1123
+ it "removes default attributes" do
1124
+ expect(node.default).to be_empty
1125
+ end
1126
+
1127
+ it "removes override attributes" do
1128
+ expect(node.override).to be_empty
1129
+ end
1130
+
1131
+ it "leaves normal level attributes untouched" do
1132
+ expect(node[:foo]).to eq("normal")
1133
+ end
1134
+
1135
+ end
1136
+
1137
+ describe "when merging environment attributes" do
1138
+ before do
1139
+ node.chef_environment = "rspec"
1140
+ @expansion = Chef::RunList::RunListExpansion.new("rspec", [])
1141
+ @expansion.default_attrs.replace({ :default => "from role", :d_role => "role only" })
1142
+ @expansion.override_attrs.replace({ :override => "from role", :o_role => "role only" })
1143
+
1144
+ @environment = Chef::Environment.new
1145
+ @environment.default_attributes = { :default => "from env", :d_env => "env only" }
1146
+ @environment.override_attributes = { :override => "from env", :o_env => "env only" }
1147
+ allow(Chef::Environment).to receive(:load).and_return(@environment)
1148
+ node.apply_expansion_attributes(@expansion)
1149
+ end
1150
+
1151
+ it "does not nuke role-only default attrs" do
1152
+ expect(node[:d_role]).to eq("role only")
1153
+ end
1154
+
1155
+ it "does not nuke role-only override attrs" do
1156
+ expect(node[:o_role]).to eq("role only")
1157
+ end
1158
+
1159
+ it "does not nuke env-only default attrs" do
1160
+ expect(node[:o_env]).to eq("env only")
1161
+ end
1162
+
1163
+ it "does not nuke role-only override attrs" do
1164
+ expect(node[:o_env]).to eq("env only")
1165
+ end
1166
+
1167
+ it "gives role defaults precedence over env defaults" do
1168
+ expect(node[:default]).to eq("from role")
1169
+ end
1170
+
1171
+ it "gives env overrides precedence over role overrides" do
1172
+ expect(node[:override]).to eq("from env")
1173
+ end
1174
+ end
1175
+
1176
+ describe "when evaluating attributes files" do
1177
+ before do
1178
+ @cookbook_repo = File.expand_path(File.join(CHEF_SPEC_DATA, "cookbooks"))
1179
+ @cookbook_loader = Chef::CookbookLoader.new(@cookbook_repo)
1180
+ @cookbook_loader.load_cookbooks
1181
+
1182
+ @cookbook_collection = Chef::CookbookCollection.new(@cookbook_loader.cookbooks_by_name)
1183
+
1184
+ @events = Chef::EventDispatch::Dispatcher.new
1185
+ @run_context = Chef::RunContext.new(node, @cookbook_collection, @events)
1186
+
1187
+ node.include_attribute("openldap::default")
1188
+ node.include_attribute("openldap::smokey")
1189
+ end
1190
+
1191
+ it "sets attributes from the files" do
1192
+ expect(node["ldap_server"]).to eql("ops1prod")
1193
+ expect(node["ldap_basedn"]).to eql("dc=hjksolutions,dc=com")
1194
+ expect(node["ldap_replication_password"]).to eql("forsure")
1195
+ expect(node["smokey"]).to eql("robinson")
1196
+ end
1197
+
1198
+ it "gives a sensible error when attempting to load a missing attributes file" do
1199
+ expect { node.include_attribute("nope-this::doesnt-exist") }.to raise_error(Chef::Exceptions::CookbookNotFound)
1200
+ end
1201
+ end
1202
+
1203
+ describe "roles" do
1204
+ it "should allow you to query whether or not it has a recipe applied with role?" do
1205
+ node.run_list << "role[sunrise]"
1206
+ expect(node.role?("sunrise")).to eql(true)
1207
+ expect(node.role?("not at home")).to eql(false)
1208
+ end
1209
+
1210
+ it "should allow you to set roles with arguments" do
1211
+ node.run_list << "role[one]"
1212
+ node.run_list << "role[two]"
1213
+ expect(node.role?("one")).to eql(true)
1214
+ expect(node.role?("two")).to eql(true)
1215
+ end
1216
+ end
1217
+
1218
+ describe "run_list" do
1219
+ it "should have a Chef::RunList of recipes and roles that should be applied" do
1220
+ expect(node.run_list).to be_a_kind_of(Chef::RunList)
1221
+ end
1222
+
1223
+ it "should allow you to query the run list with arguments" do
1224
+ node.run_list "recipe[baz]"
1225
+ expect(node.run_list?("recipe[baz]")).to eql(true)
1226
+ end
1227
+
1228
+ it "should allow you to set the run list with arguments" do
1229
+ node.run_list "recipe[baz]", "role[foo]"
1230
+ expect(node.run_list?("recipe[baz]")).to eql(true)
1231
+ expect(node.run_list?("role[foo]")).to eql(true)
1232
+ end
1233
+ end
1234
+
1235
+ describe "from file" do
1236
+ it "should load a node from a ruby file" do
1237
+ node.from_file(File.expand_path(File.join(CHEF_SPEC_DATA, "nodes", "test.rb")))
1238
+ expect(node.name).to eql("test.example.com-short")
1239
+ expect(node["sunshine"]).to eql("in")
1240
+ expect(node["something"]).to eql("else")
1241
+ expect(node.run_list).to eq(["operations-master", "operations-monitoring"])
1242
+ end
1243
+
1244
+ it "should raise an exception if the file cannot be found or read" do
1245
+ expect { node.from_file("/tmp/monkeydiving") }.to raise_error(IOError)
1246
+ end
1247
+ end
1248
+
1249
+ describe "update_from!" do
1250
+ before(:each) do
1251
+ node.name("orig")
1252
+ node.chef_environment("dev")
1253
+ node.default_attrs = { "one" => { "two" => "three", "four" => "five", "eight" => "nine" } }
1254
+ node.override_attrs = { "one" => { "two" => "three", "four" => "six" } }
1255
+ node.normal_attrs = { "one" => { "two" => "seven" } }
1256
+ node.run_list << "role[marxist]"
1257
+ node.run_list << "role[leninist]"
1258
+ node.run_list << "recipe[stalinist]"
1259
+
1260
+ @example = Chef::Node.new()
1261
+ @example.name("newname")
1262
+ @example.chef_environment("prod")
1263
+ @example.default_attrs = { "alpha" => { "bravo" => "charlie", "delta" => "echo" } }
1264
+ @example.override_attrs = { "alpha" => { "bravo" => "foxtrot", "delta" => "golf" } }
1265
+ @example.normal_attrs = { "alpha" => { "bravo" => "hotel" } }
1266
+ @example.run_list << "role[comedy]"
1267
+ @example.run_list << "role[drama]"
1268
+ @example.run_list << "recipe[mystery]"
1269
+ end
1270
+
1271
+ it "allows update of everything except name" do
1272
+ node.update_from!(@example)
1273
+ expect(node.name).to eq("orig")
1274
+ expect(node.chef_environment).to eq(@example.chef_environment)
1275
+ expect(node.default_attrs).to eq(@example.default_attrs)
1276
+ expect(node.override_attrs).to eq(@example.override_attrs)
1277
+ expect(node.normal_attrs).to eq(@example.normal_attrs)
1278
+ expect(node.run_list).to eq(@example.run_list)
1279
+ end
1280
+
1281
+ it "should not update the name of the node" do
1282
+ expect(node).not_to receive(:name).with(@example.name)
1283
+ node.update_from!(@example)
1284
+ end
1285
+ end
1286
+
1287
+ describe "to_hash" do
1288
+ it "should serialize itself as a hash" do
1289
+ node.chef_environment("dev")
1290
+ node.default_attrs = { "one" => { "two" => "three", "four" => "five", "eight" => "nine" } }
1291
+ node.override_attrs = { "one" => { "two" => "three", "four" => "six" } }
1292
+ node.normal_attrs = { "one" => { "two" => "seven" } }
1293
+ node.run_list << "role[marxist]"
1294
+ node.run_list << "role[leninist]"
1295
+ node.run_list << "recipe[stalinist]"
1296
+ h = node.to_hash
1297
+ expect(h["one"]["two"]).to eq("three")
1298
+ expect(h["one"]["four"]).to eq("six")
1299
+ expect(h["one"]["eight"]).to eq("nine")
1300
+ expect(h["role"]).to be_include("marxist")
1301
+ expect(h["role"]).to be_include("leninist")
1302
+ expect(h["run_list"]).to be_include("role[marxist]")
1303
+ expect(h["run_list"]).to be_include("role[leninist]")
1304
+ expect(h["run_list"]).to be_include("recipe[stalinist]")
1305
+ expect(h["chef_environment"]).to eq("dev")
1306
+ end
1307
+
1308
+ it "should return an empty array for empty run_list" do
1309
+ expect(node.to_hash["run_list"]).to eq([])
1310
+ end
1311
+ end
1312
+
1313
+ describe "converting to or from json" do
1314
+ it "should serialize itself as json", :json => true do
1315
+ node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1316
+ json = Chef::JSONCompat.to_json(node)
1317
+ expect(json).to match(/json_class/)
1318
+ expect(json).to match(/name/)
1319
+ expect(json).to match(/chef_environment/)
1320
+ expect(json).to match(/normal/)
1321
+ expect(json).to match(/default/)
1322
+ expect(json).to match(/override/)
1323
+ expect(json).to match(/run_list/)
1324
+ end
1325
+
1326
+ it "should serialize valid json with a run list", :json => true do
1327
+ #This test came about because activesupport mucks with Chef json serialization
1328
+ #Test should pass with and without Activesupport
1329
+ node.run_list << { "type" => "role", "name" => "Cthulu" }
1330
+ node.run_list << { "type" => "role", "name" => "Hastur" }
1331
+ json = Chef::JSONCompat.to_json(node)
1332
+ expect(json).to match(/\"run_list\":\[\"role\[Cthulu\]\",\"role\[Hastur\]\"\]/)
1333
+ end
1334
+
1335
+ it "should serialize the correct run list", :json => true do
1336
+ node.run_list << "role[marxist]"
1337
+ node.run_list << "role[leninist]"
1338
+ node.override_runlist << "role[stalinist]"
1339
+ expect(node.run_list).to be_include("role[stalinist]")
1340
+ json = Chef::JSONCompat.to_json(node)
1341
+ expect(json).to match(/\"run_list\":\[\"role\[marxist\]\",\"role\[leninist\]\"\]/)
1342
+ end
1343
+
1344
+ it "merges the override components into a combined override object" do
1345
+ node.attributes.role_override["role override"] = "role override"
1346
+ node.attributes.env_override["env override"] = "env override"
1347
+ node_for_json = node.for_json
1348
+ expect(node_for_json["override"]["role override"]).to eq("role override")
1349
+ expect(node_for_json["override"]["env override"]).to eq("env override")
1350
+ end
1351
+
1352
+ it "merges the default components into a combined default object" do
1353
+ node.attributes.role_default["role default"] = "role default"
1354
+ node.attributes.env_default["env default"] = "env default"
1355
+ node_for_json = node.for_json
1356
+ expect(node_for_json["default"]["role default"]).to eq("role default")
1357
+ expect(node_for_json["default"]["env default"]).to eq("env default")
1358
+ end
1359
+
1360
+ it "should deserialize itself from json", :json => true do
1361
+ node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1362
+ json = Chef::JSONCompat.to_json(node)
1363
+ serialized_node = Chef::Node.from_hash(Chef::JSONCompat.parse(json))
1364
+ expect(serialized_node).to be_a_kind_of(Chef::Node)
1365
+ expect(serialized_node.name).to eql(node.name)
1366
+ expect(serialized_node.chef_environment).to eql(node.chef_environment)
1367
+ node.each_attribute do |k, v|
1368
+ expect(serialized_node[k]).to eql(v)
1369
+ end
1370
+ expect(serialized_node.run_list).to eq(node.run_list)
1371
+ end
1372
+
1373
+ context "when policyfile attributes are not present" do
1374
+
1375
+ it "does not have a policy_name key in the json" do
1376
+ expect(node.for_json.keys).to_not include("policy_name")
1377
+ end
1378
+
1379
+ it "does not have a policy_group key in the json" do
1380
+ expect(node.for_json.keys).to_not include("policy_name")
1381
+ end
1382
+ end
1383
+
1384
+ context "when policyfile attributes are present" do
1385
+
1386
+ before do
1387
+ node.policy_name = "my-application"
1388
+ node.policy_group = "staging"
1389
+ end
1390
+
1391
+ it "includes policy_name key in the json" do
1392
+ expect(node.for_json).to have_key("policy_name")
1393
+ expect(node.for_json["policy_name"]).to eq("my-application")
1394
+ end
1395
+
1396
+ it "includes a policy_group key in the json" do
1397
+ expect(node.for_json).to have_key("policy_group")
1398
+ expect(node.for_json["policy_group"]).to eq("staging")
1399
+ end
1400
+
1401
+ it "parses policyfile attributes from JSON" do
1402
+ round_tripped_node = Chef::Node.from_hash(node.for_json)
1403
+
1404
+ expect(round_tripped_node.policy_name).to eq("my-application")
1405
+ expect(round_tripped_node.policy_group).to eq("staging")
1406
+ end
1407
+
1408
+ end
1409
+
1410
+ include_examples "to_json equivalent to Chef::JSONCompat.to_json" do
1411
+ let(:jsonable) do
1412
+ node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1413
+ node
1414
+ end
1415
+ end
1416
+ end
1417
+
1418
+ describe "to_s" do
1419
+ it "should turn into a string like node[name]" do
1420
+ node.name("airplane")
1421
+ expect(node.to_s).to eql("node[airplane]")
1422
+ end
1423
+ end
1424
+
1425
+ describe "api model" do
1426
+ before(:each) do
1427
+ @rest = double("Chef::ServerAPI")
1428
+ allow(Chef::ServerAPI).to receive(:new).and_return(@rest)
1429
+ @query = double("Chef::Search::Query")
1430
+ allow(Chef::Search::Query).to receive(:new).and_return(@query)
1431
+ end
1432
+
1433
+ describe "list" do
1434
+ describe "inflated" do
1435
+ it "should return a hash of node names and objects" do
1436
+ n1 = double("Chef::Node", :name => "one")
1437
+ allow(n1).to receive(:kind_of?).with(Chef::Node) { true }
1438
+ expect(@query).to receive(:search).with(:node).and_yield(n1)
1439
+ r = Chef::Node.list(true)
1440
+ expect(r["one"]).to eq(n1)
1441
+ end
1442
+ end
1443
+
1444
+ it "should return a hash of node names and urls" do
1445
+ expect(@rest).to receive(:get).and_return({ "one" => "http://foo" })
1446
+ r = Chef::Node.list
1447
+ expect(r["one"]).to eq("http://foo")
1448
+ end
1449
+ end
1450
+
1451
+ describe "load" do
1452
+ it "should load a node by name" do
1453
+ node.from_file(File.expand_path("nodes/test.example.com.rb", CHEF_SPEC_DATA))
1454
+ json = Chef::JSONCompat.to_json(node)
1455
+ parsed = Chef::JSONCompat.parse(json)
1456
+ expect(@rest).to receive(:get).with("nodes/test.example.com").and_return(parsed)
1457
+ serialized_node = Chef::Node.load("test.example.com")
1458
+ expect(serialized_node).to be_a_kind_of(Chef::Node)
1459
+ expect(serialized_node.name).to eql(node.name)
1460
+ end
1461
+ end
1462
+
1463
+ describe "destroy" do
1464
+ it "should destroy a node" do
1465
+ expect(@rest).to receive(:delete).with("nodes/monkey").and_return("foo")
1466
+ node.name("monkey")
1467
+ node.destroy
1468
+ end
1469
+ end
1470
+
1471
+ describe "save" do
1472
+ it "should update a node if it already exists" do
1473
+ node.name("monkey")
1474
+ allow(node).to receive(:data_for_save).and_return({})
1475
+ expect(@rest).to receive(:put).with("nodes/monkey", {}).and_return("foo")
1476
+ node.save
1477
+ end
1478
+
1479
+ it "should not try and create if it can update" do
1480
+ node.name("monkey")
1481
+ allow(node).to receive(:data_for_save).and_return({})
1482
+ expect(@rest).to receive(:put).with("nodes/monkey", {}).and_return("foo")
1483
+ expect(@rest).not_to receive(:post)
1484
+ node.save
1485
+ end
1486
+
1487
+ it "should create if it cannot update" do
1488
+ node.name("monkey")
1489
+ allow(node).to receive(:data_for_save).and_return({})
1490
+ exception = double("404 error", :code => "404")
1491
+ expect(@rest).to receive(:put).and_raise(Net::HTTPServerException.new("foo", exception))
1492
+ expect(@rest).to receive(:post).with("nodes", {})
1493
+ node.save
1494
+ end
1495
+
1496
+ describe "when whyrun mode is enabled" do
1497
+ before do
1498
+ Chef::Config[:why_run] = true
1499
+ end
1500
+ after do
1501
+ Chef::Config[:why_run] = false
1502
+ end
1503
+ it "should not save" do
1504
+ node.name("monkey")
1505
+ expect(@rest).not_to receive(:put)
1506
+ expect(@rest).not_to receive(:post)
1507
+ node.save
1508
+ end
1509
+ end
1510
+
1511
+ context "with whitelisted attributes configured" do
1512
+ it "should only save whitelisted attributes (and subattributes)" do
1513
+ Chef::Config[:automatic_attribute_whitelist] = [
1514
+ ["filesystem", "/dev/disk0s2"],
1515
+ "network/interfaces/eth0",
1516
+ ]
1517
+
1518
+ data = {
1519
+ "automatic" => {
1520
+ "filesystem" => {
1521
+ "/dev/disk0s2" => { "size" => "10mb" },
1522
+ "map - autohome" => { "size" => "10mb" },
1523
+ },
1524
+ "network" => {
1525
+ "interfaces" => {
1526
+ "eth0" => {},
1527
+ "eth1" => {},
1528
+ },
1529
+ },
1530
+ },
1531
+ "default" => {}, "normal" => {}, "override" => {}
1532
+ }
1533
+
1534
+ selected_data = {
1535
+ "automatic" => {
1536
+ "filesystem" => {
1537
+ "/dev/disk0s2" => { "size" => "10mb" },
1538
+ },
1539
+ "network" => {
1540
+ "interfaces" => {
1541
+ "eth0" => {},
1542
+ },
1543
+ },
1544
+ },
1545
+ "default" => {}, "normal" => {}, "override" => {}
1546
+ }
1547
+
1548
+ node.name("picky-monkey")
1549
+ allow(node).to receive(:for_json).and_return(data)
1550
+ expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1551
+ node.save
1552
+ end
1553
+
1554
+ it "should save false-y whitelisted attributes" do
1555
+ Chef::Config[:default_attribute_whitelist] = [
1556
+ "foo/bar/baz",
1557
+ ]
1558
+
1559
+ data = {
1560
+ "default" => {
1561
+ "foo" => {
1562
+ "bar" => {
1563
+ "baz" => false,
1564
+ },
1565
+ "other" => {
1566
+ "stuff" => true,
1567
+ },
1568
+ },
1569
+ },
1570
+ }
1571
+
1572
+ selected_data = {
1573
+ "default" => {
1574
+ "foo" => {
1575
+ "bar" => {
1576
+ "baz" => false,
1577
+ },
1578
+ },
1579
+ },
1580
+ }
1581
+
1582
+ node.name("falsey-monkey")
1583
+ allow(node).to receive(:for_json).and_return(data)
1584
+ expect(@rest).to receive(:put).with("nodes/falsey-monkey", selected_data).and_return("foo")
1585
+ node.save
1586
+ end
1587
+
1588
+ it "should not save any attributes if the whitelist is empty" do
1589
+ Chef::Config[:automatic_attribute_whitelist] = []
1590
+
1591
+ data = {
1592
+ "automatic" => {
1593
+ "filesystem" => {
1594
+ "/dev/disk0s2" => { "size" => "10mb" },
1595
+ "map - autohome" => { "size" => "10mb" },
1596
+ },
1597
+ },
1598
+ "default" => {}, "normal" => {}, "override" => {}
1599
+ }
1600
+
1601
+ selected_data = {
1602
+ "automatic" => {}, "default" => {}, "normal" => {}, "override" => {}
1603
+ }
1604
+
1605
+ node.name("picky-monkey")
1606
+ allow(node).to receive(:for_json).and_return(data)
1607
+ expect(@rest).to receive(:put).with("nodes/picky-monkey", selected_data).and_return("foo")
1608
+ node.save
1609
+ end
1610
+ end
1611
+
1612
+ context "when policyfile attributes are present" do
1613
+
1614
+ before do
1615
+ node.name("example-node")
1616
+ node.policy_name = "my-application"
1617
+ node.policy_group = "staging"
1618
+ end
1619
+
1620
+ context "and the server supports policyfile attributes in node JSON" do
1621
+
1622
+ it "creates the object normally" do
1623
+ expect(@rest).to receive(:post).with("nodes", node.for_json)
1624
+ node.create
1625
+ end
1626
+
1627
+ it "saves the node object normally" do
1628
+ expect(@rest).to receive(:put).with("nodes/example-node", node.for_json)
1629
+ node.save
1630
+ end
1631
+ end
1632
+
1633
+ # Chef Server before 12.3
1634
+ context "and the Chef Server does not support policyfile attributes in node JSON" do
1635
+
1636
+ let(:response_body) { %q[{"error":["Invalid key policy_name in request body"]}] }
1637
+
1638
+ let(:response) do
1639
+ Net::HTTPResponse.send(:response_class, "400").new("1.0", "400", "Bad Request").tap do |r|
1640
+ allow(r).to receive(:body).and_return(response_body)
1641
+ end
1642
+ end
1643
+
1644
+ let(:http_exception) do
1645
+ begin
1646
+ response.error!
1647
+ rescue => e
1648
+ e
1649
+ end
1650
+ end
1651
+
1652
+ let(:trimmed_node) do
1653
+ node.for_json.tap do |j|
1654
+ j.delete("policy_name")
1655
+ j.delete("policy_group")
1656
+ end
1657
+
1658
+ end
1659
+
1660
+ context "on Chef Client 13 and later" do
1661
+
1662
+ # Though we normally attempt to provide compatibility with chef
1663
+ # server one major version back, policyfiles were beta when we
1664
+ # added the policyfile attributes to the node JSON, therefore
1665
+ # policyfile users need to be on 12.3 minimum when upgrading Chef
1666
+ # Client to 13+
1667
+ it "lets the 400 pass through", chef: ">= 13" do
1668
+ expect { node.save }.to raise_error(http_exception)
1669
+ end
1670
+
1671
+ end
1672
+
1673
+ context "when the node exists" do
1674
+
1675
+ it "falls back to saving without policyfile attributes" do
1676
+ expect(@rest).to receive(:put).with("nodes/example-node", node.for_json).and_raise(http_exception)
1677
+ expect(@rest).to receive(:put).with("nodes/example-node", trimmed_node).and_return(@node)
1678
+ expect { node.save }.to_not raise_error
1679
+ end
1680
+
1681
+ end
1682
+
1683
+ context "when the node doesn't exist" do
1684
+
1685
+ let(:response_404) do
1686
+ Net::HTTPResponse.send(:response_class, "404").new("1.0", "404", "Not Found")
1687
+ end
1688
+
1689
+ let(:http_exception_404) do
1690
+ begin
1691
+ response_404.error!
1692
+ rescue => e
1693
+ e
1694
+ end
1695
+ end
1696
+
1697
+ it "falls back to saving without policyfile attributes" do
1698
+ expect(@rest).to receive(:put).with("nodes/example-node", node.for_json).and_raise(http_exception)
1699
+ expect(@rest).to receive(:put).with("nodes/example-node", trimmed_node).and_raise(http_exception_404)
1700
+ expect(@rest).to receive(:post).with("nodes", trimmed_node).and_return(@node)
1701
+ node.save
1702
+ end
1703
+
1704
+ it "creates the node without policyfile attributes" do
1705
+ expect(@rest).to receive(:post).with("nodes", node.for_json).and_raise(http_exception)
1706
+ expect(@rest).to receive(:post).with("nodes", trimmed_node).and_return(@node)
1707
+ node.create
1708
+ end
1709
+ end
1710
+
1711
+ end
1712
+
1713
+ end
1714
+
1715
+ end
1716
+ end
1717
+
1718
+ describe "method_missing handling" do
1719
+ it "should have an #empty? method via Chef::Node::Attribute" do
1720
+ node.default["foo"] = "bar"
1721
+ expect(node.empty?).to be false
1722
+ end
1723
+
1724
+ it "it should correctly implement #respond_to?" do
1725
+ expect(node.respond_to?(:empty?)).to be true
1726
+ end
1727
+
1728
+ it "it should correctly retrieve the method with #method" do
1729
+ expect(node.method(:empty?)).to be_kind_of(Method)
1730
+ end
1731
+ end
1732
+
1733
+ describe "path tracking via __path__" do
1734
+ it "works through hash keys" do
1735
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1736
+ expect(node["foo"]["bar"].__path__).to eql(%w{foo bar})
1737
+ end
1738
+
1739
+ it "works through the default level" do
1740
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1741
+ expect(node.default["foo"]["bar"].__path__).to eql(%w{foo bar})
1742
+ end
1743
+
1744
+ it "works through arrays" do
1745
+ node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1746
+ expect(node["foo"][0].__path__).to eql(["foo", 0])
1747
+ expect(node["foo"][0]["bar"].__path__).to eql(["foo", 0, "bar"])
1748
+ end
1749
+
1750
+ it "works through arrays at the default level" do
1751
+ node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1752
+ expect(node.default["foo"][0].__path__).to eql(["foo", 0])
1753
+ expect(node.default["foo"][0]["bar"].__path__).to eql(["foo", 0, "bar"])
1754
+ end
1755
+
1756
+ # if we set __path__ in the initializer we'd get this wrong, this is why we
1757
+ # update the path on every #[] or #[]= operator
1758
+ it "works on access when the node has been rearranged" do
1759
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1760
+ a = node.default["foo"]
1761
+ node.default["fizz"] = a
1762
+ expect(node["fizz"]["bar"].__path__).to eql(%w{fizz bar})
1763
+ expect(node["foo"]["bar"].__path__).to eql(%w{foo bar})
1764
+ end
1765
+
1766
+ # We have a problem because the __path__ is stored on in each node, but the
1767
+ # node can be wired up at multiple locations in the tree via pointers. One
1768
+ # solution would be to deep-dup the value in `#[]=(key, value)` and fix the
1769
+ # __path__ on all the dup'd nodes. The problem is that this would create an
1770
+ # unusual situation where after assignment, you couldn't mutate the thing you
1771
+ # hand a handle on. I'm not entirely positive this behavior is the correct
1772
+ # thing to support, but it is more hash-like (although if we start with a hash
1773
+ # then convert_value does its thing and we *do* get dup'd on assignment). This
1774
+ # behavior likely makes any implementation of a deep merge cache built over the
1775
+ # top of __path__ tracking have edge conditions where it will fail.
1776
+ #
1777
+ # Removing this support would be a breaking change. The test is included here
1778
+ # because it seems most likely that someone would break this behavior while trying
1779
+ # to fix __path__ behavior.
1780
+ it "does not dup in the background when a node is assigned" do
1781
+ # get a handle on a vividmash (can't be a hash or else we convert_value it)
1782
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1783
+ a = node.default["foo"]
1784
+ # assign that somewhere else in the tree
1785
+ node.default["fizz"] = a
1786
+ # now upate the source
1787
+ a["duptest"] = true
1788
+ # the tree should have been updated
1789
+ expect(node.default["fizz"]["duptest"]).to be true
1790
+ expect(node["fizz"]["duptest"]).to be true
1791
+ end
1792
+ end
1793
+
1794
+ describe "root tracking via __root__" do
1795
+ it "works through hash keys" do
1796
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1797
+ expect(node["foo"]["bar"].__root__).to eql(node.attributes)
1798
+ end
1799
+
1800
+ it "works through the default level" do
1801
+ node.default["foo"] = { "bar" => { "baz" => "qux" } }
1802
+ expect(node.default["foo"]["bar"].__root__).to eql(node.attributes)
1803
+ end
1804
+
1805
+ it "works through arrays" do
1806
+ node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1807
+ expect(node["foo"][0].__root__).to eql(node.attributes)
1808
+ expect(node["foo"][0]["bar"].__root__).to eql(node.attributes)
1809
+ end
1810
+
1811
+ it "works through arrays at the default level" do
1812
+ node.default["foo"] = [ { "bar" => { "baz" => "qux" } } ]
1813
+ expect(node.default["foo"][0].__root__).to eql(node.attributes)
1814
+ expect(node.default["foo"][0]["bar"].__root__).to eql(node.attributes)
1815
+ end
1816
+ end
1817
+
1818
+ describe "ways of abusing Chef 12 node state" do
1819
+ # these tests abuse the top_level_breadcrumb state in Chef 12
1820
+ it "derived attributes work correctly" do
1821
+ node.default["v1"] = 1
1822
+ expect(node["a"]).to eql(nil)
1823
+ node.default["a"] = node["v1"]
1824
+ expect(node["a"]).to eql(1)
1825
+ end
1826
+
1827
+ it "works when saving nodes to variables" do
1828
+ a = node.default["a"]
1829
+ expect(node["a"]).to eql({})
1830
+ node.default["b"] = 0
1831
+ a["key"] = 1
1832
+
1833
+ expect(node["a"]["key"]).to eql(1)
1834
+ end
1835
+ end
1836
+ end