chef 16.2.73-universal-mingw32 → 16.4.41-universal-mingw32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (316) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +4 -4
  3. data/Rakefile +1 -1
  4. data/chef-universal-mingw32.gemspec +2 -3
  5. data/chef.gemspec +2 -1
  6. data/lib/chef/action_collection.rb +4 -0
  7. data/lib/chef/api_client/registration.rb +2 -2
  8. data/lib/chef/application.rb +13 -1
  9. data/lib/chef/application/apply.rb +5 -5
  10. data/lib/chef/application/windows_service.rb +27 -27
  11. data/lib/chef/{whitelist.rb → attribute_allowlist.rb} +11 -11
  12. data/lib/chef/{blacklist.rb → attribute_blocklist.rb} +9 -9
  13. data/lib/chef/chef_class.rb +0 -1
  14. data/lib/chef/chef_fs/chef_fs_data_store.rb +54 -54
  15. data/lib/chef/chef_fs/data_handler/organization_data_handler.rb +1 -2
  16. data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +10 -10
  17. data/lib/chef/chef_fs/file_system/chef_server/cookbooks_dir.rb +1 -5
  18. data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +8 -8
  19. data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +8 -8
  20. data/lib/chef/chef_fs/file_system/repository/base_file.rb +1 -0
  21. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +2 -2
  22. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +1 -1
  23. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +18 -18
  24. data/lib/chef/chef_fs/file_system/repository/directory.rb +1 -1
  25. data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +1 -1
  26. data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +1 -1
  27. data/lib/chef/client.rb +14 -14
  28. data/lib/chef/cookbook/remote_file_vendor.rb +1 -3
  29. data/lib/chef/cookbook/syntax_check.rb +1 -2
  30. data/lib/chef/cookbook_loader.rb +15 -29
  31. data/lib/chef/data_bag.rb +1 -2
  32. data/lib/chef/data_collector/run_end_message.rb +11 -1
  33. data/lib/chef/deprecated.rb +8 -0
  34. data/lib/chef/dsl/platform_introspection.rb +9 -7
  35. data/lib/chef/encrypted_data_bag_item/decryptor.rb +1 -1
  36. data/lib/chef/environment.rb +3 -4
  37. data/lib/chef/exceptions.rb +4 -1
  38. data/lib/chef/file_content_management/tempfile.rb +9 -9
  39. data/lib/chef/handler.rb +2 -0
  40. data/lib/chef/http.rb +11 -11
  41. data/lib/chef/http/authenticator.rb +3 -1
  42. data/lib/chef/json_compat.rb +1 -1
  43. data/lib/chef/knife.rb +4 -4
  44. data/lib/chef/knife/bootstrap.rb +6 -12
  45. data/lib/chef/knife/bootstrap/train_connector.rb +1 -0
  46. data/lib/chef/knife/config_get.rb +1 -0
  47. data/lib/chef/knife/config_list_profiles.rb +4 -1
  48. data/lib/chef/knife/configure.rb +3 -1
  49. data/lib/chef/knife/cookbook_download.rb +1 -1
  50. data/lib/chef/knife/cookbook_metadata.rb +1 -1
  51. data/lib/chef/knife/cookbook_upload.rb +28 -33
  52. data/lib/chef/knife/core/gem_glob_loader.rb +1 -1
  53. data/lib/chef/knife/core/generic_presenter.rb +1 -1
  54. data/lib/chef/knife/core/hashed_command_loader.rb +3 -2
  55. data/lib/chef/knife/core/subcommand_loader.rb +20 -1
  56. data/lib/chef/knife/core/ui.rb +8 -2
  57. data/lib/chef/knife/core/windows_bootstrap_context.rb +32 -25
  58. data/lib/chef/knife/delete.rb +15 -15
  59. data/lib/chef/knife/exec.rb +2 -2
  60. data/lib/chef/knife/rehash.rb +3 -21
  61. data/lib/chef/knife/ssh.rb +11 -7
  62. data/lib/chef/knife/xargs.rb +19 -19
  63. data/lib/chef/knife/yaml_convert.rb +1 -1
  64. data/lib/chef/log.rb +7 -2
  65. data/lib/chef/mixin/checksum.rb +0 -1
  66. data/lib/chef/mixin/chef_utils_wiring.rb +40 -0
  67. data/lib/chef/mixin/deep_merge.rb +35 -6
  68. data/{spec/unit/log_spec.rb → lib/chef/mixin/default_paths.rb} +13 -5
  69. data/lib/chef/mixin/openssl_helper.rb +30 -6
  70. data/lib/chef/mixin/path_sanity.rb +5 -4
  71. data/lib/chef/mixin/shell_out.rb +4 -188
  72. data/lib/chef/mixin/template.rb +1 -0
  73. data/lib/chef/mixin/which.rb +6 -3
  74. data/lib/chef/mixins.rb +1 -0
  75. data/lib/chef/monkey_patches/webrick-utils.rb +10 -10
  76. data/lib/chef/node.rb +36 -12
  77. data/lib/chef/node/attribute.rb +2 -4
  78. data/lib/chef/node_map.rb +21 -18
  79. data/lib/chef/platform/service_helpers.rb +31 -28
  80. data/lib/chef/property.rb +1 -1
  81. data/lib/chef/provider/cron/unix.rb +0 -2
  82. data/lib/chef/provider/git.rb +17 -9
  83. data/lib/chef/provider/group.rb +0 -2
  84. data/lib/chef/provider/group/suse.rb +5 -5
  85. data/lib/chef/provider/ifconfig.rb +1 -4
  86. data/lib/chef/provider/mount.rb +0 -2
  87. data/lib/chef/provider/mount/solaris.rb +0 -1
  88. data/lib/chef/provider/package.rb +0 -2
  89. data/lib/chef/provider/package/rubygems.rb +1 -1
  90. data/lib/chef/provider/package/snap.rb +3 -4
  91. data/lib/chef/provider/package/windows.rb +9 -4
  92. data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +9 -9
  93. data/lib/chef/provider/package/zypper.rb +0 -1
  94. data/lib/chef/provider/powershell_script.rb +21 -5
  95. data/lib/chef/provider/route.rb +1 -1
  96. data/lib/chef/provider/service.rb +2 -2
  97. data/lib/chef/provider/service/arch.rb +1 -1
  98. data/lib/chef/provider/service/debian.rb +1 -1
  99. data/lib/chef/provider/service/gentoo.rb +2 -2
  100. data/lib/chef/provider/service/macosx.rb +2 -2
  101. data/lib/chef/provider/service/openbsd.rb +1 -4
  102. data/lib/chef/provider/service/redhat.rb +2 -2
  103. data/lib/chef/provider/service/upstart.rb +1 -1
  104. data/lib/chef/provider/service/windows.rb +10 -10
  105. data/lib/chef/provider/systemd_unit.rb +0 -2
  106. data/lib/chef/provider/template/content.rb +1 -0
  107. data/lib/chef/provider/user/dscl.rb +2 -2
  108. data/lib/chef/provider/user/mac.rb +9 -9
  109. data/lib/chef/provider/windows_task.rb +0 -3
  110. data/lib/chef/provider/yum_repository.rb +1 -1
  111. data/lib/chef/provider/zypper_repository.rb +1 -2
  112. data/lib/chef/providers.rb +0 -1
  113. data/lib/chef/recipe.rb +1 -1
  114. data/lib/chef/resource.rb +8 -10
  115. data/lib/chef/resource/apt_repository.rb +1 -10
  116. data/lib/chef/resource/build_essential.rb +2 -2
  117. data/lib/chef/resource/chef_client_scheduled_task.rb +1 -1
  118. data/lib/chef/resource/chef_client_systemd_timer.rb +2 -2
  119. data/lib/chef/resource/chef_vault_secret.rb +13 -13
  120. data/lib/chef/resource/chocolatey_feature.rb +1 -2
  121. data/lib/chef/resource/cron/cron_d.rb +1 -1
  122. data/lib/chef/resource/cron_access.rb +2 -2
  123. data/lib/chef/resource/execute.rb +4 -5
  124. data/lib/chef/resource/homebrew_update.rb +2 -2
  125. data/lib/chef/resource/hostname.rb +18 -18
  126. data/lib/chef/resource/lwrp_base.rb +1 -0
  127. data/lib/chef/resource/macos_userdefaults.rb +176 -61
  128. data/lib/chef/resource/openssl_dhparam.rb +2 -0
  129. data/lib/chef/resource/openssl_ec_private_key.rb +2 -0
  130. data/lib/chef/resource/openssl_ec_public_key.rb +2 -0
  131. data/lib/chef/resource/openssl_rsa_private_key.rb +2 -0
  132. data/lib/chef/resource/openssl_rsa_public_key.rb +2 -0
  133. data/lib/chef/resource/openssl_x509_certificate.rb +35 -35
  134. data/lib/chef/resource/openssl_x509_crl.rb +3 -2
  135. data/lib/chef/resource/openssl_x509_request.rb +23 -20
  136. data/lib/chef/resource/osx_profile.rb +227 -5
  137. data/lib/chef/resource/powershell_package_source.rb +1 -1
  138. data/lib/chef/resource/powershell_script.rb +24 -30
  139. data/lib/chef/resource/service.rb +2 -2
  140. data/lib/chef/resource/ssh_known_hosts_entry.rb +1 -1
  141. data/lib/chef/resource/sudo.rb +2 -2
  142. data/lib/chef/resource/sysctl.rb +5 -5
  143. data/lib/chef/resource/timezone.rb +112 -73
  144. data/lib/chef/resource/user_ulimit.rb +1 -1
  145. data/lib/chef/resource/windows_ad_join.rb +2 -0
  146. data/lib/chef/resource/windows_audit_policy.rb +3 -0
  147. data/lib/chef/resource/windows_auto_run.rb +2 -0
  148. data/lib/chef/resource/windows_certificate.rb +2 -0
  149. data/lib/chef/resource/windows_dfs_folder.rb +2 -0
  150. data/lib/chef/resource/windows_dfs_namespace.rb +2 -0
  151. data/lib/chef/resource/windows_dfs_server.rb +2 -0
  152. data/lib/chef/resource/windows_dns_record.rb +25 -5
  153. data/lib/chef/resource/windows_dns_zone.rb +12 -7
  154. data/lib/chef/resource/windows_feature.rb +2 -0
  155. data/lib/chef/resource/windows_feature_dism.rb +10 -0
  156. data/lib/chef/resource/windows_feature_powershell.rb +14 -2
  157. data/lib/chef/resource/windows_firewall_profile.rb +199 -0
  158. data/lib/chef/resource/windows_firewall_rule.rb +5 -3
  159. data/lib/chef/resource/windows_font.rb +3 -1
  160. data/lib/chef/resource/windows_pagefile.rb +4 -0
  161. data/lib/chef/resource/windows_printer.rb +17 -18
  162. data/lib/chef/resource/windows_printer_port.rb +14 -13
  163. data/lib/chef/resource/windows_security_policy.rb +51 -20
  164. data/lib/chef/resource/windows_share.rb +5 -3
  165. data/lib/chef/resource/windows_shortcut.rb +2 -0
  166. data/lib/chef/resource/windows_uac.rb +2 -0
  167. data/lib/chef/resource/windows_user_privilege.rb +2 -0
  168. data/lib/chef/resource/windows_workgroup.rb +2 -3
  169. data/lib/chef/resource_collection/stepable_iterator.rb +1 -2
  170. data/lib/chef/resource_inspector.rb +7 -1
  171. data/lib/chef/resources.rb +1 -0
  172. data/lib/chef/role.rb +3 -4
  173. data/lib/chef/run_context/cookbook_compiler.rb +20 -20
  174. data/lib/chef/run_status.rb +2 -6
  175. data/lib/chef/server_api_versions.rb +4 -0
  176. data/lib/chef/shell.rb +1 -1
  177. data/lib/chef/shell/shell_session.rb +2 -0
  178. data/lib/chef/util/backup.rb +1 -1
  179. data/lib/chef/util/diff.rb +11 -12
  180. data/lib/chef/util/powershell/cmdlet.rb +1 -1
  181. data/lib/chef/version.rb +2 -2
  182. data/lib/chef/win32/file.rb +2 -2
  183. data/lib/chef/win32/file/version_info.rb +5 -5
  184. data/lib/chef/win32/registry.rb +1 -2
  185. data/spec/data/ssl/chef-rspec.cert +15 -15
  186. data/spec/functional/knife/ssh_spec.rb +5 -16
  187. data/spec/functional/resource/aix_service_spec.rb +0 -2
  188. data/spec/functional/resource/aixinit_service_spec.rb +7 -8
  189. data/spec/functional/resource/apt_package_spec.rb +0 -1
  190. data/spec/functional/resource/bff_spec.rb +2 -2
  191. data/spec/functional/resource/cookbook_file_spec.rb +1 -1
  192. data/spec/functional/resource/cron_spec.rb +0 -1
  193. data/spec/functional/resource/dsc_resource_spec.rb +1 -1
  194. data/spec/functional/resource/dsc_script_spec.rb +0 -1
  195. data/spec/functional/resource/git_spec.rb +23 -1
  196. data/spec/functional/resource/group_spec.rb +12 -8
  197. data/spec/functional/resource/insserv_spec.rb +4 -5
  198. data/spec/functional/resource/link_spec.rb +20 -20
  199. data/spec/functional/resource/powershell_script_spec.rb +4 -4
  200. data/spec/functional/resource/remote_file_spec.rb +1 -7
  201. data/spec/functional/resource/rpm_spec.rb +2 -2
  202. data/spec/functional/resource/windows_certificate_spec.rb +3 -3
  203. data/spec/functional/resource/windows_font_spec.rb +49 -0
  204. data/spec/functional/resource/windows_security_policy_spec.rb +0 -3
  205. data/spec/functional/resource/windows_user_privilege_spec.rb +1 -1
  206. data/spec/functional/run_lock_spec.rb +26 -25
  207. data/spec/functional/shell_spec.rb +5 -5
  208. data/spec/functional/util/powershell/cmdlet_spec.rb +1 -1
  209. data/spec/functional/version_spec.rb +1 -1
  210. data/spec/functional/win32/registry_spec.rb +8 -8
  211. data/spec/functional/win32/service_manager_spec.rb +1 -1
  212. data/spec/integration/knife/common_options_spec.rb +12 -12
  213. data/spec/integration/knife/config_get_profile_spec.rb +69 -68
  214. data/spec/integration/knife/config_get_spec.rb +126 -125
  215. data/spec/integration/knife/config_list_profiles_spec.rb +181 -152
  216. data/spec/integration/knife/config_use_profile_spec.rb +110 -109
  217. data/spec/integration/knife/cookbook_upload_spec.rb +27 -0
  218. data/spec/integration/knife/diff_spec.rb +3 -1
  219. data/spec/integration/knife/download_spec.rb +3 -1
  220. data/spec/integration/knife/serve_spec.rb +5 -5
  221. data/spec/integration/knife/upload_spec.rb +3 -1
  222. data/spec/integration/recipes/accumulator_spec.rb +1 -1
  223. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +2 -2
  224. data/spec/integration/recipes/lwrp_spec.rb +1 -1
  225. data/spec/integration/recipes/notifies_spec.rb +1 -1
  226. data/spec/integration/recipes/notifying_block_spec.rb +1 -1
  227. data/spec/integration/recipes/recipe_dsl_spec.rb +1 -1
  228. data/spec/integration/recipes/resource_converge_if_changed_spec.rb +2 -0
  229. data/spec/integration/recipes/resource_load_spec.rb +2 -0
  230. data/spec/integration/recipes/unified_mode_spec.rb +1 -1
  231. data/spec/integration/recipes/use_partial_spec.rb +1 -1
  232. data/spec/scripts/ssl-serve.rb +1 -1
  233. data/spec/spec_helper.rb +16 -10
  234. data/spec/support/chef_helpers.rb +1 -20
  235. data/spec/support/platform_helpers.rb +9 -11
  236. data/spec/support/platforms/win32/spec_service.rb +1 -1
  237. data/spec/support/shared/functional/directory_resource.rb +1 -1
  238. data/spec/support/shared/functional/execute_resource.rb +1 -1
  239. data/spec/support/shared/functional/file_resource.rb +20 -21
  240. data/spec/support/shared/functional/win32_service.rb +1 -1
  241. data/spec/support/shared/functional/windows_script.rb +3 -3
  242. data/spec/support/shared/integration/integration_helper.rb +22 -52
  243. data/spec/support/shared/integration/knife_support.rb +2 -9
  244. data/spec/support/shared/unit/application_dot_d.rb +0 -1
  245. data/spec/support/shared/unit/script_resource.rb +6 -20
  246. data/spec/support/shared/unit/windows_script_resource.rb +15 -28
  247. data/spec/unit/application_spec.rb +4 -2
  248. data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +2 -4
  249. data/spec/unit/chef_fs/{parallelizer.rb → parallelizer_spec.rb} +1 -1
  250. data/spec/unit/cookbook/gem_installer_spec.rb +2 -1
  251. data/spec/unit/data_collector_spec.rb +29 -1
  252. data/spec/unit/dsl/platform_introspection_spec.rb +1 -0
  253. data/spec/unit/environment_spec.rb +7 -7
  254. data/spec/unit/event_dispatch/dispatcher_spec.rb +3 -0
  255. data/spec/unit/http/api_versions_spec.rb +19 -1
  256. data/spec/unit/json_compat_spec.rb +1 -1
  257. data/spec/unit/knife/bootstrap_spec.rb +16 -20
  258. data/spec/unit/knife/cookbook_download_spec.rb +4 -4
  259. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +1 -1
  260. data/spec/unit/knife/cookbook_upload_spec.rb +7 -10
  261. data/spec/unit/knife/core/hashed_command_loader_spec.rb +3 -3
  262. data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +21 -12
  263. data/spec/unit/knife/supermarket_share_spec.rb +1 -1
  264. data/spec/unit/log/syslog_spec.rb +6 -10
  265. data/spec/unit/log/winevt_spec.rb +21 -13
  266. data/spec/unit/lwrp_spec.rb +4 -4
  267. data/spec/unit/mixin/{path_sanity_spec.rb → default_paths_spec.rb} +14 -14
  268. data/spec/unit/mixin/powershell_exec_spec.rb +1 -1
  269. data/spec/unit/mixin/securable_spec.rb +0 -1
  270. data/spec/unit/mixin/shell_out_spec.rb +25 -26
  271. data/spec/unit/mixin/template_spec.rb +30 -30
  272. data/spec/unit/mixin/which.rb +8 -0
  273. data/spec/unit/mixin/windows_architecture_helper_spec.rb +4 -4
  274. data/spec/unit/node/immutable_collections_spec.rb +6 -2
  275. data/spec/unit/node_spec.rb +103 -16
  276. data/spec/unit/property_spec.rb +5 -5
  277. data/spec/unit/provider/execute_spec.rb +0 -7
  278. data/spec/unit/provider/ifconfig_spec.rb +0 -1
  279. data/spec/unit/provider/package/dnf/python_helper_spec.rb +1 -1
  280. data/spec/unit/provider/package/rubygems_spec.rb +5 -10
  281. data/spec/unit/provider/package/smartos_spec.rb +1 -1
  282. data/spec/unit/provider/package/windows_spec.rb +30 -53
  283. data/spec/unit/provider/powershell_script_spec.rb +11 -4
  284. data/spec/unit/provider/remote_directory_spec.rb +9 -9
  285. data/spec/unit/provider/service/arch_service_spec.rb +3 -2
  286. data/spec/unit/provider/service/debian_service_spec.rb +1 -1
  287. data/spec/unit/provider/service/gentoo_service_spec.rb +7 -7
  288. data/spec/unit/provider/service/macosx_spec.rb +3 -3
  289. data/spec/unit/provider/service/redhat_spec.rb +3 -3
  290. data/spec/unit/provider/service/upstart_service_spec.rb +3 -3
  291. data/spec/unit/provider/service/windows_spec.rb +2 -6
  292. data/spec/unit/provider/systemd_unit_spec.rb +28 -24
  293. data/spec/unit/provider_resolver_spec.rb +6 -6
  294. data/spec/unit/provider_spec.rb +1 -0
  295. data/spec/unit/resource/batch_spec.rb +6 -6
  296. data/spec/unit/resource/execute_spec.rb +123 -118
  297. data/spec/unit/resource/macos_user_defaults_spec.rb +103 -2
  298. data/spec/unit/resource/osx_profile_spec.rb +233 -0
  299. data/spec/unit/resource/powershell_script_spec.rb +11 -29
  300. data/spec/unit/resource/script_spec.rb +6 -1
  301. data/spec/unit/resource/timezone_spec.rb +63 -0
  302. data/spec/unit/resource/windows_feature_powershell_spec.rb +30 -4
  303. data/spec/unit/resource/windows_firewall_profile_spec.rb +77 -0
  304. data/spec/unit/resource/windows_package_spec.rb +1 -0
  305. data/spec/unit/resource_reporter_spec.rb +1 -1
  306. data/spec/unit/role_spec.rb +11 -11
  307. data/spec/unit/run_context/cookbook_compiler_spec.rb +1 -1
  308. data/spec/unit/run_lock_spec.rb +1 -1
  309. data/spec/unit/scan_access_control_spec.rb +1 -1
  310. data/spec/unit/server_api_spec.rb +43 -16
  311. data/spec/unit/util/diff_spec.rb +1 -15
  312. data/spec/unit/win32/security_spec.rb +4 -3
  313. data/tasks/rspec.rb +1 -1
  314. metadata +39 -31
  315. data/lib/chef/provider/osx_profile.rb +0 -255
  316. data/spec/unit/provider/osx_profile_spec.rb +0 -255
@@ -22,12 +22,8 @@ require "spec_helper"
22
22
  describe Chef::Provider::Service::Windows, "load_current_resource" do
23
23
  include_context "Win32"
24
24
 
25
- before(:all) do
26
- Chef::ReservedNames::Win32::Security = Class.new unless windows?
27
- end
28
-
29
- after(:all) do
30
- Chef::ReservedNames::Win32.send(:remove_const, :Security) unless windows?
25
+ before do
26
+ stub_const("Chef::ReservedNames::Win32::Security", Class.new) unless windows?
31
27
  end
32
28
 
33
29
  let(:logger) { double("Mixlib::Log::Child").as_null_object }
@@ -220,31 +220,35 @@ describe Chef::Provider::SystemdUnit do
220
220
  expect(current_resource.content).to eq(nil)
221
221
  end
222
222
 
223
- it "loads the user unit content if the file exists and user is set" do
224
- new_resource.user("joe")
225
- allow(File).to receive(:exist?)
226
- .with(unit_path_user)
227
- .and_return(true)
228
- allow(File).to receive(:read)
229
- .with(unit_path_user)
230
- .and_return(unit_content_string)
231
- expect(File).to receive(:exist?)
232
- .with(unit_path_user)
233
- expect(File).to receive(:read)
234
- .with(unit_path_user)
235
- provider.load_current_resource
236
- expect(current_resource.content).to eq(unit_content_string)
237
- end
223
+ # A password is required when specifying a user on Windows. Since systemd resources
224
+ # won't actually run on Windows, skip these tests rather than code a workaround.
225
+ unless windows?
226
+ it "loads the user unit content if the file exists and user is set" do
227
+ new_resource.user("joe")
228
+ allow(File).to receive(:exist?)
229
+ .with(unit_path_user)
230
+ .and_return(true)
231
+ allow(File).to receive(:read)
232
+ .with(unit_path_user)
233
+ .and_return(unit_content_string)
234
+ expect(File).to receive(:exist?)
235
+ .with(unit_path_user)
236
+ expect(File).to receive(:read)
237
+ .with(unit_path_user)
238
+ provider.load_current_resource
239
+ expect(current_resource.content).to eq(unit_content_string)
240
+ end
238
241
 
239
- it "does not load the user unit if the file does not exist and user is set" do
240
- new_resource.user("joe")
241
- allow(File).to receive(:exist?)
242
- .with(unit_path_user)
243
- .and_return(false)
244
- expect(File).to_not receive(:read)
245
- .with(unit_path_user)
246
- provider.load_current_resource
247
- expect(current_resource.content).to eq(nil)
242
+ it "does not load the user unit if the file does not exist and user is set" do
243
+ new_resource.user("joe")
244
+ allow(File).to receive(:exist?)
245
+ .with(unit_path_user)
246
+ .and_return(false)
247
+ expect(File).to_not receive(:read)
248
+ .with(unit_path_user)
249
+ provider.load_current_resource
250
+ expect(current_resource.content).to eq(nil)
251
+ end
248
252
  end
249
253
  end
250
254
 
@@ -54,11 +54,11 @@ describe Chef::ProviderResolver do
54
54
 
55
55
  let(:provider_resolver) { Chef::ProviderResolver.new(node, resource, action) }
56
56
  let(:resolved_provider) do
57
- begin
58
- resource ? resource.provider_for_action(action).class : nil
59
- rescue Chef::Exceptions::ProviderNotFound
60
- nil
61
- end
57
+
58
+ resource ? resource.provider_for_action(action).class : nil
59
+ rescue Chef::Exceptions::ProviderNotFound
60
+ nil
61
+
62
62
  end
63
63
 
64
64
  let(:service_name) { "test" }
@@ -722,7 +722,7 @@ describe Chef::ProviderResolver do
722
722
  %w{mac_os_x mac_os_x_server} => {
723
723
  group: [ Chef::Resource::Group, Chef::Provider::Group::Dscl ],
724
724
  package: [ Chef::Resource::HomebrewPackage, Chef::Provider::Package::Homebrew ],
725
- osx_profile: [ Chef::Resource::OsxProfile, Chef::Provider::OsxProfile],
725
+ osx_profile: [ Chef::Resource::OsxProfile],
726
726
  user: [ Chef::Resource::User::DsclUser, Chef::Provider::User::Dscl ],
727
727
 
728
728
  "mac_os_x" => {
@@ -20,6 +20,7 @@ require "spec_helper"
20
20
 
21
21
  class NoWhyrunDemonstrator < Chef::Provider
22
22
  attr_reader :system_state_altered
23
+
23
24
  def whyrun_supported?
24
25
  false
25
26
  end
@@ -19,24 +19,24 @@
19
19
  require "spec_helper"
20
20
 
21
21
  describe Chef::Resource::Batch do
22
- let(:node) { Chef::Node.new }
23
22
 
24
- before(:each) do
23
+ let(:resource) do
24
+ node = Chef::Node.new
25
25
  node.default["kernel"] = {}
26
26
  node.default["kernel"][:machine] = :x86_64.to_s
27
27
  node.automatic[:os] = "windows"
28
28
 
29
29
  run_context = Chef::RunContext.new(node, nil, nil)
30
- @resource = Chef::Resource::Batch.new("batch_unit_test", run_context)
30
+ Chef::Resource::Batch.new("batch_unit_test", run_context)
31
31
  end
32
32
 
33
33
  it "creates a new Chef::Resource::Batch" do
34
- expect(@resource).to be_a_kind_of(Chef::Resource::Batch)
34
+ expect(resource).to be_a_kind_of(Chef::Resource::Batch)
35
35
  end
36
36
 
37
37
  context "windows script" do
38
- let(:resource_instance) { @resource }
39
- let(:resource_instance_name ) { @resource.command }
38
+ let(:windows_script_resource) { resource }
39
+ let(:resource_instance_name ) { resource.command }
40
40
  let(:resource_name) { :batch }
41
41
  let(:interpreter_file_name) { "cmd.exe" }
42
42
 
@@ -63,6 +63,16 @@ describe Chef::Resource::Execute do
63
63
  expect(identity[:user]).to eq("user")
64
64
  end
65
65
  end
66
+
67
+ context "when username is passed as an integer" do
68
+ let(:username) { 499 }
69
+
70
+ it "correctly parses the user and domain" do
71
+ identity = resource.qualify_user(username, password, domain)
72
+ expect(identity[:domain]).to eq(nil)
73
+ expect(identity[:user]).to eq(499)
74
+ end
75
+ end
66
76
  end
67
77
 
68
78
  shared_examples_for "it received valid credentials" do
@@ -106,172 +116,167 @@ describe Chef::Resource::Execute do
106
116
  end
107
117
  end
108
118
 
109
- shared_examples_for "a consumer of the Execute resource" do
110
- context "when running on Windows" do
111
- before do
112
- allow(resource).to receive(:windows?).and_return(true)
113
- end
114
-
115
- context "when no user, domain, or password is specified" do
116
- let(:username) { nil }
117
- let(:domain) { nil }
118
- let(:password) { nil }
119
- it_behaves_like "it received valid credentials"
120
- end
121
-
122
- context "when a valid username is specified" do
123
- let(:username) { "starchild" }
124
- let(:elevated) { false }
125
- context "when a valid domain is specified" do
126
- let(:domain) { "mothership" }
127
-
128
- context "when the password is not specified" do
129
- let(:password) { nil }
130
- it_behaves_like "it received invalid credentials"
131
- end
132
-
133
- context "when the password is specified" do
134
- let(:password) { "we.funk!" }
135
- it_behaves_like "it received valid credentials"
136
- end
137
- end
119
+ context "when running on Windows" do
120
+ before do
121
+ allow(resource).to receive(:windows?).and_return(true)
122
+ end
138
123
 
139
- context "when the domain is not specified" do
140
- let(:domain) { nil }
141
- let(:elevated) { false }
124
+ context "when no user, domain, or password is specified" do
125
+ let(:username) { nil }
126
+ let(:domain) { nil }
127
+ let(:password) { nil }
128
+ it_behaves_like "it received valid credentials"
129
+ end
142
130
 
143
- context "when the password is not specified" do
144
- let(:password) { nil }
145
- it_behaves_like "it received invalid credentials"
146
- end
131
+ context "when a valid username is specified" do
132
+ let(:username) { "starchild" }
133
+ let(:elevated) { false }
134
+ context "when a valid domain is specified" do
135
+ let(:domain) { "mothership" }
147
136
 
148
- context "when the password is specified" do
149
- let(:password) { "we.funk!" }
150
- it_behaves_like "it received valid credentials"
151
- end
137
+ context "when the password is not specified" do
138
+ let(:password) { nil }
139
+ it_behaves_like "it received invalid credentials"
152
140
  end
153
141
 
154
- context "when username is not specified" do
155
- let(:username) { nil }
156
-
157
- context "when domain is specified" do
158
- let(:domain) { "mothership" }
159
- let(:password) { nil }
160
- it_behaves_like "it received invalid username and domain"
161
- end
162
-
163
- context "when password is specified" do
164
- let(:domain) { nil }
165
- let(:password) { "we.funk!" }
166
- it_behaves_like "it received invalid username and domain"
167
- end
142
+ context "when the password is specified" do
143
+ let(:password) { "we.funk!" }
144
+ it_behaves_like "it received valid credentials"
168
145
  end
169
146
  end
170
147
 
171
- context "when invalid username is specified" do
172
- let(:username) { "user@domain@domain" }
148
+ context "when the domain is not specified" do
173
149
  let(:domain) { nil }
174
- let(:password) { "we.funk!" }
175
- it_behaves_like "it received invalid username and domain"
176
- end
177
-
178
- context "when the domain is provided in both username and domain" do
179
- let(:domain) { "some_domain" }
180
- let(:password) { "we.funk!" }
150
+ let(:elevated) { false }
181
151
 
182
- context "when username is in the form domain\\user" do
183
- let(:username) { "mothership\\starchild" }
184
- it_behaves_like "it received invalid username and domain"
152
+ context "when the password is not specified" do
153
+ let(:password) { nil }
154
+ it_behaves_like "it received invalid credentials"
185
155
  end
186
156
 
187
- context "when username is in the form user@domain" do
188
- let(:username) { "starchild@mothership" }
189
- it_behaves_like "it received invalid username and domain"
157
+ context "when the password is specified" do
158
+ let(:password) { "we.funk!" }
159
+ it_behaves_like "it received valid credentials"
190
160
  end
191
161
  end
192
162
 
193
- context "when elevated is passed" do
194
- let(:elevated) { true }
163
+ context "when username is not specified" do
164
+ let(:username) { nil }
195
165
 
196
- context "when username and password are not passed" do
197
- let(:username) { nil }
198
- let(:domain) { nil }
166
+ context "when domain is specified" do
167
+ let(:domain) { "mothership" }
199
168
  let(:password) { nil }
200
- it_behaves_like "it received invalid credentials"
169
+ it_behaves_like "it received invalid username and domain"
201
170
  end
202
171
 
203
- context "when username and password are passed" do
204
- let(:username) { "user" }
172
+ context "when password is specified" do
205
173
  let(:domain) { nil }
206
174
  let(:password) { "we.funk!" }
207
- it_behaves_like "it received valid credentials"
175
+ it_behaves_like "it received invalid username and domain"
208
176
  end
209
177
  end
210
178
  end
211
179
 
212
- context "when not running on Windows" do
213
- before do
214
- allow(resource).to receive(:node).and_return({ platform_family: "ubuntu" })
180
+ context "when invalid username is specified" do
181
+ let(:username) { "user@domain@domain" }
182
+ let(:domain) { nil }
183
+ let(:password) { "we.funk!" }
184
+ it_behaves_like "it received invalid username and domain"
185
+ end
186
+
187
+ context "when the domain is provided in both username and domain" do
188
+ let(:domain) { "some_domain" }
189
+ let(:password) { "we.funk!" }
190
+
191
+ context "when username is in the form domain\\user" do
192
+ let(:username) { "mothership\\starchild" }
193
+ it_behaves_like "it received invalid username and domain"
194
+ end
195
+
196
+ context "when username is in the form user@domain" do
197
+ let(:username) { "starchild@mothership" }
198
+ it_behaves_like "it received invalid username and domain"
215
199
  end
200
+ end
216
201
 
217
- context "when no user, domain, or password is specified" do
202
+ context "when elevated is passed" do
203
+ let(:elevated) { true }
204
+
205
+ context "when username and password are not passed" do
218
206
  let(:username) { nil }
219
207
  let(:domain) { nil }
220
208
  let(:password) { nil }
209
+ it_behaves_like "it received invalid credentials"
210
+ end
211
+
212
+ context "when username and password are passed" do
213
+ let(:username) { "user" }
214
+ let(:domain) { nil }
215
+ let(:password) { "we.funk!" }
221
216
  it_behaves_like "it received valid credentials"
222
217
  end
218
+ end
219
+ end
220
+
221
+ context "when not running on Windows" do
222
+ before do
223
+ allow(resource).to receive(:node).and_return({ platform_family: "ubuntu" })
224
+ end
223
225
 
224
- context "when the user is specified and the domain and password are not" do
225
- let(:username) { "starchild" }
226
+ context "when no user, domain, or password is specified" do
227
+ let(:username) { nil }
228
+ let(:domain) { nil }
229
+ let(:password) { nil }
230
+ it_behaves_like "it received valid credentials"
231
+ end
232
+
233
+ context "when the user is specified and the domain and password are not" do
234
+ let(:username) { "starchild" }
235
+ let(:domain) { nil }
236
+ let(:password) { nil }
237
+ it_behaves_like "it received valid credentials"
238
+
239
+ context "when the password is specified and the domain is not" do
240
+ let(:password) { "we.funk!" }
226
241
  let(:domain) { nil }
242
+ it_behaves_like "it received credentials that are not valid on the platform"
243
+ end
244
+
245
+ context "when the domain is specified and the password is not" do
246
+ let(:domain) { "mothership" }
227
247
  let(:password) { nil }
228
- it_behaves_like "it received valid credentials"
248
+ it_behaves_like "it received credentials that are not valid on the platform"
249
+ end
229
250
 
230
- context "when the password is specified and the domain is not" do
251
+ context "when the domain and password are specified" do
252
+ let(:domain) { "mothership" }
253
+ let(:password) { "we.funk!" }
254
+ it_behaves_like "it received credentials that are not valid on the platform"
255
+ end
256
+ end
257
+
258
+ context "when the user is not specified" do
259
+ let(:username) { nil }
260
+ context "when the domain is specified" do
261
+ let(:domain) { "mothership" }
262
+ context "when the password is specified" do
231
263
  let(:password) { "we.funk!" }
232
- let(:domain) { nil }
233
264
  it_behaves_like "it received credentials that are not valid on the platform"
234
265
  end
235
266
 
236
- context "when the domain is specified and the password is not" do
237
- let(:domain) { "mothership" }
267
+ context "when password is not specified" do
238
268
  let(:password) { nil }
239
269
  it_behaves_like "it received credentials that are not valid on the platform"
240
270
  end
271
+ end
241
272
 
242
- context "when the domain and password are specified" do
243
- let(:domain) { "mothership" }
273
+ context "when the domain is not specified" do
274
+ let(:domain) { nil }
275
+ context "when the password is specified" do
244
276
  let(:password) { "we.funk!" }
245
277
  it_behaves_like "it received credentials that are not valid on the platform"
246
278
  end
247
279
  end
248
-
249
- context "when the user is not specified" do
250
- let(:username) { nil }
251
- context "when the domain is specified" do
252
- let(:domain) { "mothership" }
253
- context "when the password is specified" do
254
- let(:password) { "we.funk!" }
255
- it_behaves_like "it received credentials that are not valid on the platform"
256
- end
257
-
258
- context "when password is not specified" do
259
- let(:password) { nil }
260
- it_behaves_like "it received credentials that are not valid on the platform"
261
- end
262
- end
263
-
264
- context "when the domain is not specified" do
265
- let(:domain) { nil }
266
- context "when the password is specified" do
267
- let(:password) { "we.funk!" }
268
- it_behaves_like "it received credentials that are not valid on the platform"
269
- end
270
- end
271
- end
272
280
  end
273
281
  end
274
-
275
- it_behaves_like "a consumer of the Execute resource"
276
-
277
282
  end
@@ -20,16 +20,117 @@ require "spec_helper"
20
20
  describe Chef::Resource::MacosUserDefaults do
21
21
 
22
22
  let(:resource) { Chef::Resource::MacosUserDefaults.new("foo") }
23
+ let(:provider) { resource.provider_for_action(:write) }
23
24
 
24
25
  it "has a resource name of :macos_userdefaults" do
25
- expect(resource.resource_name).to eql(:macos_userdefaults)
26
+ expect(resource.resource_name).to eq(:macos_userdefaults)
27
+ end
28
+
29
+ it "the domain property defaults to NSGlobalDomain" do
30
+ expect(resource.domain).to eq("NSGlobalDomain")
31
+ end
32
+
33
+ it "the value property coerces keys in hashes to strings so we can compare them with plist data" do
34
+ resource.value "User": "/Library/Managed Installs/way_fake.log"
35
+ expect(resource.value).to eq({ "User" => "/Library/Managed Installs/way_fake.log" })
36
+ end
37
+
38
+ it "the host property defaults to nil" do
39
+ expect(resource.host).to be_nil
40
+ end
41
+
42
+ it "the sudo property defaults to false" do
43
+ expect(resource.sudo).to be false
26
44
  end
27
45
 
28
46
  it "sets the default action as :write" do
29
- expect(resource.action).to eql([:write])
47
+ expect(resource.action).to eq([:write])
30
48
  end
31
49
 
32
50
  it "supports :write action" do
33
51
  expect { resource.action :write }.not_to raise_error
34
52
  end
53
+
54
+ describe "#defaults_export_cmd" do
55
+ it "exports NSGlobalDomain if no domain is set" do
56
+ expect(provider.defaults_export_cmd(resource)).to eq(["/usr/bin/defaults", "export", "NSGlobalDomain", "-"])
57
+ end
58
+
59
+ it "exports a provided domain" do
60
+ resource.domain "com.tim"
61
+ expect(provider.defaults_export_cmd(resource)).to eq(["/usr/bin/defaults", "export", "com.tim", "-"])
62
+ end
63
+
64
+ it "sets -currentHost if host is 'current'" do
65
+ resource.host "current"
66
+ expect(provider.defaults_export_cmd(resource)).to eq(["/usr/bin/defaults", "-currentHost", "export", "NSGlobalDomain", "-"])
67
+ end
68
+
69
+ it "sets -host 'tim-laptop if host is 'tim-laptop'" do
70
+ resource.host "tim-laptop"
71
+ expect(provider.defaults_export_cmd(resource)).to eq(["/usr/bin/defaults", "-host", "tim-laptop", "export", "NSGlobalDomain", "-"])
72
+ end
73
+ end
74
+
75
+ describe "#defaults_modify_cmd" do
76
+ # avoid needing to set these required values over and over. We'll overwrite them where necessary
77
+ before do
78
+ resource.key = "foo"
79
+ resource.value = "bar"
80
+ end
81
+
82
+ it "writes to NSGlobalDomain if domain isn't specified" do
83
+ expect(provider.defaults_modify_cmd).to eq(["/usr/bin/defaults", "write", "NSGlobalDomain", "foo", "-string", "bar"])
84
+ end
85
+
86
+ it "uses the domain property if set" do
87
+ resource.domain = "MyCustomDomain"
88
+ expect(provider.defaults_modify_cmd).to eq(["/usr/bin/defaults", "write", "MyCustomDomain", "foo", "-string", "bar"])
89
+ end
90
+
91
+ it "sets host specific values using host property" do
92
+ resource.host = "tims_laptop"
93
+ expect(provider.defaults_modify_cmd).to eq(["/usr/bin/defaults", "-host", "tims_laptop", "write", "NSGlobalDomain", "foo", "-string", "bar"])
94
+ end
95
+
96
+ it "if host is set to :current it passes CurrentHost" do
97
+ resource.host = :current
98
+ expect(provider.defaults_modify_cmd).to eq(["/usr/bin/defaults", "-currentHost", "write", "NSGlobalDomain", "foo", "-string", "bar"])
99
+ end
100
+
101
+ it "raises ArgumentError if bool is specified, but the value can't be made into a bool" do
102
+ resource.type "bool"
103
+ expect { provider.defaults_modify_cmd }.to raise_error(ArgumentError)
104
+ end
105
+
106
+ it "autodetects array type and passes individual values" do
107
+ resource.value = %w{one two three}
108
+ expect(provider.defaults_modify_cmd).to eq(["/usr/bin/defaults", "write", "NSGlobalDomain", "foo", "-array", "one", "two", "three"])
109
+ end
110
+
111
+ it "autodetects string type and passes a single value" do
112
+ resource.value = "one"
113
+ expect(provider.defaults_modify_cmd).to eq(["/usr/bin/defaults", "write", "NSGlobalDomain", "foo", "-string", "one"])
114
+ end
115
+
116
+ it "autodetects integer type and passes a single value" do
117
+ resource.value = 1
118
+ expect(provider.defaults_modify_cmd).to eq(["/usr/bin/defaults", "write", "NSGlobalDomain", "foo", "-int", 1])
119
+ end
120
+
121
+ it "autodetects boolean type from TrueClass value and passes a 'TRUE' string" do
122
+ resource.value = true
123
+ expect(provider.defaults_modify_cmd).to eq(["/usr/bin/defaults", "write", "NSGlobalDomain", "foo", "-bool", "TRUE"])
124
+ end
125
+
126
+ it "autodetects boolean type from FalseClass value and passes a 'FALSE' string" do
127
+ resource.value = false
128
+ expect(provider.defaults_modify_cmd).to eq(["/usr/bin/defaults", "write", "NSGlobalDomain", "foo", "-bool", "FALSE"])
129
+ end
130
+
131
+ it "autodetects dict type from Hash value and flattens keys & values" do
132
+ resource.value = { "foo" => "bar" }
133
+ expect(provider.defaults_modify_cmd).to eq(["/usr/bin/defaults", "write", "NSGlobalDomain", "foo", "-dict", "foo", "bar"])
134
+ end
135
+ end
35
136
  end