chef 12.0.3-x86-mingw32 → 12.1.0.rc.0-x86-mingw32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (653) hide show
  1. checksums.yaml +4 -4
  2. data/CONTRIBUTING.md +4 -1
  3. data/README.md +42 -18
  4. data/distro/common/html/_sources/ctl_chef_client.txt +1 -1
  5. data/distro/common/html/_sources/ctl_chef_server.txt +53 -35
  6. data/distro/common/html/_sources/ctl_chef_solo.txt +1 -1
  7. data/distro/common/html/_sources/knife_bootstrap.txt +1 -1
  8. data/distro/common/html/_sources/knife_cookbook_site.txt +1 -1
  9. data/distro/common/html/_sources/knife_data_bag.txt +4 -4
  10. data/distro/common/html/_sources/knife_status.txt +1 -1
  11. data/distro/common/html/_static/searchtools.js +1 -1
  12. data/distro/common/html/ctl_chef_client.html +55 -7
  13. data/distro/common/html/ctl_chef_server.html +84 -41
  14. data/distro/common/html/ctl_chef_shell.html +45 -1
  15. data/distro/common/html/ctl_chef_solo.html +51 -5
  16. data/distro/common/html/index.html +2 -2
  17. data/distro/common/html/knife.html +1 -1
  18. data/distro/common/html/knife_bootstrap.html +30 -10
  19. data/distro/common/html/knife_cookbook_site.html +2 -0
  20. data/distro/common/html/knife_data_bag.html +4 -4
  21. data/distro/common/html/knife_node.html +2 -2
  22. data/distro/common/html/knife_raw.html +1 -1
  23. data/distro/common/html/knife_role.html +1 -1
  24. data/distro/common/html/knife_search.html +3 -3
  25. data/distro/common/html/knife_status.html +4 -0
  26. data/distro/common/html/searchindex.js +1 -1
  27. data/distro/common/man/man1/chef-shell.1 +72 -1
  28. data/distro/common/man/man1/knife-bootstrap.1 +71 -63
  29. data/distro/common/man/man1/knife-client.1 +1 -1
  30. data/distro/common/man/man1/knife-configure.1 +1 -1
  31. data/distro/common/man/man1/knife-cookbook-site.1 +4 -1
  32. data/distro/common/man/man1/knife-cookbook.1 +1 -1
  33. data/distro/common/man/man1/knife-data-bag.1 +5 -5
  34. data/distro/common/man/man1/knife-delete.1 +1 -1
  35. data/distro/common/man/man1/knife-deps.1 +1 -1
  36. data/distro/common/man/man1/knife-diff.1 +1 -1
  37. data/distro/common/man/man1/knife-download.1 +1 -1
  38. data/distro/common/man/man1/knife-edit.1 +1 -1
  39. data/distro/common/man/man1/knife-environment.1 +1 -1
  40. data/distro/common/man/man1/knife-exec.1 +1 -1
  41. data/distro/common/man/man1/knife-index-rebuild.1 +1 -1
  42. data/distro/common/man/man1/knife-list.1 +1 -1
  43. data/distro/common/man/man1/knife-node.1 +3 -3
  44. data/distro/common/man/man1/knife-raw.1 +2 -2
  45. data/distro/common/man/man1/knife-recipe-list.1 +1 -1
  46. data/distro/common/man/man1/knife-role.1 +2 -2
  47. data/distro/common/man/man1/knife-search.1 +4 -4
  48. data/distro/common/man/man1/knife-serve.1 +1 -1
  49. data/distro/common/man/man1/knife-show.1 +1 -1
  50. data/distro/common/man/man1/knife-ssh.1 +1 -1
  51. data/distro/common/man/man1/knife-ssl-check.1 +1 -1
  52. data/distro/common/man/man1/knife-ssl-fetch.1 +1 -1
  53. data/distro/common/man/man1/knife-status.1 +1 -1
  54. data/distro/common/man/man1/knife-tag.1 +1 -1
  55. data/distro/common/man/man1/knife-upload.1 +1 -1
  56. data/distro/common/man/man1/knife-user.1 +1 -1
  57. data/distro/common/man/man1/knife-xargs.1 +1 -1
  58. data/distro/common/man/man1/knife.1 +1 -1
  59. data/distro/common/man/man8/chef-apply.8 +86 -0
  60. data/distro/common/man/man8/chef-client.8 +76 -5
  61. data/distro/common/man/man8/chef-solo.8 +79 -6
  62. data/distro/common/markdown/man1/knife-bootstrap.mkd +1 -1
  63. data/distro/common/markdown/man1/knife-cookbook-site.mkd +1 -1
  64. data/distro/common/markdown/man1/knife-data-bag.mkd +1 -1
  65. data/distro/common/markdown/man1/knife-environment.mkd +1 -1
  66. data/distro/common/markdown/man1/knife.mkd +1 -1
  67. data/lib/chef.rb +0 -7
  68. data/lib/chef/api_client.rb +10 -2
  69. data/lib/chef/api_client/registration.rb +7 -9
  70. data/lib/chef/application.rb +28 -12
  71. data/lib/chef/application/apply.rb +17 -1
  72. data/lib/chef/application/client.rb +74 -6
  73. data/lib/chef/application/knife.rb +1 -2
  74. data/lib/chef/application/solo.rb +30 -0
  75. data/lib/chef/application/windows_service.rb +1 -0
  76. data/lib/chef/application/windows_service_manager.rb +8 -2
  77. data/lib/chef/applications.rb +0 -1
  78. data/lib/chef/audit/audit_event_proxy.rb +93 -0
  79. data/lib/chef/audit/audit_reporter.rb +169 -0
  80. data/lib/chef/audit/control_group_data.rb +140 -0
  81. data/lib/chef/audit/rspec_formatter.rb +37 -0
  82. data/lib/chef/audit/runner.rb +178 -0
  83. data/lib/chef/chef_fs/chef_fs_data_store.rb +11 -2
  84. data/lib/chef/chef_fs/config.rb +25 -4
  85. data/lib/chef/chef_fs/data_handler/policy_data_handler.rb +15 -0
  86. data/lib/chef/chef_fs/data_handler/user_data_handler.rb +1 -0
  87. data/lib/chef/chef_fs/file_system.rb +1 -1
  88. data/lib/chef/chef_fs/file_system/base_fs_dir.rb +5 -0
  89. data/lib/chef/chef_fs/file_system/chef_repository_file_system_cookbook_entry.rb +3 -2
  90. data/lib/chef/{shef/ext.rb → chef_fs/file_system/chef_repository_file_system_policies_dir.rb} +22 -3
  91. data/lib/chef/chef_fs/file_system/chef_repository_file_system_root_dir.rb +4 -0
  92. data/lib/chef/client.rb +81 -52
  93. data/lib/chef/config.rb +35 -3
  94. data/lib/chef/cookbook/metadata.rb +3 -3
  95. data/lib/chef/cookbook_manifest.rb +275 -0
  96. data/lib/chef/cookbook_site_streaming_uploader.rb +24 -23
  97. data/lib/chef/cookbook_uploader.rb +11 -2
  98. data/lib/chef/cookbook_version.rb +71 -194
  99. data/lib/chef/data_bag.rb +5 -2
  100. data/lib/chef/data_bag_item.rb +6 -3
  101. data/lib/chef/deprecation/warnings.rb +5 -4
  102. data/lib/chef/dsl/audit.rb +51 -0
  103. data/lib/chef/dsl/include_recipe.rb +2 -3
  104. data/lib/chef/dsl/reboot_pending.rb +1 -1
  105. data/lib/chef/dsl/recipe.rb +49 -31
  106. data/lib/chef/encrypted_data_bag_item/assertions.rb +0 -3
  107. data/lib/chef/environment.rb +5 -2
  108. data/lib/chef/event_dispatch/base.rb +36 -1
  109. data/lib/chef/event_dispatch/dispatcher.rb +3 -5
  110. data/lib/chef/exceptions.rb +61 -2
  111. data/lib/chef/file_access_control/unix.rb +12 -0
  112. data/lib/chef/file_access_control/windows.rb +14 -0
  113. data/lib/chef/formatters/doc.rb +47 -1
  114. data/{spec/unit/monkey_patches/string_spec.rb → lib/chef/guard_interpreter.rb} +11 -16
  115. data/lib/chef/guard_interpreter/resource_guard_interpreter.rb +3 -2
  116. data/lib/chef/http.rb +1 -2
  117. data/lib/chef/knife.rb +5 -3
  118. data/lib/chef/knife/bootstrap.rb +84 -15
  119. data/lib/chef/knife/bootstrap/chef_vault_handler.rb +165 -0
  120. data/lib/chef/knife/bootstrap/client_builder.rb +190 -0
  121. data/lib/chef/knife/bootstrap/{README.md → templates/README.md} +0 -0
  122. data/lib/chef/knife/bootstrap/{archlinux-gems.erb → templates/archlinux-gems.erb} +9 -0
  123. data/lib/chef/knife/bootstrap/{chef-aix.erb → templates/chef-aix.erb} +9 -0
  124. data/lib/chef/knife/bootstrap/{chef-full.erb → templates/chef-full.erb} +10 -1
  125. data/lib/chef/knife/client_create.rb +8 -7
  126. data/lib/chef/knife/cookbook_site_download.rb +1 -1
  127. data/lib/chef/knife/cookbook_site_install.rb +1 -1
  128. data/lib/chef/knife/cookbook_site_list.rb +1 -1
  129. data/lib/chef/knife/cookbook_site_search.rb +1 -1
  130. data/lib/chef/knife/cookbook_site_share.rb +39 -28
  131. data/lib/chef/knife/cookbook_site_show.rb +3 -3
  132. data/lib/chef/knife/cookbook_site_unshare.rb +1 -1
  133. data/lib/chef/knife/cookbook_test.rb +1 -0
  134. data/lib/chef/knife/cookbook_upload.rb +13 -8
  135. data/lib/chef/knife/core/bootstrap_context.rb +14 -3
  136. data/lib/chef/knife/core/generic_presenter.rb +5 -2
  137. data/lib/chef/knife/core/object_loader.rb +1 -1
  138. data/lib/chef/knife/core/subcommand_loader.rb +24 -0
  139. data/lib/chef/knife/core/ui.rb +9 -1
  140. data/lib/chef/knife/node_run_list_remove.rb +11 -3
  141. data/lib/chef/knife/raw.rb +14 -3
  142. data/lib/chef/knife/role_env_run_list_add.rb +86 -0
  143. data/lib/chef/knife/role_env_run_list_clear.rb +55 -0
  144. data/lib/chef/knife/role_env_run_list_remove.rb +57 -0
  145. data/lib/chef/knife/role_env_run_list_replace.rb +59 -0
  146. data/lib/chef/knife/role_env_run_list_set.rb +70 -0
  147. data/lib/chef/knife/role_run_list_add.rb +86 -0
  148. data/lib/chef/knife/role_run_list_clear.rb +55 -0
  149. data/lib/chef/knife/role_run_list_remove.rb +57 -0
  150. data/lib/chef/knife/role_run_list_replace.rb +59 -0
  151. data/lib/chef/knife/role_run_list_set.rb +70 -0
  152. data/lib/chef/knife/search.rb +4 -4
  153. data/lib/chef/knife/serve.rb +3 -0
  154. data/lib/chef/knife/ssh.rb +1 -1
  155. data/lib/chef/knife/ssl_check.rb +2 -2
  156. data/lib/chef/knife/ssl_fetch.rb +14 -1
  157. data/lib/chef/log.rb +10 -1
  158. data/lib/chef/mixin/command.rb +1 -1
  159. data/lib/chef/mixin/command/windows.rb +1 -5
  160. data/lib/chef/mixin/get_source_from_package.rb +1 -0
  161. data/lib/chef/mixin/params_validate.rb +2 -2
  162. data/lib/chef/mixin/securable.rb +1 -7
  163. data/lib/chef/mixin/shell_out.rb +7 -1
  164. data/lib/chef/mixin/template.rb +2 -14
  165. data/lib/chef/mixin/why_run.rb +1 -1
  166. data/lib/chef/monkey_patches/net_http.rb +4 -0
  167. data/lib/chef/monologger.rb +0 -2
  168. data/lib/chef/node.rb +5 -2
  169. data/lib/chef/node/attribute.rb +11 -9
  170. data/lib/chef/node/attribute_collections.rb +8 -12
  171. data/lib/chef/node/immutable_collections.rb +4 -10
  172. data/lib/chef/org.rb +148 -0
  173. data/lib/chef/platform/provider_mapping.rb +3 -2
  174. data/lib/chef/platform/provider_priority_map.rb +2 -0
  175. data/lib/chef/platform/query_helpers.rb +0 -3
  176. data/lib/chef/policy_builder/policyfile.rb +51 -8
  177. data/lib/chef/provider/deploy.rb +1 -2
  178. data/lib/chef/provider/directory.rb +3 -3
  179. data/lib/chef/provider/dsc_script.rb +13 -7
  180. data/lib/chef/provider/env.rb +8 -8
  181. data/lib/chef/provider/execute.rb +55 -36
  182. data/lib/chef/provider/file.rb +8 -0
  183. data/lib/chef/provider/group.rb +2 -0
  184. data/lib/chef/provider/group/dscl.rb +3 -4
  185. data/lib/chef/provider/ifconfig.rb +25 -25
  186. data/lib/chef/provider/ifconfig/aix.rb +25 -27
  187. data/lib/chef/provider/lwrp_base.rb +1 -1
  188. data/lib/chef/provider/mount.rb +2 -2
  189. data/lib/chef/provider/mount/mount.rb +3 -4
  190. data/lib/chef/provider/mount/solaris.rb +1 -1
  191. data/lib/chef/provider/package.rb +297 -48
  192. data/lib/chef/provider/package/aix.rb +25 -30
  193. data/lib/chef/provider/package/apt.rb +63 -19
  194. data/lib/chef/provider/package/dpkg.rb +15 -16
  195. data/lib/chef/provider/package/macports.rb +7 -7
  196. data/lib/chef/provider/package/openbsd.rb +107 -0
  197. data/lib/chef/provider/package/pacman.rb +13 -15
  198. data/lib/chef/provider/package/portage.rb +3 -4
  199. data/lib/chef/provider/package/rpm.rb +28 -17
  200. data/lib/chef/provider/package/rubygems.rb +9 -9
  201. data/lib/chef/provider/package/solaris.rb +17 -21
  202. data/lib/chef/provider/package/windows/msi.rb +1 -1
  203. data/lib/chef/provider/package/yum-dump.py +2 -2
  204. data/lib/chef/provider/package/yum.rb +117 -51
  205. data/lib/chef/provider/package/zypper.rb +17 -18
  206. data/lib/chef/provider/powershell_script.rb +4 -4
  207. data/lib/chef/provider/registry_key.rb +2 -2
  208. data/lib/chef/provider/remote_directory.rb +1 -1
  209. data/lib/chef/provider/script.rb +25 -16
  210. data/lib/chef/provider/service.rb +1 -1
  211. data/lib/chef/provider/service/freebsd.rb +1 -1
  212. data/lib/chef/provider/service/openbsd.rb +216 -0
  213. data/lib/chef/provider/service/upstart.rb +1 -1
  214. data/lib/chef/provider/service/windows.rb +99 -1
  215. data/lib/chef/provider/user.rb +1 -1
  216. data/lib/chef/provider/user/dscl.rb +19 -4
  217. data/lib/chef/providers.rb +2 -0
  218. data/lib/chef/recipe.rb +11 -5
  219. data/lib/chef/request_id.rb +1 -1
  220. data/lib/chef/resource.rb +839 -444
  221. data/lib/chef/resource/chef_gem.rb +20 -3
  222. data/lib/chef/resource/conditional.rb +3 -14
  223. data/lib/chef/resource/dsc_script.rb +14 -0
  224. data/lib/chef/resource/execute.rb +14 -7
  225. data/lib/chef/resource/file.rb +14 -0
  226. data/lib/chef/resource/file/verification.rb +122 -0
  227. data/lib/chef/resource/ips_package.rb +1 -1
  228. data/lib/chef/resource/lwrp_base.rb +2 -11
  229. data/lib/chef/resource/macports_package.rb +2 -1
  230. data/lib/chef/resource/openbsd_package.rb +51 -0
  231. data/lib/chef/resource/package.rb +2 -2
  232. data/lib/chef/resource/paludis_package.rb +1 -1
  233. data/lib/chef/resource/reboot.rb +1 -1
  234. data/lib/chef/resource/remote_file.rb +1 -0
  235. data/lib/chef/resource/rpm_package.rb +9 -0
  236. data/lib/chef/resource/script.rb +11 -0
  237. data/lib/chef/resource/template.rb +2 -3
  238. data/lib/chef/resource/windows_package.rb +1 -1
  239. data/lib/chef/resource/windows_service.rb +18 -0
  240. data/lib/chef/resource_builder.rb +137 -0
  241. data/lib/chef/resource_definition.rb +1 -1
  242. data/lib/chef/resource_reporter.rb +1 -1
  243. data/lib/chef/resources.rb +1 -0
  244. data/lib/chef/role.rb +17 -4
  245. data/lib/chef/run_context.rb +10 -6
  246. data/lib/chef/search/query.rb +66 -87
  247. data/lib/chef/shell/ext.rb +2 -2
  248. data/lib/chef/util/diff.rb +1 -4
  249. data/lib/chef/util/dsc/configuration_generator.rb +30 -6
  250. data/lib/chef/util/dsc/lcm_output_parser.rb +7 -3
  251. data/lib/chef/util/dsc/local_configuration_manager.rb +8 -8
  252. data/lib/chef/util/file_edit.rb +2 -2
  253. data/lib/chef/util/path_helper.rb +1 -4
  254. data/lib/chef/util/windows/net_use.rb +3 -3
  255. data/lib/chef/version.rb +1 -1
  256. data/lib/chef/win32/api.rb +1 -0
  257. data/lib/chef/win32/api/security.rb +26 -0
  258. data/lib/chef/win32/file.rb +21 -0
  259. data/lib/chef/win32/security.rb +46 -0
  260. data/lib/chef/win32/security/token.rb +8 -0
  261. data/lib/chef/win32/version.rb +0 -4
  262. data/spec/data/recipes.tgz +0 -0
  263. data/spec/functional/application_spec.rb +1 -1
  264. data/spec/functional/audit/rspec_formatter_spec.rb +54 -0
  265. data/spec/functional/audit/runner_spec.rb +137 -0
  266. data/spec/functional/dsl/reboot_pending_spec.rb +10 -10
  267. data/spec/functional/dsl/registry_helper_spec.rb +6 -6
  268. data/spec/functional/event_loggers/windows_eventlog_spec.rb +5 -5
  269. data/spec/functional/file_content_management/deploy_strategies_spec.rb +12 -21
  270. data/spec/functional/http/simple_spec.rb +1 -1
  271. data/spec/functional/knife/cookbook_delete_spec.rb +24 -24
  272. data/spec/functional/knife/exec_spec.rb +2 -4
  273. data/spec/functional/knife/smoke_test.rb +1 -1
  274. data/spec/functional/knife/ssh_spec.rb +23 -23
  275. data/spec/functional/provider/remote_file/cache_control_data_spec.rb +8 -8
  276. data/spec/functional/provider/whyrun_safe_ruby_block_spec.rb +2 -2
  277. data/spec/functional/rebooter_spec.rb +1 -1
  278. data/spec/functional/resource/aix_service_spec.rb +3 -0
  279. data/spec/functional/resource/aixinit_service_spec.rb +3 -3
  280. data/spec/functional/resource/bash_spec.rb +88 -0
  281. data/spec/functional/resource/deploy_revision_spec.rb +99 -100
  282. data/spec/functional/resource/env_spec.rb +3 -3
  283. data/spec/functional/resource/execute_spec.rb +97 -63
  284. data/spec/functional/resource/file_spec.rb +7 -7
  285. data/spec/functional/resource/git_spec.rb +13 -13
  286. data/spec/functional/resource/group_spec.rb +28 -25
  287. data/spec/functional/resource/ifconfig_spec.rb +2 -2
  288. data/spec/functional/resource/link_spec.rb +77 -78
  289. data/spec/functional/resource/mount_spec.rb +5 -5
  290. data/spec/functional/resource/ohai_spec.rb +1 -1
  291. data/spec/functional/resource/package_spec.rb +22 -22
  292. data/spec/functional/resource/powershell_spec.rb +57 -42
  293. data/spec/functional/resource/reboot_spec.rb +2 -2
  294. data/spec/functional/resource/registry_spec.rb +91 -91
  295. data/spec/functional/resource/remote_directory_spec.rb +19 -19
  296. data/spec/functional/resource/remote_file_spec.rb +18 -18
  297. data/spec/functional/resource/template_spec.rb +4 -4
  298. data/spec/functional/resource/user/dscl_spec.rb +4 -4
  299. data/spec/functional/resource/user/useradd_spec.rb +64 -51
  300. data/spec/functional/resource/windows_service_spec.rb +98 -0
  301. data/spec/functional/run_lock_spec.rb +9 -9
  302. data/spec/functional/shell_spec.rb +3 -3
  303. data/spec/functional/tiny_server_spec.rb +12 -12
  304. data/spec/functional/util/path_helper_spec.rb +1 -1
  305. data/spec/functional/version_spec.rb +1 -1
  306. data/spec/functional/win32/registry_helper_spec.rb +125 -125
  307. data/spec/functional/win32/security_spec.rb +65 -2
  308. data/spec/functional/win32/service_manager_spec.rb +30 -84
  309. data/spec/functional/win32/versions_spec.rb +6 -6
  310. data/spec/integration/client/client_spec.rb +102 -9
  311. data/spec/integration/knife/chef_fs_data_store_spec.rb +12 -8
  312. data/spec/integration/knife/common_options_spec.rb +3 -3
  313. data/spec/integration/knife/cookbook_api_ipv6_spec.rb +2 -2
  314. data/spec/integration/knife/deps_spec.rb +4 -4
  315. data/spec/integration/knife/diff_spec.rb +6 -6
  316. data/spec/integration/knife/download_spec.rb +6 -6
  317. data/spec/integration/knife/list_spec.rb +2 -2
  318. data/spec/integration/knife/raw_spec.rb +5 -5
  319. data/spec/integration/knife/serve_spec.rb +3 -3
  320. data/spec/integration/knife/show_spec.rb +3 -3
  321. data/spec/integration/knife/upload_spec.rb +18 -18
  322. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
  323. data/spec/integration/solo/solo_spec.rb +11 -12
  324. data/spec/spec_helper.rb +27 -15
  325. data/spec/stress/win32/file_spec.rb +4 -4
  326. data/spec/stress/win32/security_spec.rb +4 -4
  327. data/spec/support/chef_helpers.rb +3 -3
  328. data/spec/support/matchers/leak.rb +2 -2
  329. data/spec/support/mock/platform.rb +1 -1
  330. data/spec/support/pedant/Gemfile +3 -0
  331. data/spec/support/pedant/pedant_config.rb +9 -2
  332. data/spec/support/pedant/run_pedant.rb +15 -16
  333. data/spec/support/platform_helpers.rb +8 -12
  334. data/spec/support/shared/functional/directory_resource.rb +13 -13
  335. data/spec/support/shared/functional/file_resource.rb +83 -83
  336. data/spec/support/shared/functional/http.rb +1 -1
  337. data/spec/support/shared/functional/securable_resource.rb +64 -64
  338. data/spec/support/shared/functional/securable_resource_with_reporting.rb +43 -41
  339. data/spec/support/shared/functional/win32_service.rb +60 -0
  340. data/spec/support/shared/functional/windows_script.rb +8 -8
  341. data/spec/support/shared/integration/knife_support.rb +8 -5
  342. data/spec/support/shared/matchers/exit_with_code.rb +6 -2
  343. data/spec/support/shared/unit/api_error_inspector.rb +8 -8
  344. data/spec/support/shared/unit/execute_resource.rb +24 -20
  345. data/spec/support/shared/unit/file_system_support.rb +2 -2
  346. data/spec/support/shared/unit/platform_introspector.rb +21 -21
  347. data/spec/support/shared/unit/provider/file.rb +239 -210
  348. data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +69 -69
  349. data/spec/support/shared/unit/script_resource.rb +40 -32
  350. data/spec/support/shared/unit/windows_script_resource.rb +8 -8
  351. data/spec/unit/api_client/registration_spec.rb +47 -47
  352. data/spec/unit/api_client_spec.rb +107 -69
  353. data/spec/unit/application/apply_spec.rb +31 -15
  354. data/spec/unit/application/client_spec.rb +146 -45
  355. data/spec/unit/application/knife_spec.rb +31 -31
  356. data/spec/unit/application/solo_spec.rb +59 -43
  357. data/spec/unit/application_spec.rb +109 -74
  358. data/spec/unit/audit/audit_event_proxy_spec.rb +311 -0
  359. data/spec/unit/audit/audit_reporter_spec.rb +393 -0
  360. data/spec/unit/audit/control_group_data_spec.rb +478 -0
  361. data/{lib/chef/monkey_patches/file.rb → spec/unit/audit/rspec_formatter_spec.rb} +11 -8
  362. data/spec/unit/audit/runner_spec.rb +135 -0
  363. data/spec/unit/chef_fs/config_spec.rb +52 -0
  364. data/spec/unit/chef_fs/diff_spec.rb +12 -12
  365. data/spec/unit/chef_fs/file_pattern_spec.rb +276 -277
  366. data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +6 -6
  367. data/spec/unit/chef_fs/file_system_spec.rb +26 -13
  368. data/spec/unit/chef_fs/parallelizer.rb +87 -87
  369. data/spec/unit/chef_spec.rb +1 -1
  370. data/spec/unit/client_spec.rb +263 -97
  371. data/spec/unit/config_fetcher_spec.rb +13 -13
  372. data/spec/unit/config_spec.rb +105 -66
  373. data/spec/unit/cookbook/chefignore_spec.rb +6 -6
  374. data/spec/unit/cookbook/cookbook_version_loader_spec.rb +3 -3
  375. data/spec/unit/cookbook/metadata_spec.rb +149 -149
  376. data/spec/unit/cookbook/syntax_check_spec.rb +36 -31
  377. data/spec/unit/cookbook_loader_spec.rb +62 -58
  378. data/spec/unit/cookbook_manifest_spec.rb +141 -468
  379. data/spec/unit/cookbook_site_streaming_uploader_spec.rb +27 -27
  380. data/spec/unit/cookbook_spec.rb +15 -15
  381. data/spec/unit/cookbook_uploader_spec.rb +37 -3
  382. data/spec/unit/cookbook_version_file_specificity_spec.rb +554 -0
  383. data/spec/unit/cookbook_version_spec.rb +98 -240
  384. data/spec/unit/daemon_spec.rb +31 -31
  385. data/spec/unit/data_bag_item_spec.rb +121 -89
  386. data/spec/unit/data_bag_spec.rb +35 -35
  387. data/spec/unit/deprecation_spec.rb +27 -14
  388. data/spec/unit/digester_spec.rb +3 -3
  389. data/spec/unit/dsl/audit_spec.rb +43 -0
  390. data/spec/unit/dsl/data_query_spec.rb +1 -1
  391. data/spec/unit/dsl/platform_introspection_spec.rb +14 -14
  392. data/spec/unit/dsl/reboot_pending_spec.rb +18 -18
  393. data/spec/unit/dsl/regsitry_helper_spec.rb +6 -6
  394. data/spec/unit/encrypted_data_bag_item_spec.rb +58 -82
  395. data/spec/unit/environment_spec.rb +105 -105
  396. data/spec/unit/exceptions_spec.rb +47 -1
  397. data/spec/unit/file_access_control_spec.rb +62 -56
  398. data/spec/unit/file_cache_spec.rb +11 -11
  399. data/spec/unit/file_content_management/deploy/cp_spec.rb +2 -2
  400. data/spec/unit/file_content_management/deploy/mv_unix_spec.rb +10 -10
  401. data/spec/unit/file_content_management/deploy/mv_windows_spec.rb +23 -23
  402. data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +14 -14
  403. data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +12 -12
  404. data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +1 -1
  405. data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +16 -16
  406. data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +4 -4
  407. data/spec/unit/guard_interpreter/resource_guard_interpreter_spec.rb +103 -13
  408. data/spec/unit/guard_interpreter_spec.rb +41 -0
  409. data/spec/unit/handler/json_file_spec.rb +10 -10
  410. data/spec/unit/handler_spec.rb +39 -39
  411. data/spec/unit/http/basic_client_spec.rb +3 -3
  412. data/spec/unit/http/http_request_spec.rb +10 -10
  413. data/spec/unit/http/simple_spec.rb +3 -3
  414. data/spec/unit/http/ssl_policies_spec.rb +15 -15
  415. data/spec/unit/http/validate_content_length_spec.rb +18 -13
  416. data/spec/unit/http_spec.rb +16 -9
  417. data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +153 -0
  418. data/spec/unit/knife/bootstrap/client_builder_spec.rb +178 -0
  419. data/spec/unit/knife/bootstrap_spec.rb +144 -91
  420. data/spec/unit/knife/client_bulk_delete_spec.rb +24 -24
  421. data/spec/unit/knife/client_create_spec.rb +57 -43
  422. data/spec/unit/knife/client_delete_spec.rb +15 -15
  423. data/spec/unit/knife/client_edit_spec.rb +4 -4
  424. data/spec/unit/knife/client_list_spec.rb +2 -2
  425. data/spec/unit/knife/client_reregister_spec.rb +9 -9
  426. data/spec/unit/knife/configure_client_spec.rb +20 -20
  427. data/spec/unit/knife/configure_spec.rb +85 -85
  428. data/spec/unit/knife/cookbook_bulk_delete_spec.rb +15 -15
  429. data/spec/unit/knife/cookbook_create_spec.rb +59 -59
  430. data/spec/unit/knife/cookbook_delete_spec.rb +49 -49
  431. data/spec/unit/knife/cookbook_download_spec.rb +56 -56
  432. data/spec/unit/knife/cookbook_list_spec.rb +9 -9
  433. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +8 -8
  434. data/spec/unit/knife/cookbook_metadata_spec.rb +44 -44
  435. data/spec/unit/knife/cookbook_show_spec.rb +29 -29
  436. data/spec/unit/knife/cookbook_site_download_spec.rb +26 -26
  437. data/spec/unit/knife/cookbook_site_install_spec.rb +5 -1
  438. data/spec/unit/knife/cookbook_site_share_spec.rb +68 -59
  439. data/spec/unit/knife/cookbook_site_unshare_spec.rb +15 -15
  440. data/spec/unit/knife/cookbook_test_spec.rb +16 -16
  441. data/spec/unit/knife/cookbook_upload_spec.rb +105 -71
  442. data/spec/unit/knife/core/bootstrap_context_spec.rb +37 -22
  443. data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +36 -36
  444. data/spec/unit/knife/core/object_loader_spec.rb +3 -3
  445. data/spec/unit/knife/core/subcommand_loader_spec.rb +107 -33
  446. data/spec/unit/knife/core/ui_spec.rb +84 -72
  447. data/spec/unit/knife/data_bag_from_file_spec.rb +1 -1
  448. data/spec/unit/knife/environment_compare_spec.rb +12 -12
  449. data/spec/unit/knife/environment_create_spec.rb +16 -16
  450. data/spec/unit/knife/environment_delete_spec.rb +14 -14
  451. data/spec/unit/knife/environment_edit_spec.rb +15 -15
  452. data/spec/unit/knife/environment_from_file_spec.rb +17 -17
  453. data/spec/unit/knife/environment_list_spec.rb +7 -7
  454. data/spec/unit/knife/environment_show_spec.rb +10 -10
  455. data/spec/unit/knife/index_rebuild_spec.rb +17 -17
  456. data/spec/unit/knife/knife_help.rb +24 -24
  457. data/spec/unit/knife/node_bulk_delete_spec.rb +14 -14
  458. data/spec/unit/knife/node_delete_spec.rb +11 -11
  459. data/spec/unit/knife/node_edit_spec.rb +17 -17
  460. data/spec/unit/knife/node_environment_set_spec.rb +12 -12
  461. data/spec/unit/knife/node_from_file_spec.rb +8 -8
  462. data/spec/unit/knife/node_list_spec.rb +9 -9
  463. data/spec/unit/knife/node_run_list_add_spec.rb +29 -29
  464. data/spec/unit/knife/node_run_list_remove_spec.rb +28 -13
  465. data/spec/unit/knife/node_run_list_set_spec.rb +27 -27
  466. data/spec/unit/knife/raw_spec.rb +43 -0
  467. data/spec/unit/knife/role_bulk_delete_spec.rb +12 -12
  468. data/spec/unit/knife/role_create_spec.rb +12 -12
  469. data/spec/unit/knife/role_delete_spec.rb +10 -10
  470. data/spec/unit/knife/role_edit_spec.rb +13 -13
  471. data/spec/unit/knife/role_env_run_list_add_spec.rb +217 -0
  472. data/spec/unit/knife/role_env_run_list_clear_spec.rb +100 -0
  473. data/spec/unit/knife/role_env_run_list_remove_spec.rb +108 -0
  474. data/spec/unit/knife/role_env_run_list_replace_spec.rb +108 -0
  475. data/spec/unit/knife/role_env_run_list_set_spec.rb +102 -0
  476. data/spec/unit/knife/role_from_file_spec.rb +10 -10
  477. data/spec/unit/knife/role_list_spec.rb +7 -7
  478. data/spec/unit/knife/role_run_list_add_spec.rb +179 -0
  479. data/spec/unit/knife/role_run_list_clear_spec.rb +90 -0
  480. data/spec/unit/knife/role_run_list_remove_spec.rb +98 -0
  481. data/spec/unit/knife/role_run_list_replace_spec.rb +101 -0
  482. data/spec/unit/knife/role_run_list_set_spec.rb +92 -0
  483. data/spec/unit/knife/ssh_spec.rb +66 -66
  484. data/spec/unit/knife/ssl_check_spec.rb +27 -27
  485. data/spec/unit/knife/ssl_fetch_spec.rb +45 -12
  486. data/spec/unit/knife/status_spec.rb +5 -5
  487. data/spec/unit/knife/tag_create_spec.rb +5 -5
  488. data/spec/unit/knife/tag_delete_spec.rb +6 -6
  489. data/spec/unit/knife/tag_list_spec.rb +4 -4
  490. data/spec/unit/knife/user_create_spec.rb +18 -18
  491. data/spec/unit/knife/user_delete_spec.rb +4 -4
  492. data/spec/unit/knife/user_edit_spec.rb +7 -7
  493. data/spec/unit/knife/user_list_spec.rb +2 -2
  494. data/spec/unit/knife/user_reregister_spec.rb +10 -10
  495. data/spec/unit/knife/user_show_spec.rb +5 -5
  496. data/spec/unit/knife_spec.rb +36 -36
  497. data/spec/unit/lwrp_spec.rb +63 -39
  498. data/spec/unit/mash_spec.rb +6 -6
  499. data/spec/unit/mixin/checksum_spec.rb +2 -2
  500. data/spec/unit/mixin/command_spec.rb +13 -13
  501. data/spec/unit/mixin/convert_to_class_name_spec.rb +6 -6
  502. data/spec/unit/mixin/deep_merge_spec.rb +49 -49
  503. data/spec/unit/mixin/deprecation_spec.rb +5 -5
  504. data/spec/unit/mixin/enforce_ownership_and_permissions_spec.rb +14 -14
  505. data/spec/unit/mixin/homebrew_user_spec.rb +3 -3
  506. data/spec/unit/mixin/params_validate_spec.rb +71 -71
  507. data/spec/unit/mixin/path_sanity_spec.rb +14 -14
  508. data/spec/unit/mixin/securable_spec.rb +177 -177
  509. data/spec/unit/mixin/shell_out_spec.rb +56 -27
  510. data/spec/unit/mixin/template_spec.rb +31 -31
  511. data/spec/unit/mixin/windows_architecture_helper_spec.rb +5 -5
  512. data/spec/unit/mixin/xml_escape_spec.rb +7 -7
  513. data/spec/unit/monkey_patches/uri_spec.rb +1 -1
  514. data/spec/unit/monologger_spec.rb +3 -3
  515. data/spec/unit/node/attribute_spec.rb +185 -136
  516. data/spec/unit/node/immutable_collections_spec.rb +22 -22
  517. data/spec/unit/node_spec.rb +210 -179
  518. data/spec/unit/org_spec.rb +196 -0
  519. data/spec/unit/platform/query_helpers_spec.rb +5 -5
  520. data/spec/unit/platform_spec.rb +46 -46
  521. data/spec/unit/policy_builder/expand_node_object_spec.rb +17 -18
  522. data/spec/unit/policy_builder/policyfile_spec.rb +159 -71
  523. data/spec/unit/provider/directory_spec.rb +5 -5
  524. data/spec/unit/provider/dsc_script_spec.rb +6 -6
  525. data/spec/unit/provider/env_spec.rb +27 -14
  526. data/spec/unit/provider/execute_spec.rb +139 -68
  527. data/spec/unit/provider/file/content_spec.rb +8 -8
  528. data/spec/unit/provider/git_spec.rb +10 -5
  529. data/spec/unit/provider/group/dscl_spec.rb +8 -11
  530. data/spec/unit/provider/group_spec.rb +13 -13
  531. data/spec/unit/provider/ifconfig/aix_spec.rb +3 -2
  532. data/spec/unit/provider/ifconfig/debian_spec.rb +19 -19
  533. data/spec/unit/provider/ifconfig_spec.rb +2 -2
  534. data/spec/unit/provider/mdadm_spec.rb +2 -2
  535. data/spec/unit/provider/mount/aix_spec.rb +5 -5
  536. data/spec/unit/provider/mount/mount_spec.rb +22 -22
  537. data/spec/unit/provider/mount/solaris_spec.rb +20 -20
  538. data/spec/unit/provider/package/aix_spec.rb +23 -22
  539. data/spec/unit/provider/package/apt_spec.rb +23 -4
  540. data/spec/unit/provider/package/dpkg_spec.rb +14 -15
  541. data/spec/unit/provider/package/freebsd/pkgng_spec.rb +1 -1
  542. data/spec/unit/provider/package/freebsd/port_spec.rb +1 -1
  543. data/spec/unit/provider/package/ips_spec.rb +1 -2
  544. data/spec/unit/provider/package/macports_spec.rb +14 -14
  545. data/spec/unit/provider/package/openbsd_spec.rb +66 -0
  546. data/spec/unit/provider/package/pacman_spec.rb +15 -14
  547. data/spec/unit/provider/package/portage_spec.rb +11 -11
  548. data/spec/unit/provider/package/rpm_spec.rb +132 -84
  549. data/spec/unit/provider/package/rubygems_spec.rb +54 -25
  550. data/spec/unit/provider/package/solaris_spec.rb +22 -25
  551. data/spec/unit/provider/package/yum_spec.rb +237 -36
  552. data/spec/unit/provider/package/zypper_spec.rb +9 -12
  553. data/spec/unit/provider/package_spec.rb +276 -2
  554. data/spec/unit/provider/package_spec.rbe +0 -0
  555. data/spec/unit/provider/remote_directory_spec.rb +25 -25
  556. data/spec/unit/provider/remote_file/ftp_spec.rb +3 -3
  557. data/spec/unit/provider/route_spec.rb +3 -3
  558. data/spec/unit/provider/script_spec.rb +61 -43
  559. data/spec/unit/provider/service/aix_service_spec.rb +5 -5
  560. data/spec/unit/provider/service/arch_service_spec.rb +5 -5
  561. data/spec/unit/provider/service/debian_service_spec.rb +8 -8
  562. data/spec/unit/provider/service/freebsd_service_spec.rb +16 -2
  563. data/spec/unit/provider/service/gentoo_service_spec.rb +8 -8
  564. data/spec/unit/provider/service/init_service_spec.rb +5 -5
  565. data/spec/unit/provider/service/insserv_service_spec.rb +2 -2
  566. data/spec/unit/provider/service/invokercd_service_spec.rb +5 -5
  567. data/spec/unit/provider/service/macosx_spec.rb +7 -7
  568. data/spec/unit/provider/service/openbsd_service_spec.rb +543 -0
  569. data/spec/unit/provider/service/redhat_spec.rb +4 -4
  570. data/spec/unit/provider/service/simple_service_spec.rb +2 -2
  571. data/spec/unit/provider/service/solaris_smf_service_spec.rb +14 -14
  572. data/spec/unit/provider/service/systemd_service_spec.rb +15 -7
  573. data/spec/unit/provider/service/upstart_service_spec.rb +4 -4
  574. data/spec/unit/provider/service/windows_spec.rb +119 -25
  575. data/spec/unit/provider/service_spec.rb +1 -1
  576. data/spec/unit/provider/user/dscl_spec.rb +38 -30
  577. data/spec/unit/provider/user_spec.rb +1 -1
  578. data/spec/unit/provider_resolver_spec.rb +7 -7
  579. data/spec/unit/provider_spec.rb +23 -23
  580. data/spec/unit/recipe_spec.rb +194 -83
  581. data/spec/unit/registry_helper_spec.rb +143 -143
  582. data/spec/unit/resource/chef_gem_spec.rb +117 -3
  583. data/spec/unit/resource/conditional_action_not_nothing_spec.rb +2 -2
  584. data/spec/unit/resource/conditional_spec.rb +56 -15
  585. data/spec/unit/resource/deploy_spec.rb +2 -2
  586. data/spec/unit/resource/dsc_script_spec.rb +32 -0
  587. data/spec/unit/resource/execute_spec.rb +4 -0
  588. data/spec/unit/resource/file/verification_spec.rb +111 -0
  589. data/spec/unit/resource/file_spec.rb +14 -0
  590. data/spec/unit/resource/openbsd_package_spec.rb +49 -0
  591. data/spec/unit/resource/remote_file_spec.rb +12 -12
  592. data/spec/unit/resource/resource_notification_spec.rb +18 -18
  593. data/spec/unit/resource/rpm_package_spec.rb +12 -0
  594. data/spec/unit/resource/scm_spec.rb +4 -4
  595. data/spec/unit/resource/script_spec.rb +3 -5
  596. data/spec/unit/resource/subversion_spec.rb +1 -1
  597. data/spec/unit/resource_builder_spec.rb +1 -0
  598. data/spec/unit/resource_collection/resource_list_spec.rb +2 -2
  599. data/spec/unit/resource_collection/resource_set_spec.rb +3 -3
  600. data/spec/unit/resource_collection/stepable_iterator_spec.rb +24 -24
  601. data/spec/unit/resource_collection_spec.rb +52 -52
  602. data/spec/unit/resource_definition_spec.rb +1 -1
  603. data/spec/unit/resource_reporter_spec.rb +118 -118
  604. data/spec/unit/resource_spec.rb +131 -125
  605. data/spec/unit/rest/auth_credentials_spec.rb +73 -73
  606. data/spec/unit/rest_spec.rb +12 -12
  607. data/spec/unit/role_spec.rb +85 -84
  608. data/spec/unit/run_context/cookbook_compiler_spec.rb +18 -18
  609. data/spec/unit/run_context_spec.rb +39 -68
  610. data/spec/unit/run_list/run_list_expansion_spec.rb +21 -21
  611. data/spec/unit/run_list/run_list_item_spec.rb +28 -28
  612. data/spec/unit/run_list/versioned_recipe_list_spec.rb +14 -14
  613. data/spec/unit/run_list_spec.rb +55 -55
  614. data/spec/unit/run_lock_spec.rb +14 -14
  615. data/spec/unit/run_status_spec.rb +24 -24
  616. data/spec/unit/scan_access_control_spec.rb +23 -23
  617. data/spec/unit/search/query_spec.rb +54 -66
  618. data/spec/unit/shell/model_wrapper_spec.rb +13 -13
  619. data/spec/unit/shell/shell_ext_spec.rb +32 -32
  620. data/spec/unit/shell/shell_session_spec.rb +24 -24
  621. data/spec/unit/shell_out_spec.rb +4 -4
  622. data/spec/unit/shell_spec.rb +27 -27
  623. data/spec/unit/user_spec.rb +50 -50
  624. data/spec/unit/util/backup_spec.rb +32 -32
  625. data/spec/unit/util/diff_spec.rb +31 -31
  626. data/spec/unit/util/dsc/configuration_generator_spec.rb +38 -16
  627. data/spec/unit/util/dsc/lcm_output_parser_spec.rb +21 -26
  628. data/spec/unit/util/dsc/local_configuration_manager_spec.rb +10 -10
  629. data/spec/unit/util/editor_spec.rb +10 -10
  630. data/spec/unit/util/file_edit_spec.rb +10 -10
  631. data/spec/unit/util/path_helper_spec.rb +38 -46
  632. data/spec/unit/util/powershell/cmdlet_spec.rb +9 -9
  633. data/spec/unit/util/selinux_spec.rb +30 -30
  634. data/spec/unit/util/threaded_job_queue_spec.rb +6 -6
  635. data/spec/unit/version/platform_spec.rb +5 -5
  636. data/spec/unit/version_class_spec.rb +15 -15
  637. data/spec/unit/version_constraint/platform_spec.rb +7 -7
  638. data/spec/unit/version_constraint_spec.rb +43 -43
  639. data/spec/unit/windows_service_spec.rb +15 -15
  640. data/spec/unit/workstation_config_loader_spec.rb +2 -2
  641. data/tasks/rspec.rb +16 -18
  642. metadata +126 -49
  643. data/bin/shef +0 -35
  644. data/lib/chef/application/agent.rb +0 -18
  645. data/lib/chef/monkey_patches/fileutils.rb +0 -65
  646. data/lib/chef/monkey_patches/numeric.rb +0 -15
  647. data/lib/chef/monkey_patches/object.rb +0 -9
  648. data/lib/chef/monkey_patches/pathname.rb +0 -32
  649. data/lib/chef/monkey_patches/regexp.rb +0 -34
  650. data/lib/chef/monkey_patches/securerandom.rb +0 -44
  651. data/lib/chef/monkey_patches/string.rb +0 -49
  652. data/lib/chef/monkey_patches/tempfile.rb +0 -64
  653. data/lib/chef/monkey_patches/uri.rb +0 -70
@@ -41,9 +41,7 @@ describe Chef::Knife::Exec do
41
41
  @server.stop
42
42
  end
43
43
 
44
- pending "executes a script in the context of the chef-shell main context", :ruby_18_only
45
-
46
- it "executes a script in the context of the chef-shell main context", :ruby_gte_19_only do
44
+ it "executes a script in the context of the chef-shell main context" do
47
45
  @node = Chef::Node.new
48
46
  @node.name("ohai-world")
49
47
  response = {"rows" => [@node],"start" => 0,"total" => 1}
@@ -51,7 +49,7 @@ describe Chef::Knife::Exec do
51
49
  code = "$output.puts nodes.all"
52
50
  @knife.config[:exec] = code
53
51
  @knife.run
54
- $output.string.should match(%r{node\[ohai-world\]})
52
+ expect($output.string).to match(%r{node\[ohai-world\]})
55
53
  end
56
54
 
57
55
  end
@@ -29,6 +29,6 @@ describe "knife smoke tests" do
29
29
  knife_cmd = Mixlib::ShellOut.new("#{knife_path} -v")
30
30
  knife_cmd.run_command
31
31
  knife_cmd.error!
32
- knife_cmd.stdout.should include(Chef::VERSION)
32
+ expect(knife_cmd.stdout).to include(Chef::VERSION)
33
33
  end
34
34
  end
@@ -40,7 +40,7 @@ describe Chef::Knife::Ssh do
40
40
 
41
41
  it "uses the ssh_identity_file" do
42
42
  @knife.run
43
- @knife.config[:identity_file].should == "~/.ssh/aws.rsa"
43
+ expect(@knife.config[:identity_file]).to eq("~/.ssh/aws.rsa")
44
44
  end
45
45
  end
46
46
 
@@ -52,7 +52,7 @@ describe Chef::Knife::Ssh do
52
52
 
53
53
  it "uses the ssh_identity_file" do
54
54
  @knife.run
55
- @knife.config[:identity_file].should == "~/.ssh/aws.rsa"
55
+ expect(@knife.config[:identity_file]).to eq("~/.ssh/aws.rsa")
56
56
  end
57
57
  end
58
58
 
@@ -64,13 +64,13 @@ describe Chef::Knife::Ssh do
64
64
 
65
65
  it "should use the value on the command line" do
66
66
  @knife.run
67
- @knife.config[:identity_file].should == "~/.ssh/aws.rsa"
67
+ expect(@knife.config[:identity_file]).to eq("~/.ssh/aws.rsa")
68
68
  end
69
69
 
70
70
  it "should override what is set in knife.rb" do
71
71
  Chef::Config[:knife][:ssh_identity_file] = "~/.ssh/other.rsa"
72
72
  @knife.run
73
- @knife.config[:identity_file].should == "~/.ssh/aws.rsa"
73
+ expect(@knife.config[:identity_file]).to eq("~/.ssh/aws.rsa")
74
74
  end
75
75
  end
76
76
 
@@ -82,7 +82,7 @@ describe Chef::Knife::Ssh do
82
82
 
83
83
  it "uses the default" do
84
84
  @knife.run
85
- @knife.config[:identity_file].should == nil
85
+ expect(@knife.config[:identity_file]).to eq(nil)
86
86
  end
87
87
  end
88
88
  end
@@ -95,7 +95,7 @@ describe Chef::Knife::Ssh do
95
95
 
96
96
  it "uses the ssh_port" do
97
97
  @knife.run
98
- @knife.config[:ssh_port].should == "31337"
98
+ expect(@knife.config[:ssh_port]).to eq("31337")
99
99
  end
100
100
  end
101
101
  end
@@ -109,7 +109,7 @@ describe Chef::Knife::Ssh do
109
109
 
110
110
  it "uses the ssh_user" do
111
111
  @knife.run
112
- @knife.config[:ssh_user].should == "ubuntu"
112
+ expect(@knife.config[:ssh_user]).to eq("ubuntu")
113
113
  end
114
114
  end
115
115
 
@@ -121,7 +121,7 @@ describe Chef::Knife::Ssh do
121
121
 
122
122
  it "uses the ssh_user" do
123
123
  @knife.run
124
- @knife.config[:ssh_user].should == "ubuntu"
124
+ expect(@knife.config[:ssh_user]).to eq("ubuntu")
125
125
  end
126
126
  end
127
127
 
@@ -133,13 +133,13 @@ describe Chef::Knife::Ssh do
133
133
 
134
134
  it "should use the value on the command line" do
135
135
  @knife.run
136
- @knife.config[:ssh_user].should == "ubuntu"
136
+ expect(@knife.config[:ssh_user]).to eq("ubuntu")
137
137
  end
138
138
 
139
139
  it "should override what is set in knife.rb" do
140
140
  Chef::Config[:knife][:ssh_user] = "root"
141
141
  @knife.run
142
- @knife.config[:ssh_user].should == "ubuntu"
142
+ expect(@knife.config[:ssh_user]).to eq("ubuntu")
143
143
  end
144
144
  end
145
145
 
@@ -151,7 +151,7 @@ describe Chef::Knife::Ssh do
151
151
 
152
152
  it "uses the default (current user)" do
153
153
  @knife.run
154
- @knife.config[:ssh_user].should == nil
154
+ expect(@knife.config[:ssh_user]).to eq(nil)
155
155
  end
156
156
  end
157
157
  end
@@ -165,7 +165,7 @@ describe Chef::Knife::Ssh do
165
165
 
166
166
  it "uses the ssh_attribute" do
167
167
  @knife.run
168
- @knife.config[:attribute].should == "ec2.public_hostname"
168
+ expect(@knife.config[:attribute]).to eq("ec2.public_hostname")
169
169
  end
170
170
  end
171
171
 
@@ -177,7 +177,7 @@ describe Chef::Knife::Ssh do
177
177
 
178
178
  it "uses the default" do
179
179
  @knife.run
180
- @knife.config[:attribute].should == "fqdn"
180
+ expect(@knife.config[:attribute]).to eq("fqdn")
181
181
  end
182
182
  end
183
183
 
@@ -189,7 +189,7 @@ describe Chef::Knife::Ssh do
189
189
 
190
190
  it "should use the value on the command line" do
191
191
  @knife.run
192
- @knife.config[:attribute].should == "ec2.public_hostname"
192
+ expect(@knife.config[:attribute]).to eq("ec2.public_hostname")
193
193
  end
194
194
 
195
195
  it "should override what is set in knife.rb" do
@@ -198,7 +198,7 @@ describe Chef::Knife::Ssh do
198
198
  # Then we run knife with the -a flag, which sets the above variable
199
199
  setup_knife(['-a ec2.public_hostname', '*:*', 'uptime'])
200
200
  @knife.run
201
- @knife.config[:attribute].should == "ec2.public_hostname"
201
+ expect(@knife.config[:attribute]).to eq("ec2.public_hostname")
202
202
  end
203
203
  end
204
204
  end
@@ -211,9 +211,9 @@ describe Chef::Knife::Ssh do
211
211
  end
212
212
 
213
213
  it "uses the ssh_gateway" do
214
- @knife.session.should_receive(:via).with("ec2.public_hostname", "user", {})
214
+ expect(@knife.session).to receive(:via).with("ec2.public_hostname", "user", {})
215
215
  @knife.run
216
- @knife.config[:ssh_gateway].should == "user@ec2.public_hostname"
216
+ expect(@knife.config[:ssh_gateway]).to eq("user@ec2.public_hostname")
217
217
  end
218
218
  end
219
219
 
@@ -224,9 +224,9 @@ describe Chef::Knife::Ssh do
224
224
  end
225
225
 
226
226
  it "uses the ssh_gateway" do
227
- @knife.session.should_receive(:via).with("ec2.public_hostname", "user", {})
227
+ expect(@knife.session).to receive(:via).with("ec2.public_hostname", "user", {})
228
228
  @knife.run
229
- @knife.config[:ssh_gateway].should == "user@ec2.public_hostname"
229
+ expect(@knife.config[:ssh_gateway]).to eq("user@ec2.public_hostname")
230
230
  end
231
231
  end
232
232
 
@@ -234,13 +234,13 @@ describe Chef::Knife::Ssh do
234
234
  before do
235
235
  setup_knife(['-G user@ec2.public_hostname', '*:*', 'uptime'])
236
236
  Chef::Config[:knife][:ssh_gateway] = nil
237
- @knife.session.stub(:via) do |host, user, options|
237
+ allow(@knife.session).to receive(:via) do |host, user, options|
238
238
  raise Net::SSH::AuthenticationFailed unless options[:password]
239
239
  end
240
240
  end
241
241
 
242
242
  it "should prompt the user for a password" do
243
- @knife.ui.should_receive(:ask).with("Enter the password for user@ec2.public_hostname: ").and_return("password")
243
+ expect(@knife.ui).to receive(:ask).with("Enter the password for user@ec2.public_hostname: ").and_return("password")
244
244
  @knife.run
245
245
  end
246
246
  end
@@ -252,7 +252,7 @@ describe Chef::Knife::Ssh do
252
252
  # if available, but #merge_configs (which is called by #configure_chef) is
253
253
  # necessary to have default options merged in.
254
254
  @knife.merge_configs
255
- @knife.stub(:ssh_command).and_return { 0 }
255
+ allow(@knife).to receive(:ssh_command) { 0 }
256
256
  @api = TinyServer::API.instance
257
257
  @api.clear
258
258
 
@@ -260,7 +260,7 @@ describe Chef::Knife::Ssh do
260
260
  Chef::Config[:client_key] = nil
261
261
  Chef::Config[:chef_server_url] = 'http://localhost:9000'
262
262
 
263
- @api.get("/search/node?q=*:*&sort=X_CHEF_id_CHEF_X%20asc&start=0&rows=1000", 200) {
263
+ @api.get("/search/node?q=*:*&sort=X_CHEF_id_CHEF_X%20asc&start=0", 200) {
264
264
  %({"total":1, "start":0, "rows":[{"name":"i-xxxxxxxx", "json_class":"Chef::Node", "automatic":{"fqdn":"the.fqdn", "ec2":{"public_hostname":"the_public_hostname"}},"recipes":[]}]})
265
265
  }
266
266
  end
@@ -64,9 +64,9 @@ describe Chef::Provider::RemoteFile::CacheControlData do
64
64
  it "writes the data to the cache and the same data can be read back" do
65
65
  cache_control_data.save
66
66
  saved_cache_control_data = Chef::Provider::RemoteFile::CacheControlData.load_and_validate(uri, file_checksum)
67
- saved_cache_control_data.etag.should == cache_control_data.etag
68
- saved_cache_control_data.mtime.should == cache_control_data.mtime
69
- saved_cache_control_data.checksum.should == cache_control_data.checksum
67
+ expect(saved_cache_control_data.etag).to eq(cache_control_data.etag)
68
+ expect(saved_cache_control_data.mtime).to eq(cache_control_data.mtime)
69
+ expect(saved_cache_control_data.checksum).to eq(cache_control_data.checksum)
70
70
  end
71
71
 
72
72
  # Cover the very long remote file path case -- see CHEF-4422 where
@@ -81,17 +81,17 @@ describe Chef::Provider::RemoteFile::CacheControlData do
81
81
  let(:uri) { uri_exceeds_file_system_limit }
82
82
 
83
83
  it "writes data to the cache" do
84
- lambda do
84
+ expect do
85
85
  cache_control_data.save
86
- end.should_not raise_error
86
+ end.not_to raise_error
87
87
  end
88
88
 
89
89
  it "writes the data to the cache and the same data can be read back" do
90
90
  cache_control_data.save
91
91
  saved_cache_control_data = Chef::Provider::RemoteFile::CacheControlData.load_and_validate(uri, file_checksum)
92
- saved_cache_control_data.etag.should == cache_control_data.etag
93
- saved_cache_control_data.mtime.should == cache_control_data.mtime
94
- saved_cache_control_data.checksum.should == cache_control_data.checksum
92
+ expect(saved_cache_control_data.etag).to eq(cache_control_data.etag)
93
+ expect(saved_cache_control_data.mtime).to eq(cache_control_data.mtime)
94
+ expect(saved_cache_control_data.checksum).to eq(cache_control_data.checksum)
95
95
  end
96
96
 
97
97
  end
@@ -44,8 +44,8 @@ describe Chef::Resource::WhyrunSafeRubyBlock do
44
44
 
45
45
  it "updates the evil laugh, even in why-run mode" do
46
46
  new_resource.run_action(new_resource.action)
47
- $evil_global_evil_laugh.should == :mwahahaha
48
- new_resource.should be_updated
47
+ expect($evil_global_evil_laugh).to eq(:mwahahaha)
48
+ expect(new_resource).to be_updated
49
49
  end
50
50
  end
51
51
  end
@@ -70,7 +70,7 @@ describe Chef::Platform::Rebooter do
70
70
 
71
71
  shared_context 'test a reboot method' do
72
72
  def test_rebooter_method(method_sym, is_windows, expected_reboot_str)
73
- Chef::Platform.stub(:windows?).and_return(is_windows)
73
+ allow(Chef::Platform).to receive(:windows?).and_return(is_windows)
74
74
  expect(rebooter).to receive(:shell_out!).once.with(expected_reboot_str)
75
75
  expect(rebooter).to receive(method_sym).once.and_call_original
76
76
  rebooter.send(method_sym, run_context.node)
@@ -73,6 +73,9 @@ shared_examples "src service" do
73
73
  end
74
74
 
75
75
  describe Chef::Resource::Service, :requires_root, :aix_only do
76
+
77
+ include Chef::Mixin::ShellOut
78
+
76
79
  def get_user_id
77
80
  shell_out("id -u #{ENV['USER']}").stdout.chomp
78
81
  end
@@ -28,12 +28,12 @@ describe Chef::Resource::Service, :requires_root, :aix_only do
28
28
 
29
29
  # Platform specific validation routines.
30
30
  def service_should_be_started(file_name)
31
- # The existance of this file indicates that the service was started.
32
- expect(File.exists?("/tmp/#{file_name}")).to be_true
31
+ # The existence of this file indicates that the service was started.
32
+ expect(File.exists?("/tmp/#{file_name}")).to be_truthy
33
33
  end
34
34
 
35
35
  def service_should_be_stopped(file_name)
36
- expect(File.exists?("/tmp/#{file_name}")).to be_false
36
+ expect(File.exists?("/tmp/#{file_name}")).to be_falsey
37
37
  end
38
38
 
39
39
  def valide_symlinks(expected_output, run_level = nil, status = nil, priority = nil)
@@ -0,0 +1,88 @@
1
+ #
2
+ # Author:: Serdar Sutay (<serdar@opscode.com>)
3
+ # Copyright:: Copyright (c) 2014 Opscode, 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 'functional/resource/base'
21
+
22
+ describe Chef::Resource::Bash, :unix_only do
23
+ let(:code) { "echo hello" }
24
+ let(:resource) {
25
+ resource = Chef::Resource::Bash.new("foo_resource", run_context)
26
+ resource.code(code)
27
+ resource
28
+ }
29
+
30
+ describe "when setting the command attribute" do
31
+ let (:command) { 'wizard racket' }
32
+
33
+ # in Chef-12 the `command` attribute is largely useless, but does set the identity attribute
34
+ # so that notifications need to target the value of the command. it will not run the `command`
35
+ # and if it is given without a code block then it does nothing and always succeeds.
36
+ describe "in Chef-12", :chef_lt_13_only do
37
+ it "gets the commmand attribute from the name" do
38
+ expect(resource.command).to eql("foo_resource")
39
+ end
40
+
41
+ it "sets the resource identity to the command name" do
42
+ resource.command command
43
+ expect(resource.identity).to eql(command)
44
+ end
45
+
46
+ it "warns when the code is not present and a useless `command` is present" do
47
+ expect(Chef::Log).to receive(:warn).with(/coding error/)
48
+ expect(Chef::Log).to receive(:warn).with(/deprecated/)
49
+ resource.code nil
50
+ resource.command command
51
+ expect { resource.run_action(:run) }.not_to raise_error
52
+ end
53
+
54
+ describe "when the code is not present" do
55
+ let(:code) { nil }
56
+ it "warns" do
57
+ expect(Chef::Log).to receive(:warn)
58
+ expect { resource.run_action(:run) }.not_to raise_error
59
+ end
60
+ end
61
+ end
62
+
63
+ # in Chef-13 the `command` attribute needs to be for internal use only
64
+ describe "in Chef-13", :chef_gte_13_only do
65
+ it "should raise an exception when trying to set the command" do
66
+ expect { resource.command command }.to raise_error # FIXME: add a real error in Chef-13
67
+ end
68
+
69
+ it "should initialize the command to nil" do
70
+ expect(resource.command).to be_nil
71
+ end
72
+
73
+ describe "when the code is not present" do
74
+ let(:code) { nil }
75
+ it "raises an exception" do
76
+ expect { resource.run_action(:run) }.to raise_error # FIXME: add a real error in Chef-13
77
+ expect { resource.run_action(:run) }.not_to raise_error
78
+ end
79
+ end
80
+ end
81
+ end
82
+
83
+ it "times out when a timeout is set on the resource" do
84
+ resource.code 'sleep 600'
85
+ resource.timeout 0.1
86
+ expect { resource.run_action(:run) }.to raise_error(Mixlib::ShellOut::CommandTimeout)
87
+ end
88
+ end
@@ -45,11 +45,10 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
45
45
 
46
46
  before(:all) do
47
47
  @ohai = Ohai::System.new
48
- @ohai.all_plugins("os")
48
+ @ohai.all_plugins(["platform", "os"])
49
49
  end
50
50
 
51
51
  let(:node) do
52
-
53
52
  Chef::Node.new.tap do |n|
54
53
  n.name "rspec-test"
55
54
  n.consume_external_attrs(@ohai.data, {})
@@ -173,12 +172,12 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
173
172
  it "deploys the app to the target revision (#{target_rev_spec})" do
174
173
  target_rev = send(target_rev_spec)
175
174
 
176
- File.should exist(rel_path("current"))
175
+ expect(File).to exist(rel_path("current"))
177
176
 
178
- actual_current_rev.should == target_rev
177
+ expect(actual_current_rev).to eq(target_rev)
179
178
 
180
179
  # Is the app code actually there?
181
- File.should exist(rel_path("current/app/app.rb"))
180
+ expect(File).to exist(rel_path("current/app/app.rb"))
182
181
  end
183
182
  end
184
183
 
@@ -193,12 +192,12 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
193
192
  the_app_is_deployed_at_revision(:latest_rev)
194
193
 
195
194
  it "restarts the application" do
196
- File.should exist(rel_path("current/restart.txt"))
197
- actual_operations_order.should == %w[deploy_to_latest_rev]
195
+ expect(File).to exist(rel_path("current/restart.txt"))
196
+ expect(actual_operations_order).to eq(%w[deploy_to_latest_rev])
198
197
  end
199
198
 
200
199
  it "is marked as updated" do
201
- deploy_to_latest_rev.should be_updated_by_last_action
200
+ expect(deploy_to_latest_rev).to be_updated_by_last_action
202
201
  end
203
202
  end
204
203
 
@@ -215,15 +214,15 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
215
214
  the_app_is_deployed_at_revision(:latest_rev)
216
215
 
217
216
  it "restarts the application after rolling back" do
218
- actual_operations_order.should == %w[deploy_to_latest_rev deploy_to_previous_rev deploy_to_latest_rev_again]
217
+ expect(actual_operations_order).to eq(%w[deploy_to_latest_rev deploy_to_previous_rev deploy_to_latest_rev_again])
219
218
  end
220
219
 
221
220
  it "is marked updated" do
222
- deploy_to_latest_rev_again.should be_updated_by_last_action
221
+ expect(deploy_to_latest_rev_again).to be_updated_by_last_action
223
222
  end
224
223
 
225
224
  it "deploys the right code" do
226
- IO.read(rel_path("current/app/app.rb")).should include("this is the fourth version of the app")
225
+ expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the fourth version of the app")
227
226
  end
228
227
  end
229
228
 
@@ -233,27 +232,27 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
233
232
  end
234
233
 
235
234
  it "creates the required directory tree" do
236
- File.should be_directory(rel_path("releases"))
237
- File.should be_directory(rel_path("shared"))
238
- File.should be_directory(rel_path("releases/#{latest_rev}"))
235
+ expect(File).to be_directory(rel_path("releases"))
236
+ expect(File).to be_directory(rel_path("shared"))
237
+ expect(File).to be_directory(rel_path("releases/#{latest_rev}"))
239
238
 
240
- File.should be_directory(rel_path("current/tmp"))
241
- File.should be_directory(rel_path("current/config"))
242
- File.should be_directory(rel_path("current/public"))
239
+ expect(File).to be_directory(rel_path("current/tmp"))
240
+ expect(File).to be_directory(rel_path("current/config"))
241
+ expect(File).to be_directory(rel_path("current/public"))
243
242
 
244
- File.should be_symlink(rel_path("current"))
245
- File.readlink(rel_path("current")).should == rel_path("releases/#{latest_rev}")
243
+ expect(File).to be_symlink(rel_path("current"))
244
+ expect(File.readlink(rel_path("current"))).to eq(rel_path("releases/#{latest_rev}"))
246
245
  end
247
246
 
248
247
  the_app_is_deployed_at_revision(:latest_rev)
249
248
 
250
249
  it "restarts the application" do
251
- File.should exist(rel_path("current/restart.txt"))
252
- actual_operations_order.should == %w[deploy_to_latest_rev]
250
+ expect(File).to exist(rel_path("current/restart.txt"))
251
+ expect(actual_operations_order).to eq(%w[deploy_to_latest_rev])
253
252
  end
254
253
 
255
254
  it "is marked as updated" do
256
- deploy_to_latest_rev.should be_updated_by_last_action
255
+ expect(deploy_to_latest_rev).to be_updated_by_last_action
257
256
  end
258
257
  end
259
258
 
@@ -266,11 +265,11 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
266
265
  the_app_is_deployed_at_revision(:latest_rev)
267
266
 
268
267
  it "does not restart the app" do
269
- actual_operations_order.should == %w[deploy_to_latest_rev]
268
+ expect(actual_operations_order).to eq(%w[deploy_to_latest_rev])
270
269
  end
271
270
 
272
271
  it "is not marked updated" do
273
- deploy_to_latest_rev.should_not be_updated_by_last_action
272
+ expect(deploy_to_latest_rev).not_to be_updated_by_last_action
274
273
  end
275
274
 
276
275
  end
@@ -284,11 +283,11 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
284
283
  the_app_is_deployed_at_revision(:latest_rev)
285
284
 
286
285
  it "restarts the app" do
287
- actual_operations_order.should == %w[deploy_to_latest_rev deploy_to_latest_rev_again]
286
+ expect(actual_operations_order).to eq(%w[deploy_to_latest_rev deploy_to_latest_rev_again])
288
287
  end
289
288
 
290
289
  it "is marked updated" do
291
- deploy_to_latest_rev.should be_updated_by_last_action
290
+ expect(deploy_to_latest_rev).to be_updated_by_last_action
292
291
  end
293
292
 
294
293
  end
@@ -302,15 +301,15 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
302
301
  the_app_is_deployed_at_revision(:latest_rev)
303
302
 
304
303
  it "restarts the application after the new deploy" do
305
- actual_operations_order.should == %w[deploy_to_previous_rev deploy_to_latest_rev]
304
+ expect(actual_operations_order).to eq(%w[deploy_to_previous_rev deploy_to_latest_rev])
306
305
  end
307
306
 
308
307
  it "is marked updated" do
309
- deploy_to_previous_rev.should be_updated_by_last_action
308
+ expect(deploy_to_previous_rev).to be_updated_by_last_action
310
309
  end
311
310
 
312
311
  it "leaves the old copy of the app around for rollback" do
313
- File.should exist(File.join(deploy_directory, "releases", previous_rev))
312
+ expect(File).to exist(File.join(deploy_directory, "releases", previous_rev))
314
313
  end
315
314
 
316
315
  end
@@ -325,15 +324,15 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
325
324
  the_app_is_deployed_at_revision(:latest_rev)
326
325
 
327
326
  it "restarts the application after rolling back" do
328
- actual_operations_order.should == %w[deploy_to_latest_rev deploy_to_previous_rev deploy_to_latest_rev_again]
327
+ expect(actual_operations_order).to eq(%w[deploy_to_latest_rev deploy_to_previous_rev deploy_to_latest_rev_again])
329
328
  end
330
329
 
331
330
  it "is marked updated" do
332
- deploy_to_latest_rev_again.should be_updated_by_last_action
331
+ expect(deploy_to_latest_rev_again).to be_updated_by_last_action
333
332
  end
334
333
 
335
334
  it "deploys the right code" do
336
- IO.read(rel_path("current/app/app.rb")).should include("this is the fourth version of the app")
335
+ expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the fourth version of the app")
337
336
  end
338
337
  end
339
338
 
@@ -350,31 +349,31 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
350
349
  the_app_is_deployed_at_revision(:previous_rev)
351
350
 
352
351
  it "restarts the application after rolling back" do
353
- actual_operations_order.should == %w[deploy_to_previous_rev deploy_to_latest_rev deploy_to_latest_rev_again]
352
+ expect(actual_operations_order).to eq(%w[deploy_to_previous_rev deploy_to_latest_rev deploy_to_latest_rev_again])
354
353
  end
355
354
 
356
355
  it "is marked updated" do
357
- deploy_to_latest_rev_again.should be_updated_by_last_action
356
+ expect(deploy_to_latest_rev_again).to be_updated_by_last_action
358
357
  end
359
358
 
360
359
  it "deploys the right code" do
361
- IO.read(rel_path("current/app/app.rb")).should include("this is the third version of the app")
360
+ expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the third version of the app")
362
361
  end
363
362
 
364
363
  it "all_releases after first deploy should have one entry" do
365
- @previous_rev_all_releases.length.should == 1
364
+ expect(@previous_rev_all_releases.length).to eq(1)
366
365
  end
367
366
 
368
367
  it "all_releases after second deploy should have two entries" do
369
- @latest_rev_all_releases.length.should == 2
368
+ expect(@latest_rev_all_releases.length).to eq(2)
370
369
  end
371
370
 
372
371
  it "all_releases after rollback should have one entry" do
373
- @previous_rev_again_all_releases.length.should == 1
372
+ expect(@previous_rev_again_all_releases.length).to eq(1)
374
373
  end
375
374
 
376
375
  it "all_releases after rollback should be the same as after the first deploy" do
377
- @previous_rev_again_all_releases.should == @previous_rev_all_releases
376
+ expect(@previous_rev_again_all_releases).to eq(@previous_rev_all_releases)
378
377
  end
379
378
 
380
379
  end
@@ -393,31 +392,31 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
393
392
  the_app_is_deployed_at_revision(:previous_rev)
394
393
 
395
394
  it "restarts the application after rolling back" do
396
- actual_operations_order.should == %w[deploy_to_previous_rev deploy_to_latest_rev deploy_to_previous_rev_again]
395
+ expect(actual_operations_order).to eq(%w[deploy_to_previous_rev deploy_to_latest_rev deploy_to_previous_rev_again])
397
396
  end
398
397
 
399
398
  it "is marked updated" do
400
- deploy_to_previous_rev_again.should be_updated_by_last_action
399
+ expect(deploy_to_previous_rev_again).to be_updated_by_last_action
401
400
  end
402
401
 
403
402
  it "deploys the right code" do
404
- IO.read(rel_path("current/app/app.rb")).should include("this is the third version of the app")
403
+ expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the third version of the app")
405
404
  end
406
405
 
407
406
  it "all_releases after first deploy should have one entry" do
408
- @previous_rev_all_releases.length.should == 1
407
+ expect(@previous_rev_all_releases.length).to eq(1)
409
408
  end
410
409
 
411
410
  it "all_releases after second deploy should have two entries" do
412
- @latest_rev_all_releases.length.should == 2
411
+ expect(@latest_rev_all_releases.length).to eq(2)
413
412
  end
414
413
 
415
414
  it "all_releases after rollback should have one entry" do
416
- @previous_rev_again_all_releases.length.should == 1
415
+ expect(@previous_rev_again_all_releases.length).to eq(1)
417
416
  end
418
417
 
419
418
  it "all_releases after rollback should be the same as after the first deploy" do
420
- @previous_rev_again_all_releases.should == @previous_rev_all_releases
419
+ expect(@previous_rev_again_all_releases).to eq(@previous_rev_all_releases)
421
420
  end
422
421
  end
423
422
 
@@ -438,23 +437,23 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
438
437
  the_app_is_deployed_at_revision(:second_rev)
439
438
 
440
439
  it "restarts the application after rolling back" do
441
- actual_operations_order.should == %w[deploy_to_second_rev deploy_to_previous_rev deploy_to_previous_rev_again deploy_to_latest_rev deploy_to_latest_rev_again]
440
+ expect(actual_operations_order).to eq(%w[deploy_to_second_rev deploy_to_previous_rev deploy_to_previous_rev_again deploy_to_latest_rev deploy_to_latest_rev_again])
442
441
  end
443
442
 
444
443
  it "is marked updated" do
445
- deploy_to_latest_rev_again.should be_updated_by_last_action
444
+ expect(deploy_to_latest_rev_again).to be_updated_by_last_action
446
445
  end
447
446
 
448
447
  it "deploys the right code" do
449
- IO.read(rel_path("current/app/app.rb")).should include("this is the second version of the app")
448
+ expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the second version of the app")
450
449
  end
451
450
 
452
451
  it "all_releases after rollback should have one entry" do
453
- @fifth_deploy_all_releases.length.should == 1
452
+ expect(@fifth_deploy_all_releases.length).to eq(1)
454
453
  end
455
454
 
456
455
  it "all_releases after rollback should be the same as after the first deploy" do
457
- @fifth_deploy_all_releases.should == @first_deploy_all_releases
456
+ expect(@fifth_deploy_all_releases).to eq(@first_deploy_all_releases)
458
457
  end
459
458
  end
460
459
 
@@ -475,23 +474,23 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
475
474
  the_app_is_deployed_at_revision(:second_rev)
476
475
 
477
476
  it "restarts the application after rolling back" do
478
- actual_operations_order.should == %w[deploy_to_second_rev deploy_to_previous_rev deploy_to_second_rev_again deploy_to_latest_rev deploy_to_second_rev_again_again]
477
+ expect(actual_operations_order).to eq(%w[deploy_to_second_rev deploy_to_previous_rev deploy_to_second_rev_again deploy_to_latest_rev deploy_to_second_rev_again_again])
479
478
  end
480
479
 
481
480
  it "is marked updated" do
482
- deploy_to_second_rev_again_again.should be_updated_by_last_action
481
+ expect(deploy_to_second_rev_again_again).to be_updated_by_last_action
483
482
  end
484
483
 
485
484
  it "deploys the right code" do
486
- IO.read(rel_path("current/app/app.rb")).should include("this is the second version of the app")
485
+ expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the second version of the app")
487
486
  end
488
487
 
489
488
  it "all_releases after rollback should have one entry" do
490
- @fifth_deploy_all_releases.length.should == 1
489
+ expect(@fifth_deploy_all_releases.length).to eq(1)
491
490
  end
492
491
 
493
492
  it "all_releases after rollback should be the same as after the first deploy" do
494
- @fifth_deploy_all_releases.should == @first_deploy_all_releases
493
+ expect(@fifth_deploy_all_releases).to eq(@first_deploy_all_releases)
495
494
  end
496
495
 
497
496
  end
@@ -510,21 +509,21 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
510
509
  end
511
510
 
512
511
  before do
513
- File.should_not exist(deploy_directory)
512
+ expect(File).not_to exist(deploy_directory)
514
513
  deploy_to_latest_rev.run_action(:deploy)
515
514
  end
516
515
 
517
516
  it "creates the required directory tree" do
518
- File.should be_directory(rel_path("releases"))
519
- File.should be_directory(rel_path("shared"))
520
- File.should be_directory(rel_path("releases/#{latest_rev}"))
517
+ expect(File).to be_directory(rel_path("releases"))
518
+ expect(File).to be_directory(rel_path("shared"))
519
+ expect(File).to be_directory(rel_path("releases/#{latest_rev}"))
521
520
 
522
- File.should be_directory(rel_path("current/tmp"))
523
- File.should be_directory(rel_path("current/config"))
524
- File.should be_directory(rel_path("current/public"))
521
+ expect(File).to be_directory(rel_path("current/tmp"))
522
+ expect(File).to be_directory(rel_path("current/config"))
523
+ expect(File).to be_directory(rel_path("current/public"))
525
524
 
526
- File.should be_symlink(rel_path("current"))
527
- File.readlink(rel_path("current")).should == rel_path("releases/#{latest_rev}")
525
+ expect(File).to be_symlink(rel_path("current"))
526
+ expect(File.readlink(rel_path("current"))).to eq(rel_path("releases/#{latest_rev}"))
528
527
  end
529
528
 
530
529
  the_app_is_deployed_at_revision(:latest_rev)
@@ -599,18 +598,18 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
599
598
  the_app_is_deployed_at_revision(:latest_rev)
600
599
 
601
600
  it "is marked updated" do
602
- deploy_to_latest_with_inline_recipes.should be_updated_by_last_action
601
+ expect(deploy_to_latest_with_inline_recipes).to be_updated_by_last_action
603
602
  end
604
603
 
605
604
  it "calls the callbacks in order" do
606
- callback_order.should == [:before_migrate, :before_symlink, :before_restart, :after_restart]
605
+ expect(callback_order).to eq([:before_migrate, :before_symlink, :before_restart, :after_restart])
607
606
  end
608
607
 
609
608
  it "runs chef resources in the callbacks" do
610
- File.should exist(rel_path("current/before_migrate.txt"))
611
- File.should exist(rel_path("current/before_symlink.txt"))
612
- File.should exist(rel_path("current/tmp/before_restart.txt"))
613
- File.should exist(rel_path("current/tmp/after_restart.txt"))
609
+ expect(File).to exist(rel_path("current/before_migrate.txt"))
610
+ expect(File).to exist(rel_path("current/before_symlink.txt"))
611
+ expect(File).to exist(rel_path("current/tmp/before_restart.txt"))
612
+ expect(File).to exist(rel_path("current/tmp/after_restart.txt"))
614
613
  end
615
614
  end
616
615
 
@@ -629,10 +628,10 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
629
628
  the_app_is_deployed_at_revision(:rev_with_in_repo_callbacks)
630
629
 
631
630
  it "runs chef resources in the callbacks" do
632
- File.should exist(rel_path("current/before_migrate.txt"))
633
- File.should exist(rel_path("current/before_symlink.txt"))
634
- File.should exist(rel_path("current/tmp/before_restart.txt"))
635
- File.should exist(rel_path("current/tmp/after_restart.txt"))
631
+ expect(File).to exist(rel_path("current/before_migrate.txt"))
632
+ expect(File).to exist(rel_path("current/before_symlink.txt"))
633
+ expect(File).to exist(rel_path("current/tmp/before_restart.txt"))
634
+ expect(File).to exist(rel_path("current/tmp/after_restart.txt"))
636
635
  end
637
636
 
638
637
  end
@@ -690,7 +689,7 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
690
689
  end
691
690
 
692
691
  it "runs migrations in between the before_migrate and before_symlink steps" do
693
- actual_operations_order.should == %w[before_migrate migration before_symlink before_restart after_restart]
692
+ expect(actual_operations_order).to eq(%w[before_migrate migration before_symlink before_restart after_restart])
694
693
  end
695
694
  end
696
695
 
@@ -703,7 +702,7 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
703
702
  end
704
703
 
705
704
  it "should not raise an exception calling File.utime on symlinks" do
706
- lambda { deploy_with_in_repo_symlinks.run_action(:deploy) }.should_not raise_error
705
+ expect { deploy_with_in_repo_symlinks.run_action(:deploy) }.not_to raise_error
707
706
  end
708
707
  end
709
708
 
@@ -712,16 +711,16 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
712
711
  shared_examples_for "a redeployed application" do
713
712
 
714
713
  it "should redeploy the application" do
715
- File.should be_directory(rel_path("releases"))
716
- File.should be_directory(rel_path("shared"))
717
- File.should be_directory(rel_path("releases/#{latest_rev}"))
714
+ expect(File).to be_directory(rel_path("releases"))
715
+ expect(File).to be_directory(rel_path("shared"))
716
+ expect(File).to be_directory(rel_path("releases/#{latest_rev}"))
718
717
 
719
- File.should be_directory(rel_path("current/tmp"))
720
- File.should be_directory(rel_path("current/config"))
721
- File.should be_directory(rel_path("current/public"))
718
+ expect(File).to be_directory(rel_path("current/tmp"))
719
+ expect(File).to be_directory(rel_path("current/config"))
720
+ expect(File).to be_directory(rel_path("current/public"))
722
721
 
723
- File.should be_symlink(rel_path("current"))
724
- File.readlink(rel_path("current")).should == rel_path("releases/#{latest_rev}")
722
+ expect(File).to be_symlink(rel_path("current"))
723
+ expect(File.readlink(rel_path("current"))).to eq(rel_path("releases/#{latest_rev}"))
725
724
  end
726
725
  end
727
726
 
@@ -758,23 +757,23 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
758
757
  shared_examples_for "a recovered deployment" do
759
758
 
760
759
  it "should redeploy the application" do
761
- File.should be_directory(rel_path("releases"))
762
- File.should be_directory(rel_path("shared"))
763
- File.should be_directory(rel_path("releases/#{latest_rev}"))
760
+ expect(File).to be_directory(rel_path("releases"))
761
+ expect(File).to be_directory(rel_path("shared"))
762
+ expect(File).to be_directory(rel_path("releases/#{latest_rev}"))
764
763
 
765
- File.should be_directory(rel_path("current/tmp"))
766
- File.should be_directory(rel_path("current/config"))
767
- File.should be_directory(rel_path("current/public"))
764
+ expect(File).to be_directory(rel_path("current/tmp"))
765
+ expect(File).to be_directory(rel_path("current/config"))
766
+ expect(File).to be_directory(rel_path("current/public"))
768
767
 
769
- File.should be_symlink(rel_path("current"))
770
- File.readlink(rel_path("current")).should == rel_path("releases/#{latest_rev}")
768
+ expect(File).to be_symlink(rel_path("current"))
769
+ expect(File.readlink(rel_path("current"))).to eq(rel_path("releases/#{latest_rev}"))
771
770
 
772
771
  # if callbacks ran, we know the app was deployed and not merely rolled
773
772
  # back to a (busted) prior deployment.
774
- callback_order.should == [:before_migrate,
773
+ expect(callback_order).to eq([:before_migrate,
775
774
  :before_symlink,
776
775
  :before_restart,
777
- :after_restart ]
776
+ :after_restart ])
778
777
  end
779
778
  end
780
779
 
@@ -794,7 +793,7 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
794
793
 
795
794
  context "in the `#{callback}' callback" do
796
795
  before do
797
- lambda { deploy_that_fails.run_action(:deploy) }.should raise_error(Exception, %r{I am a failed deploy})
796
+ expect { deploy_that_fails.run_action(:deploy) }.to raise_error(Exception, %r{I am a failed deploy})
798
797
  deploy_to_latest_with_callback_tracking.run_action(:deploy)
799
798
  end
800
799
 
@@ -820,7 +819,7 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
820
819
  end
821
820
 
822
821
  before do
823
- lambda { deploy_that_fails.run_action(:deploy) }.should raise_error(Chef::Exceptions::Exec)
822
+ expect { deploy_that_fails.run_action(:deploy) }.to raise_error(Chef::Exceptions::Exec)
824
823
  deploy_to_latest_with_callback_tracking.run_action(:deploy)
825
824
  end
826
825
 
@@ -852,7 +851,7 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
852
851
  end
853
852
 
854
853
  before do
855
- lambda { deploy_that_fails.run_action(:deploy) }.should raise_error(RuntimeError, /network error/)
854
+ expect { deploy_that_fails.run_action(:deploy) }.to raise_error(RuntimeError, /network error/)
856
855
  deploy_to_latest_with_callback_tracking.run_action(:deploy)
857
856
  end
858
857
 
@@ -868,12 +867,12 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
868
867
  end
869
868
 
870
869
  before do
871
- lambda { deploy_that_fails.run_action(:deploy) }.should raise_error(Exception, %r{I am a failed deploy})
870
+ expect { deploy_that_fails.run_action(:deploy) }.to raise_error(Exception, %r{I am a failed deploy})
872
871
  deploy_to_latest_rev.run_action(:deploy)
873
872
  end
874
873
 
875
874
  it "removes the unsuccessful deploy after a later successful deploy" do
876
- ::File.should_not exist(File.join(deploy_directory, "releases", previous_rev))
875
+ expect(::File).not_to exist(File.join(deploy_directory, "releases", previous_rev))
877
876
  end
878
877
 
879
878
  end