chef 14.1.12-universal-mingw32 → 14.2.0-universal-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +1 -6
- data/VERSION +1 -1
- data/chef.gemspec +2 -3
- data/lib/chef/chef_fs/data_handler/data_handler_base.rb +8 -4
- data/lib/chef/cookbook/manifest_v0.rb +2 -2
- data/lib/chef/cookbook_manifest.rb +3 -2
- data/lib/chef/cookbook_version.rb +3 -2
- data/lib/chef/guard_interpreter/default_guard_interpreter.rb +2 -2
- data/lib/chef/http/auth_credentials.rb +5 -3
- data/lib/chef/http/authenticator.rb +6 -3
- data/lib/chef/knife.rb +3 -6
- data/lib/chef/knife/configure.rb +12 -8
- data/lib/chef/knife/raw.rb +6 -1
- data/lib/chef/mixin/shell_out.rb +16 -14
- data/lib/chef/provider/execute.rb +4 -3
- data/lib/chef/provider/git.rb +1 -1
- data/lib/chef/provider/package/dnf.rb +5 -5
- data/lib/chef/provider/package/windows.rb +7 -0
- data/lib/chef/provider/package/yum.rb +7 -7
- data/lib/chef/provider/service/freebsd.rb +3 -3
- data/lib/chef/provider/service/init.rb +5 -5
- data/lib/chef/provider/service/macosx.rb +5 -4
- data/lib/chef/provider/service/simple.rb +4 -4
- data/lib/chef/provider/service/systemd.rb +13 -13
- data/lib/chef/provider/service/upstart.rb +3 -3
- data/lib/chef/provider/service/windows.rb +2 -0
- data/lib/chef/provider/systemd_unit.rb +4 -4
- data/lib/chef/provider/user.rb +18 -1
- data/lib/chef/provider/user/aix.rb +40 -8
- data/lib/chef/provider/user/dscl.rb +7 -14
- data/lib/chef/provider/user/linux.rb +1 -11
- data/lib/chef/provider/user/solaris.rb +57 -26
- data/lib/chef/provider/user/useradd.rb +4 -1
- data/lib/chef/provider/windows_task.rb +1 -0
- data/lib/chef/providers.rb +1 -2
- data/lib/chef/resource/execute.rb +4 -1
- data/lib/chef/resource/gem_package.rb +1 -1
- data/lib/chef/resource/hostname.rb +1 -1
- data/lib/chef/resource/sysctl.rb +3 -1
- data/lib/chef/resource/windows_ad_join.rb +16 -3
- data/lib/chef/resource_inspector.rb +13 -0
- data/lib/chef/run_context/cookbook_compiler.rb +1 -1
- data/lib/chef/server_api.rb +2 -0
- data/lib/chef/version.rb +1 -1
- data/spec/functional/mixin/shell_out_spec.rb +27 -1
- data/spec/functional/resource/execute_spec.rb +2 -2
- data/spec/functional/resource/windows_task_spec.rb +1 -1
- data/spec/support/shared/functional/securable_resource.rb +1 -1
- data/spec/support/shared/unit/execute_resource.rb +1 -1
- data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +3 -3
- data/spec/unit/chef_fs/data_handler/data_handler_base_spec.rb +65 -0
- data/spec/unit/cookbook/manifest_v0_spec.rb +1 -1
- data/spec/unit/cookbook_manifest_spec.rb +2 -0
- data/spec/unit/dsl/recipe_spec.rb +1 -5
- data/spec/unit/http/authenticator_spec.rb +33 -8
- data/spec/unit/mixin/shell_out_spec.rb +61 -1
- data/spec/unit/provider/apt_update_spec.rb +7 -7
- data/spec/unit/provider/execute_spec.rb +16 -15
- data/spec/unit/provider/git_spec.rb +3 -3
- data/spec/unit/provider/package/windows_spec.rb +12 -0
- data/spec/unit/provider/script_spec.rb +2 -2
- data/spec/unit/provider/service/arch_service_spec.rb +9 -9
- data/spec/unit/provider/service/freebsd_service_spec.rb +6 -6
- data/spec/unit/provider/service/init_service_spec.rb +11 -11
- data/spec/unit/provider/service/invokercd_service_spec.rb +9 -9
- data/spec/unit/provider/service/macosx_spec.rb +11 -11
- data/spec/unit/provider/service/openbsd_service_spec.rb +6 -6
- data/spec/unit/provider/service/simple_service_spec.rb +4 -4
- data/spec/unit/provider/service/systemd_service_spec.rb +16 -16
- data/spec/unit/provider/service/upstart_service_spec.rb +12 -12
- data/spec/unit/provider/service/windows_spec.rb +5 -0
- data/spec/unit/provider/systemd_unit_spec.rb +163 -118
- data/spec/unit/provider/user/dscl_spec.rb +2 -9
- data/spec/unit/provider/user/solaris_spec.rb +2 -2
- data/spec/unit/provider/zypper_repository_spec.rb +3 -3
- data/spec/unit/provider_spec.rb +1 -5
- data/spec/unit/resource/apt_package_spec.rb +14 -0
- data/spec/unit/resource/apt_preference_spec.rb +14 -1
- data/spec/unit/resource/apt_repository_spec.rb +12 -3
- data/spec/unit/resource/apt_update_spec.rb +9 -0
- data/spec/unit/resource/bash_spec.rb +8 -0
- data/spec/unit/resource/bff_package_spec.rb +51 -0
- data/spec/unit/resource/breakpoint_spec.rb +4 -4
- data/spec/unit/resource/build_essential_spec.rb +5 -1
- data/spec/unit/resource/cab_package_spec.rb +10 -0
- data/spec/unit/resource/chef_gem_spec.rb +14 -0
- data/spec/unit/resource/chef_handler_spec.rb +9 -4
- data/spec/unit/resource/chocolatey_package_spec.rb +15 -1
- data/spec/unit/resource/conditional_spec.rb +3 -3
- data/spec/unit/resource/cookbook_file_spec.rb +13 -2
- data/spec/unit/resource/cron_spec.rb +2 -7
- data/spec/unit/resource/csh_spec.rb +8 -0
- data/spec/unit/resource/directory_spec.rb +4 -9
- data/spec/unit/resource/dmg_package_spec.rb +8 -4
- data/spec/unit/resource/dnf_package_spec.rb +16 -1
- data/spec/unit/resource/dpkg_package_spec.rb +18 -0
- data/spec/unit/resource/dsc_resource_spec.rb +6 -6
- data/spec/unit/resource/dsc_script_spec.rb +39 -39
- data/spec/unit/resource/execute_spec.rb +20 -12
- data/spec/unit/resource/file_spec.rb +10 -10
- data/spec/unit/resource/freebsd_package_spec.rb +16 -0
- data/spec/unit/resource/gem_package_spec.rb +27 -0
- data/spec/unit/resource/git_spec.rb +17 -2
- data/spec/unit/resource/group_spec.rb +18 -17
- data/spec/unit/resource/homebrew_cask_spec.rb +9 -4
- data/spec/unit/resource/homebrew_package_spec.rb +14 -0
- data/spec/unit/resource/homebrew_tap_spec.rb +8 -3
- data/spec/unit/resource/hostname_spec.rb +10 -6
- data/spec/unit/resource/http_request_spec.rb +14 -0
- data/spec/unit/resource/ips_package_spec.rb +15 -3
- data/spec/unit/resource/ksh_spec.rb +8 -0
- data/spec/unit/resource/launchd_spec.rb +11 -5
- data/spec/unit/resource/link_spec.rb +6 -11
- data/spec/unit/resource/log_spec.rb +8 -8
- data/spec/unit/resource/macos_user_defaults_spec.rb +5 -1
- data/spec/unit/resource/macports_package_spec.rb +19 -0
- data/spec/unit/resource/mdadm_spec.rb +7 -3
- data/spec/unit/resource/mount_spec.rb +15 -18
- data/spec/unit/resource/msu_package_spec.rb +10 -0
- data/spec/unit/resource/ohai_hint_spec.rb +9 -8
- data/spec/unit/resource/ohai_spec.rb +11 -3
- data/spec/unit/resource/openbsd_package_spec.rb +14 -0
- data/spec/unit/resource/openssl_dhparam.rb +10 -5
- data/spec/unit/resource/openssl_rsa_private_key_spec.rb +10 -5
- data/spec/unit/resource/openssl_rsa_public_key_spec.rb +9 -5
- data/spec/unit/resource/osx_profile_spec.rb +7 -4
- data/spec/unit/resource/package_spec.rb +14 -0
- data/spec/unit/resource/pacman_package_spec.rb +17 -3
- data/spec/unit/resource/paludis_package_spec.rb +36 -0
- data/spec/unit/resource/perl_spec.rb +8 -0
- data/spec/unit/resource/portage_package_spec.rb +14 -0
- data/spec/unit/resource/powershell_package_spec.rb +14 -0
- data/spec/unit/resource/python_spec.rb +8 -0
- data/spec/unit/resource/reboot_spec.rb +5 -3
- data/spec/unit/resource/registry_key_spec.rb +12 -1
- data/spec/unit/resource/remote_directory_spec.rb +11 -1
- data/spec/unit/resource/remote_file_spec.rb +19 -0
- data/spec/unit/resource/rhsm_errata_level_spec.rb +7 -3
- data/spec/unit/resource/rhsm_errata_spec.rb +8 -4
- data/spec/unit/resource/rhsm_register_spec.rb +6 -1
- data/spec/unit/resource/rhsm_repo_spec.rb +9 -4
- data/spec/unit/resource/rhsm_subscription_spec.rb +9 -4
- data/spec/unit/resource/route_spec.rb +4 -9
- data/spec/unit/resource/rpm_package_spec.rb +14 -0
- data/spec/unit/resource/ruby_block_spec.rb +12 -8
- data/spec/unit/resource/ruby_spec.rb +8 -0
- data/spec/unit/resource/scm_spec.rb +16 -8
- data/spec/unit/resource/script_spec.rb +8 -0
- data/spec/unit/resource/service_spec.rb +15 -0
- data/spec/unit/resource/smartos_package_spec.rb +18 -4
- data/spec/unit/resource/solaris_package_spec.rb +14 -0
- data/spec/unit/resource/subversion_spec.rb +14 -8
- data/spec/unit/resource/sudo_spec.rb +11 -4
- data/spec/unit/resource/swap_file_spec.rb +4 -5
- data/spec/unit/resource/sysctl_spec.rb +8 -10
- data/spec/unit/resource/systemd_unit_spec.rb +14 -12
- data/spec/unit/resource/template_spec.rb +19 -0
- data/spec/unit/resource/{windows_ad_join.rb → windows_ad_join_spec.rb} +12 -6
- data/spec/unit/resource/windows_auto_run_spec.rb +9 -9
- data/spec/unit/resource/windows_env_spec.rb +8 -16
- data/spec/unit/resource/windows_feature.rb +27 -8
- data/spec/unit/resource/windows_feature_dism.rb +30 -9
- data/spec/unit/resource/windows_feature_powershell.rb +7 -7
- data/spec/unit/resource/windows_font_spec.rb +3 -4
- data/spec/unit/resource/windows_package_spec.rb +12 -2
- data/spec/unit/resource/windows_pagefile_spec.rb +12 -8
- data/spec/unit/resource/windows_path_spec.rb +4 -5
- data/spec/unit/resource/windows_printer_port_spec.rb +20 -3
- data/spec/unit/resource/windows_printer_spec.rb +12 -5
- data/spec/unit/resource/windows_service_spec.rb +24 -1
- data/spec/unit/resource/windows_shortcut_spec.rb +4 -5
- data/spec/unit/resource/yum_repository_spec.rb +48 -2
- data/spec/unit/resource/zypper_package_spec.rb +51 -0
- data/spec/unit/resource/zypper_repository_spec.rb +56 -11
- data/spec/unit/resource_spec.rb +1 -5
- metadata +21 -12
- data/spec/functional/resource/user/useradd_spec.rb +0 -709
@@ -37,4 +37,18 @@ describe Chef::Resource::SolarisPackage, "initialize" do
|
|
37
37
|
it "sets the package_name to the name provided" do
|
38
38
|
expect(resource.package_name).to eql("foo")
|
39
39
|
end
|
40
|
+
|
41
|
+
it "sets the default action as :install" do
|
42
|
+
expect(resource.action).to eql([:install])
|
43
|
+
end
|
44
|
+
|
45
|
+
it "supports :install, :lock, :purge, :reconfig, :remove, :unlock, :upgrade actions" do
|
46
|
+
expect { resource.action :install }.not_to raise_error
|
47
|
+
expect { resource.action :lock }.not_to raise_error
|
48
|
+
expect { resource.action :purge }.not_to raise_error
|
49
|
+
expect { resource.action :reconfig }.not_to raise_error
|
50
|
+
expect { resource.action :remove }.not_to raise_error
|
51
|
+
expect { resource.action :unlock }.not_to raise_error
|
52
|
+
expect { resource.action :upgrade }.not_to raise_error
|
53
|
+
end
|
40
54
|
end
|
@@ -17,10 +17,8 @@
|
|
17
17
|
#
|
18
18
|
|
19
19
|
require "spec_helper"
|
20
|
-
require "support/shared/unit/resource/static_provider_resolution"
|
21
20
|
|
22
21
|
describe Chef::Resource::Subversion do
|
23
|
-
|
24
22
|
static_provider_resolution(
|
25
23
|
resource: Chef::Resource::Subversion,
|
26
24
|
provider: Chef::Provider::Subversion,
|
@@ -28,19 +26,27 @@ describe Chef::Resource::Subversion do
|
|
28
26
|
action: :install
|
29
27
|
)
|
30
28
|
|
31
|
-
let(:resource) { Chef::Resource::Subversion.new("
|
29
|
+
let(:resource) { Chef::Resource::Subversion.new("fakey_fakerton") }
|
32
30
|
|
33
31
|
it "is a subclass of Resource::Scm" do
|
34
|
-
expect(resource).to be_an_instance_of(Chef::Resource::Subversion)
|
35
32
|
expect(resource).to be_a_kind_of(Chef::Resource::Scm)
|
36
33
|
end
|
37
34
|
|
38
|
-
it "
|
39
|
-
expect(resource.destination).to
|
35
|
+
it "the destination property is the name_property" do
|
36
|
+
expect(resource.destination).to eql("fakey_fakerton")
|
37
|
+
end
|
38
|
+
|
39
|
+
it "sets the default action as :sync" do
|
40
|
+
expect(resource.action).to eql([:sync])
|
40
41
|
end
|
41
42
|
|
42
|
-
it "
|
43
|
-
expect
|
43
|
+
it "supports :checkout, :diff, :export, :force_export, :log, :sync actions" do
|
44
|
+
expect { resource.action :checkout }.not_to raise_error
|
45
|
+
expect { resource.action :diff }.not_to raise_error
|
46
|
+
expect { resource.action :export }.not_to raise_error
|
47
|
+
expect { resource.action :force_export }.not_to raise_error
|
48
|
+
expect { resource.action :log }.not_to raise_error
|
49
|
+
expect { resource.action :sync }.not_to raise_error
|
44
50
|
end
|
45
51
|
|
46
52
|
it "sets svn info arguments to --no-auth-cache by default" do
|
@@ -22,18 +22,25 @@ describe Chef::Resource::Sudo do
|
|
22
22
|
let(:node) { Chef::Node.new }
|
23
23
|
let(:events) { Chef::EventDispatch::Dispatcher.new }
|
24
24
|
let(:run_context) { Chef::RunContext.new(node, {}, events) }
|
25
|
-
let(:resource) { Chef::Resource::Sudo.new("
|
25
|
+
let(:resource) { Chef::Resource::Sudo.new("fakey_fakerton", run_context) }
|
26
26
|
|
27
27
|
it "has a resource name of :sudo" do
|
28
28
|
expect(resource.resource_name).to eql(:sudo)
|
29
29
|
end
|
30
30
|
|
31
|
-
it "
|
31
|
+
it "the filename property is the name_property" do
|
32
|
+
expect(resource.filename).to eql("fakey_fakerton")
|
33
|
+
end
|
34
|
+
|
35
|
+
it "sets the default action as :create" do
|
32
36
|
expect(resource.action).to eql([:create])
|
33
37
|
end
|
34
38
|
|
35
|
-
it "
|
36
|
-
expect
|
39
|
+
it "supports :create, :delete, :install, :remove actions" do
|
40
|
+
expect { resource.action :create }.not_to raise_error
|
41
|
+
expect { resource.action :delete }.not_to raise_error
|
42
|
+
expect { resource.action :install }.not_to raise_error
|
43
|
+
expect { resource.action :remove }.not_to raise_error
|
37
44
|
end
|
38
45
|
|
39
46
|
it "coerces filename property values . & ~ to __" do
|
@@ -18,23 +18,22 @@
|
|
18
18
|
require "spec_helper"
|
19
19
|
|
20
20
|
describe Chef::Resource::SwapFile do
|
21
|
-
let(:resource) { Chef::Resource::SwapFile.new("
|
21
|
+
let(:resource) { Chef::Resource::SwapFile.new("fakey_fakerton") }
|
22
22
|
|
23
23
|
it "sets resource name as :swap_file" do
|
24
24
|
expect(resource.resource_name).to eql(:swap_file)
|
25
25
|
end
|
26
26
|
|
27
|
-
it "
|
28
|
-
expect(resource.path).to eql("
|
27
|
+
it "the path property is the name_property" do
|
28
|
+
expect(resource.path).to eql("fakey_fakerton")
|
29
29
|
end
|
30
30
|
|
31
31
|
it "sets the default action as :create" do
|
32
32
|
expect(resource.action).to eql([:create])
|
33
33
|
end
|
34
34
|
|
35
|
-
it "supports :create
|
35
|
+
it "supports :create, :remove actions" do
|
36
36
|
expect { resource.action :create }.not_to raise_error
|
37
37
|
expect { resource.action :remove }.not_to raise_error
|
38
|
-
expect { resource.action :delete }.to raise_error(ArgumentError)
|
39
38
|
end
|
40
39
|
end
|
@@ -18,18 +18,23 @@
|
|
18
18
|
require "spec_helper"
|
19
19
|
|
20
20
|
describe Chef::Resource::Sysctl do
|
21
|
-
let(:resource) { Chef::Resource::Sysctl.new("
|
21
|
+
let(:resource) { Chef::Resource::Sysctl.new("fakey_fakerton") }
|
22
22
|
|
23
23
|
it "sets resource name as :sysctl" do
|
24
24
|
expect(resource.resource_name).to eql(:sysctl)
|
25
25
|
end
|
26
26
|
|
27
|
+
it "the key property is the name_property" do
|
28
|
+
expect(resource.key).to eql("fakey_fakerton")
|
29
|
+
end
|
30
|
+
|
27
31
|
it "sets the default action as :apply" do
|
28
32
|
expect(resource.action).to eql([:apply])
|
29
33
|
end
|
30
34
|
|
31
|
-
it "
|
32
|
-
expect
|
35
|
+
it "supports :apply, :remove actions" do
|
36
|
+
expect { resource.action :apply }.not_to raise_error
|
37
|
+
expect { resource.action :remove }.not_to raise_error
|
33
38
|
end
|
34
39
|
|
35
40
|
it "coerces Arrays in the value property to space delimited Strings" do
|
@@ -46,11 +51,4 @@ describe Chef::Resource::Sysctl do
|
|
46
51
|
resource.value 1.1
|
47
52
|
expect(resource.value).to eql("1.1")
|
48
53
|
end
|
49
|
-
|
50
|
-
it "supports :apply and :remove actions" do
|
51
|
-
expect { resource.action :apply }.not_to raise_error
|
52
|
-
expect { resource.action :remove }.not_to raise_error
|
53
|
-
expect { resource.action :delete }.to raise_error(ArgumentError)
|
54
|
-
expect { resource.action :install }.to raise_error(ArgumentError)
|
55
|
-
end
|
56
54
|
end
|
@@ -35,29 +35,31 @@ describe Chef::Resource::SystemdUnit do
|
|
35
35
|
}
|
36
36
|
end
|
37
37
|
|
38
|
-
it "
|
39
|
-
expect(resource.
|
38
|
+
it "the unit_name property is the name_property" do
|
39
|
+
expect(resource.unit_name).to eql("sysstat-collect.timer")
|
40
40
|
end
|
41
41
|
|
42
|
-
it "
|
42
|
+
it "sets the default action as :nothing" do
|
43
43
|
expect(resource.action).to eql([:nothing])
|
44
44
|
end
|
45
45
|
|
46
|
-
it "supports
|
46
|
+
it "supports :create, :delete, :disable, :enable, :mask, :preset, :reenable, :reload, :reload_or_restart, :reload_or_try_restart, :restart, :revert, :start, :stop, :try_restart, :unmask actions" do
|
47
47
|
expect { resource.action :create }.not_to raise_error
|
48
48
|
expect { resource.action :delete }.not_to raise_error
|
49
|
-
expect { resource.action :preset }.not_to raise_error
|
50
|
-
expect { resource.action :revert }.not_to raise_error
|
51
|
-
expect { resource.action :enable }.not_to raise_error
|
52
49
|
expect { resource.action :disable }.not_to raise_error
|
53
|
-
expect { resource.action :
|
50
|
+
expect { resource.action :enable }.not_to raise_error
|
54
51
|
expect { resource.action :mask }.not_to raise_error
|
55
|
-
expect { resource.action :
|
52
|
+
expect { resource.action :preset }.not_to raise_error
|
53
|
+
expect { resource.action :reenable }.not_to raise_error
|
54
|
+
expect { resource.action :reload }.not_to raise_error
|
55
|
+
expect { resource.action :reload_or_restart }.not_to raise_error
|
56
|
+
expect { resource.action :reload_or_try_restart }.not_to raise_error
|
57
|
+
expect { resource.action :restart }.not_to raise_error
|
58
|
+
expect { resource.action :revert }.not_to raise_error
|
56
59
|
expect { resource.action :start }.not_to raise_error
|
57
60
|
expect { resource.action :stop }.not_to raise_error
|
58
|
-
expect { resource.action :
|
59
|
-
expect { resource.action :
|
60
|
-
expect { resource.action :wrong }.to raise_error(ArgumentError)
|
61
|
+
expect { resource.action :try_restart }.not_to raise_error
|
62
|
+
expect { resource.action :unmask }.not_to raise_error
|
61
63
|
end
|
62
64
|
|
63
65
|
it "accepts boolean state properties" do
|
@@ -27,6 +27,25 @@ describe Chef::Resource::Template do
|
|
27
27
|
end
|
28
28
|
end
|
29
29
|
|
30
|
+
describe "name" do
|
31
|
+
it "the path property is the name_property" do
|
32
|
+
expect(resource.path).to eql("fakey_fakerton")
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
describe "Actions" do
|
37
|
+
it "sets the default action as :create" do
|
38
|
+
expect(resource.action).to eql([:create])
|
39
|
+
end
|
40
|
+
|
41
|
+
it "supports :create, :create_if_missing, :delete, :touch actions" do
|
42
|
+
expect { resource.action :create }.not_to raise_error
|
43
|
+
expect { resource.action :create_if_missing }.not_to raise_error
|
44
|
+
expect { resource.action :delete }.not_to raise_error
|
45
|
+
expect { resource.action :touch }.not_to raise_error
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
30
49
|
describe "source" do
|
31
50
|
it "accepts a string for the template source" do
|
32
51
|
resource.source "something"
|
@@ -24,21 +24,27 @@ describe Chef::Resource::WindowsAdJoin do
|
|
24
24
|
expect(resource.resource_name).to eql(:windows_ad_join)
|
25
25
|
end
|
26
26
|
|
27
|
-
it "
|
27
|
+
it "the domain_name property is the name_property" do
|
28
28
|
expect(resource.domain_name).to eql("example.com")
|
29
29
|
end
|
30
30
|
|
31
|
-
it "only accepts FQDNs for the domain_name property" do
|
32
|
-
expect { resource.domain_name "example" }.to raise_error(ArgumentError)
|
33
|
-
end
|
34
|
-
|
35
31
|
it "sets the default action as :join" do
|
36
32
|
expect(resource.action).to eql([:join])
|
37
33
|
end
|
38
34
|
|
39
|
-
it "
|
35
|
+
it "supports :join action" do
|
36
|
+
expect { resource.action :join }.not_to raise_error
|
37
|
+
end
|
38
|
+
|
39
|
+
it "only accepts FQDNs for the domain_name property" do
|
40
|
+
expect { resource.domain_name "example" }.to raise_error(ArgumentError)
|
41
|
+
end
|
42
|
+
|
43
|
+
it "accepts :immediate, :reboot_now, :request_reboot, :delayed, or :never values for 'reboot' property" do
|
40
44
|
expect { resource.reboot :immediate }.not_to raise_error
|
41
45
|
expect { resource.reboot :delayed }.not_to raise_error
|
46
|
+
expect { resource.reboot :reboot_now }.not_to raise_error
|
47
|
+
expect { resource.reboot :request_reboot }.not_to raise_error
|
42
48
|
expect { resource.reboot :never }.not_to raise_error
|
43
49
|
expect { resource.reboot :nopenope }.to raise_error(ArgumentError)
|
44
50
|
end
|
@@ -18,31 +18,31 @@
|
|
18
18
|
require "spec_helper"
|
19
19
|
|
20
20
|
describe Chef::Resource::WindowsAutorun do
|
21
|
-
let(:resource) { Chef::Resource::WindowsAutorun.new("
|
21
|
+
let(:resource) { Chef::Resource::WindowsAutorun.new("fakey_fakerton") }
|
22
22
|
|
23
23
|
it "sets resource name as :windows_auto_run" do
|
24
24
|
expect(resource.resource_name).to eql(:windows_auto_run)
|
25
25
|
end
|
26
26
|
|
27
|
+
it "the program_name property is the name_property" do
|
28
|
+
expect(resource.program_name).to eql("fakey_fakerton")
|
29
|
+
end
|
30
|
+
|
27
31
|
it "sets the default action as :create" do
|
28
32
|
expect(resource.action).to eql([:create])
|
29
33
|
end
|
30
34
|
|
31
|
-
it "
|
32
|
-
expect
|
35
|
+
it "supports :create, :remove actions" do
|
36
|
+
expect { resource.action :create }.not_to raise_error
|
37
|
+
expect { resource.action :remove }.not_to raise_error
|
33
38
|
end
|
39
|
+
|
34
40
|
it "supports :machine and :user in the root property" do
|
35
41
|
expect { resource.root :user }.not_to raise_error
|
36
42
|
expect { resource.root :machine }.not_to raise_error
|
37
43
|
expect { resource.root "user" }.to raise_error(ArgumentError)
|
38
44
|
end
|
39
45
|
|
40
|
-
it "supports :create and :remove actions" do
|
41
|
-
expect { resource.action :create }.not_to raise_error
|
42
|
-
expect { resource.action :remove }.not_to raise_error
|
43
|
-
expect { resource.action :delete }.to raise_error(ArgumentError)
|
44
|
-
end
|
45
|
-
|
46
46
|
it "coerces forward slashes to backslashes for the path" do
|
47
47
|
resource.path "C:/something.exe"
|
48
48
|
expect(resource.path).to eql('C:\\something.exe')
|
@@ -21,33 +21,25 @@ require "spec_helper"
|
|
21
21
|
|
22
22
|
describe Chef::Resource::WindowsEnv do
|
23
23
|
|
24
|
-
let(:resource) { Chef::Resource::WindowsEnv.new("
|
24
|
+
let(:resource) { Chef::Resource::WindowsEnv.new("fakey_fakerton") }
|
25
25
|
|
26
26
|
it "creates a new Chef::Resource::WindowsEnv" do
|
27
27
|
expect(resource).to be_a_kind_of(Chef::Resource)
|
28
28
|
expect(resource).to be_a_kind_of(Chef::Resource::WindowsEnv)
|
29
29
|
end
|
30
30
|
|
31
|
-
it "
|
32
|
-
expect(resource.
|
31
|
+
it "the key_name property is the name_property" do
|
32
|
+
expect(resource.key_name).to eql("fakey_fakerton")
|
33
33
|
end
|
34
34
|
|
35
|
-
it "
|
35
|
+
it "sets the default action as :create" do
|
36
36
|
expect(resource.action).to eql([:create])
|
37
37
|
end
|
38
38
|
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
else
|
44
|
-
expect { resource.action action }.not_to raise_error
|
45
|
-
end
|
46
|
-
end
|
47
|
-
end
|
48
|
-
|
49
|
-
it "uses the object name as the key_name by default" do
|
50
|
-
expect(resource.key_name).to eql("FOO")
|
39
|
+
it "supports :create, :delete, :modify actions" do
|
40
|
+
expect { resource.action :create }.not_to raise_error
|
41
|
+
expect { resource.action :delete }.not_to raise_error
|
42
|
+
expect { resource.action :modify }.not_to raise_error
|
51
43
|
end
|
52
44
|
|
53
45
|
it "accepts a string as the env value via 'value'" do
|
@@ -18,24 +18,43 @@
|
|
18
18
|
require "spec_helper"
|
19
19
|
|
20
20
|
describe Chef::Resource::WindowsFeature do
|
21
|
-
let(:resource) { Chef::Resource::WindowsFeature.new("
|
21
|
+
let(:resource) { Chef::Resource::WindowsFeature.new("fakey_fakerton") }
|
22
22
|
|
23
23
|
it "sets resource name as :windows_feature" do
|
24
24
|
expect(resource.resource_name).to eql(:windows_feature)
|
25
25
|
end
|
26
26
|
|
27
|
-
it "
|
28
|
-
expect(resource.
|
27
|
+
it "the feature_name property is the name_property" do
|
28
|
+
expect(resource.feature_name).to eql("fakey_fakerton")
|
29
29
|
end
|
30
30
|
|
31
|
-
it "sets the
|
32
|
-
expect(resource.
|
31
|
+
it "sets the default action as :install" do
|
32
|
+
expect(resource.action).to eql([:install])
|
33
33
|
end
|
34
34
|
|
35
|
-
it "supports :
|
35
|
+
it "supports :delete, :install, :remove actions" do
|
36
|
+
expect { resource.action :delete }.not_to raise_error
|
36
37
|
expect { resource.action :install }.not_to raise_error
|
37
38
|
expect { resource.action :remove }.not_to raise_error
|
38
|
-
expect { resource.action :delete }.not_to raise_error
|
39
|
-
expect { resource.action :update }.to raise_error(ArgumentError)
|
40
39
|
end
|
40
|
+
|
41
|
+
it "all property defaults to false" do
|
42
|
+
expect(resource.all).to eql(false)
|
43
|
+
end
|
44
|
+
|
45
|
+
it "management_tools property defaults to false" do
|
46
|
+
expect(resource.management_tools).to eql(false)
|
47
|
+
end
|
48
|
+
|
49
|
+
it "timeout property defaults to 600" do
|
50
|
+
expect(resource.timeout).to eql(600)
|
51
|
+
end
|
52
|
+
|
53
|
+
it "install_method accepts :windows_feature_dism, :windows_feature_powershell, and :windows_feature_servermanagercmd" do
|
54
|
+
expect { resource.install_method :windows_feature_dism }.not_to raise_error
|
55
|
+
expect { resource.install_method :windows_feature_powershell }.not_to raise_error
|
56
|
+
expect { resource.install_method :windows_feature_servermanagercmd }.not_to raise_error
|
57
|
+
expect { resource.install_method "windows_feature_servermanagercmd" }.to raise_error(ArgumentError)
|
58
|
+
end
|
59
|
+
|
41
60
|
end
|
@@ -18,7 +18,10 @@
|
|
18
18
|
require "spec_helper"
|
19
19
|
|
20
20
|
describe Chef::Resource::WindowsFeatureDism do
|
21
|
-
let(:
|
21
|
+
let(:node) { Chef::Node.new }
|
22
|
+
let(:events) { Chef::EventDispatch::Dispatcher.new }
|
23
|
+
let(:run_context) { Chef::RunContext.new(node, {}, events) }
|
24
|
+
let(:resource) { Chef::Resource::WindowsFeatureDism.new(%w{SNMP DHCP}, run_context) }
|
22
25
|
|
23
26
|
it "sets resource name as :windows_feature_dism" do
|
24
27
|
expect(resource.resource_name).to eql(:windows_feature_dism)
|
@@ -28,24 +31,42 @@ describe Chef::Resource::WindowsFeatureDism do
|
|
28
31
|
expect(resource.action).to eql([:install])
|
29
32
|
end
|
30
33
|
|
31
|
-
it "
|
34
|
+
it "the feature_name property is the name_property" do
|
35
|
+
node.automatic[:platform_version] = "6.2"
|
32
36
|
expect(resource.feature_name).to eql(%w{snmp dhcp})
|
33
37
|
end
|
34
38
|
|
35
|
-
it "
|
39
|
+
it "sets the default action as :install" do
|
40
|
+
expect(resource.action).to eql([:install])
|
41
|
+
end
|
42
|
+
|
43
|
+
it "supports :delete, :install, :remove actions" do
|
44
|
+
expect { resource.action :delete }.not_to raise_error
|
45
|
+
expect { resource.action :install }.not_to raise_error
|
46
|
+
expect { resource.action :remove }.not_to raise_error
|
47
|
+
end
|
48
|
+
|
49
|
+
it "coerces comma separated lists of features to a lowercase array on 2012+" do
|
50
|
+
node.automatic[:platform_version] = "6.2"
|
36
51
|
resource.feature_name "SNMP, DHCP"
|
37
52
|
expect(resource.feature_name).to eql(%w{snmp dhcp})
|
38
53
|
end
|
39
54
|
|
40
|
-
it "coerces a single feature as a String to a lowercase array" do
|
55
|
+
it "coerces a single feature as a String to a lowercase array on 2012+" do
|
56
|
+
node.automatic[:platform_version] = "6.2"
|
41
57
|
resource.feature_name "SNMP"
|
42
58
|
expect(resource.feature_name).to eql(["snmp"])
|
43
59
|
end
|
44
60
|
|
45
|
-
it "
|
46
|
-
|
47
|
-
|
48
|
-
expect
|
49
|
-
|
61
|
+
it "coerces comma separated lists of features to an array, but preserves case on < 2012" do
|
62
|
+
node.automatic[:platform_version] = "6.1"
|
63
|
+
resource.feature_name "SNMP, DHCP"
|
64
|
+
expect(resource.feature_name).to eql(%w{SNMP DHCP})
|
65
|
+
end
|
66
|
+
|
67
|
+
it "coerces a single feature as a String to an array, but preserves case on < 2012" do
|
68
|
+
node.automatic[:platform_version] = "6.1"
|
69
|
+
resource.feature_name "SNMP"
|
70
|
+
expect(resource.feature_name).to eql(["SNMP"])
|
50
71
|
end
|
51
72
|
end
|