chef 12.17.44-universal-mingw32 → 12.18.31-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 +0 -1
- data/README.md +3 -2
- data/Rakefile +9 -0
- data/VERSION +1 -1
- data/acceptance/Gemfile.lock +17 -17
- data/distro/common/html/knife_environment.html +4 -8
- data/distro/common/man/man1/knife-environment.1 +4 -16
- data/distro/powershell/chef/chef.psm1 +139 -24
- data/lib/chef/application.rb +5 -4
- data/lib/chef/application/windows_service_manager.rb +6 -4
- data/lib/chef/chef_fs/chef_fs_data_store.rb +1 -1
- data/lib/chef/chef_fs/command_line.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/rest_list_entry.rb +8 -1
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/repository/nodes_dir.rb +1 -1
- data/lib/chef/cookbook/chefignore.rb +1 -1
- data/lib/chef/cookbook/cookbook_version_loader.rb +4 -4
- data/lib/chef/cookbook/metadata.rb +2 -2
- data/lib/chef/cookbook_loader.rb +1 -1
- data/lib/chef/data_collector.rb +24 -13
- data/lib/chef/data_collector/messages.rb +8 -6
- data/lib/chef/data_collector/messages/helpers.rb +1 -1
- data/lib/chef/deprecated.rb +30 -0
- data/lib/chef/dsl/platform_introspection.rb +2 -2
- data/lib/chef/encrypted_data_bag_item.rb +1 -1
- data/lib/chef/encrypted_data_bag_item/decryptor.rb +2 -2
- data/lib/chef/environment.rb +1 -1
- data/lib/chef/exceptions.rb +5 -5
- data/lib/chef/file_access_control/unix.rb +5 -5
- data/lib/chef/formatters/error_description.rb +1 -1
- data/lib/chef/http/basic_client.rb +1 -1
- data/lib/chef/http/json_input.rb +2 -2
- data/lib/chef/knife.rb +1 -1
- data/lib/chef/knife/cookbook_site_install.rb +1 -1
- data/lib/chef/knife/core/cookbook_scm_repo.rb +1 -1
- data/lib/chef/knife/core/ui.rb +1 -1
- data/lib/chef/mixin/command.rb +1 -0
- data/lib/chef/mixin/deep_merge.rb +1 -1
- data/lib/chef/mixin/shell_out.rb +58 -3
- data/lib/chef/mixin/which.rb +5 -9
- data/lib/chef/mixin/wide_string.rb +1 -1
- data/lib/chef/node.rb +1 -1
- data/lib/chef/node/attribute.rb +4 -5
- data/lib/chef/node_map.rb +18 -2
- data/lib/chef/platform/provider_handler_map.rb +2 -2
- data/lib/chef/platform/provider_mapping.rb +5 -0
- data/lib/chef/platform/resource_handler_map.rb +2 -2
- data/lib/chef/provider/env/windows.rb +1 -1
- data/lib/chef/provider/git.rb +1 -1
- data/lib/chef/provider/group.rb +41 -46
- data/lib/chef/provider/group/aix.rb +12 -19
- data/lib/chef/provider/group/dscl.rb +46 -43
- data/lib/chef/provider/group/gpasswd.rb +7 -7
- data/lib/chef/provider/group/groupadd.rb +29 -34
- data/lib/chef/provider/group/groupmod.rb +26 -31
- data/lib/chef/provider/group/pw.rb +28 -31
- data/lib/chef/provider/group/suse.rb +9 -9
- data/lib/chef/provider/group/usermod.rb +10 -11
- data/lib/chef/provider/group/windows.rb +18 -20
- data/lib/chef/provider/ifconfig.rb +52 -63
- data/lib/chef/provider/ifconfig/aix.rb +23 -28
- data/lib/chef/provider/ifconfig/debian.rb +23 -22
- data/lib/chef/provider/ifconfig/redhat.rb +12 -12
- data/lib/chef/provider/mount/mount.rb +1 -1
- data/lib/chef/provider/osx_profile.rb +4 -2
- data/lib/chef/provider/package.rb +16 -7
- data/lib/chef/provider/package/chocolatey.rb +3 -1
- data/lib/chef/provider/package/dnf.rb +183 -0
- data/lib/chef/provider/package/dnf/dnf_helper.py +91 -0
- data/lib/chef/provider/package/dnf/python_helper.rb +120 -0
- data/lib/chef/provider/package/dnf/version.rb +56 -0
- data/lib/chef/provider/package/easy_install.rb +1 -1
- data/lib/chef/provider/package/freebsd/base.rb +1 -1
- data/lib/chef/provider/package/freebsd/pkgng.rb +1 -1
- data/lib/chef/provider/package/powershell.rb +3 -3
- data/lib/chef/provider/package/windows.rb +1 -1
- data/lib/chef/provider/package/zypper.rb +1 -1
- data/lib/chef/provider/route.rb +186 -184
- data/lib/chef/provider/service/arch.rb +2 -2
- data/lib/chef/provider/service/freebsd.rb +1 -1
- data/lib/chef/provider/service/gentoo.rb +2 -2
- data/lib/chef/provider/service/insserv.rb +2 -2
- data/lib/chef/provider/service/macosx.rb +2 -2
- data/lib/chef/provider/service/openbsd.rb +1 -1
- data/lib/chef/provider/service/redhat.rb +2 -2
- data/lib/chef/provider/support/yum_repo.erb +10 -3
- data/lib/chef/provider/user.rb +17 -20
- data/lib/chef/provider/user/aix.rb +23 -24
- data/lib/chef/provider/user/dscl.rb +56 -53
- data/lib/chef/provider/user/linux.rb +13 -16
- data/lib/chef/provider/user/pw.rb +26 -30
- data/lib/chef/provider/user/solaris.rb +11 -12
- data/lib/chef/provider/user/useradd.rb +20 -22
- data/lib/chef/provider/user/windows.rb +19 -22
- data/lib/chef/provider_resolver.rb +4 -2
- data/lib/chef/providers.rb +1 -0
- data/lib/chef/resource.rb +7 -0
- data/lib/chef/resource/chocolatey_package.rb +1 -0
- data/lib/chef/resource/dnf_package.rb +64 -0
- data/lib/chef/resource/file/verification.rb +6 -4
- data/lib/chef/resource/yum_package.rb +18 -14
- data/lib/chef/resource/yum_repository.rb +1 -1
- data/lib/chef/resource_reporter.rb +11 -0
- data/lib/chef/resources.rb +1 -0
- data/lib/chef/scan_access_control.rb +4 -4
- data/lib/chef/util/dsc/resource_store.rb +1 -1
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/memory.rb +1 -1
- data/lib/chef/win32/security.rb +2 -2
- data/lib/chef/win32/security/sid.rb +2 -2
- data/spec/functional/assets/yumrepo/chef_rpm-1.10-1.fc24.i686.rpm +0 -0
- data/spec/functional/assets/yumrepo/chef_rpm-1.10-1.fc24.src.rpm +0 -0
- data/spec/functional/assets/yumrepo/chef_rpm-1.10-1.fc24.x86_64.rpm +0 -0
- data/spec/functional/assets/yumrepo/chef_rpm-1.2-1.fc24.i686.rpm +0 -0
- data/spec/functional/assets/yumrepo/chef_rpm-1.2-1.fc24.src.rpm +0 -0
- data/spec/functional/assets/yumrepo/chef_rpm-1.2-1.fc24.x86_64.rpm +0 -0
- data/spec/functional/assets/yumrepo/repodata/313329137b55fd333b2dc66394a6661a2befa6cc535d8460d92a4a78a9c581f0-primary.sqlite.bz2 +0 -0
- data/spec/functional/assets/yumrepo/repodata/31ac4db5d5ac593728fcc26aef82b7b93c4cc4dbec843786b1845b939b658553-other.xml.gz +0 -0
- data/spec/functional/assets/yumrepo/repodata/4ac40fa3c6728c1401318e2e20a997436624e83dcf7a5f952b851ef422637773-filelists.sqlite.bz2 +0 -0
- data/spec/functional/assets/yumrepo/repodata/66391e53f0510b98b3f0b79f40ba1048026d9a1ef20905d9c40ba6f5411f3243-primary.xml.gz +0 -0
- data/spec/functional/assets/yumrepo/repodata/8b34697595fcc87928e12d24644dda9462c3857bd932861e28bc77ae1f31be16-filelists.xml.gz +0 -0
- data/spec/functional/assets/yumrepo/repodata/b97cca3fe14bcf06c52be4449b6108f7731239ff221111dcce8aada5467f60dc-other.sqlite.bz2 +0 -0
- data/spec/functional/assets/yumrepo/repodata/repomd.xml +55 -0
- data/spec/functional/resource/dnf_package_spec.rb +686 -0
- data/spec/functional/resource/dsc_script_spec.rb +1 -0
- data/spec/functional/resource/user/useradd_spec.rb +10 -1
- data/spec/integration/knife/chef_repo_path_spec.rb +2 -2
- data/spec/integration/recipes/recipe_dsl_spec.rb +3 -0
- data/spec/integration/recipes/resource_load_spec.rb +3 -3
- data/spec/spec_helper.rb +5 -3
- data/spec/support/lib/chef/provider/snakeoil.rb +1 -0
- data/spec/support/lib/chef/resource/cat.rb +1 -0
- data/spec/support/lib/chef/resource/one_two_three_four.rb +1 -0
- data/spec/support/lib/chef/resource/openldap_includer.rb +2 -0
- data/spec/support/lib/chef/resource/with_state.rb +2 -0
- data/spec/support/lib/chef/resource/zen_master.rb +1 -0
- data/spec/unit/cookbook/metadata_spec.rb +3 -3
- data/spec/unit/data_collector/messages/helpers_spec.rb +7 -0
- data/spec/unit/data_collector_spec.rb +56 -0
- data/spec/unit/decorator/lazy_spec.rb +1 -1
- data/spec/unit/environment_spec.rb +1 -1
- data/spec/unit/lwrp_spec.rb +3 -4
- data/spec/unit/node_spec.rb +23 -2
- data/spec/unit/platform_spec.rb +1 -0
- data/spec/unit/provider/group/dscl_spec.rb +29 -29
- data/spec/unit/provider/group/gpasswd_spec.rb +10 -10
- data/spec/unit/provider/group/groupadd_spec.rb +31 -30
- data/spec/unit/provider/group/groupmod_spec.rb +16 -16
- data/spec/unit/provider/group/pw_spec.rb +11 -11
- data/spec/unit/provider/group/suse_spec.rb +5 -5
- data/spec/unit/provider/group/usermod_spec.rb +15 -15
- data/spec/unit/provider/ifconfig/aix_spec.rb +14 -14
- data/spec/unit/provider/ifconfig/debian_spec.rb +10 -22
- data/spec/unit/provider/ifconfig/redhat_spec.rb +4 -4
- data/spec/unit/provider/ifconfig_spec.rb +18 -19
- data/spec/unit/provider/package/chocolatey_spec.rb +21 -21
- data/spec/unit/provider/package/msu_spec.rb +1 -1
- data/spec/unit/provider/route_spec.rb +21 -21
- data/spec/unit/provider/user/dscl_spec.rb +54 -57
- data/spec/unit/provider/user/linux_spec.rb +5 -5
- data/spec/unit/provider/user/pw_spec.rb +26 -22
- data/spec/unit/provider/user/windows_spec.rb +4 -4
- data/spec/unit/provider/user_spec.rb +19 -21
- data/spec/unit/provider_resolver_spec.rb +1 -0
- data/spec/unit/resource/chocolatey_package_spec.rb +12 -0
- data/spec/unit/resource/dnf_package_spec.rb +99 -0
- data/spec/unit/resource/remote_file_spec.rb +2 -2
- data/spec/unit/resource/yum_package_spec.rb +20 -0
- data/spec/unit/resource_reporter_spec.rb +24 -0
- data/spec/unit/resource_spec.rb +2 -0
- data/spec/unit/runner_spec.rb +1 -0
- data/tasks/bin/bundle-platform +1 -1
- data/tasks/gemfile_util.rb +2 -2
- data/tasks/templates/prerelease.md.erb +1 -10
- data/tasks/templates/release.md.erb +1 -9
- metadata +24 -5
- data/lib/chef/platform/handler_map.rb +0 -40
@@ -27,11 +27,11 @@ describe Chef::Provider::Group::Gpasswd, "modify_group_members" do
|
|
27
27
|
@new_resource.members %w{lobster rage fist}
|
28
28
|
@new_resource.append false
|
29
29
|
@provider = Chef::Provider::Group::Gpasswd.new(@new_resource, @run_context)
|
30
|
-
|
30
|
+
# @provider.stub(:run_command).and_return(true)
|
31
31
|
end
|
32
32
|
|
33
33
|
describe "when determining the current group state" do
|
34
|
-
before
|
34
|
+
before(:each) do
|
35
35
|
@provider.action = :create
|
36
36
|
@provider.load_current_resource
|
37
37
|
@provider.define_resource_requirements
|
@@ -41,13 +41,13 @@ describe Chef::Provider::Group::Gpasswd, "modify_group_members" do
|
|
41
41
|
# for Chef::Provider::Group - no need to repeat it here. We'll
|
42
42
|
# include only what's specific to this provider.
|
43
43
|
it "should raise an error if the required binary /usr/bin/gpasswd doesn't exist" do
|
44
|
-
allow(File).to receive(:
|
45
|
-
expect(File).to receive(:
|
44
|
+
allow(File).to receive(:exist?).and_return(true)
|
45
|
+
expect(File).to receive(:exist?).with("/usr/bin/gpasswd").and_return(false)
|
46
46
|
expect { @provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Group)
|
47
47
|
end
|
48
48
|
|
49
49
|
it "shouldn't raise an error if the required binaries exist" do
|
50
|
-
allow(File).to receive(:
|
50
|
+
allow(File).to receive(:exist?).and_return(true)
|
51
51
|
expect { @provider.process_resource_requirements }.not_to raise_error
|
52
52
|
end
|
53
53
|
end
|
@@ -66,7 +66,7 @@ describe Chef::Provider::Group::Gpasswd, "modify_group_members" do
|
|
66
66
|
|
67
67
|
it "logs a message and sets group's members to 'none'" do
|
68
68
|
expect(Chef::Log).to receive(:debug).with("group[wheel] setting group members to: none")
|
69
|
-
expect(@provider).to receive(:shell_out!).with("gpasswd -M
|
69
|
+
expect(@provider).to receive(:shell_out!).with("gpasswd", "-M", "", "wheel")
|
70
70
|
@provider.modify_group_members
|
71
71
|
end
|
72
72
|
end
|
@@ -91,7 +91,7 @@ describe Chef::Provider::Group::Gpasswd, "modify_group_members" do
|
|
91
91
|
end
|
92
92
|
|
93
93
|
it "should run gpasswd with the members joined by ',' followed by the target group" do
|
94
|
-
expect(@provider).to receive(:shell_out!).with("gpasswd -M lobster,rage,fist wheel")
|
94
|
+
expect(@provider).to receive(:shell_out!).with("gpasswd", "-M", "lobster,rage,fist", "wheel")
|
95
95
|
@provider.modify_group_members
|
96
96
|
end
|
97
97
|
|
@@ -104,9 +104,9 @@ describe Chef::Provider::Group::Gpasswd, "modify_group_members" do
|
|
104
104
|
|
105
105
|
it "should run gpasswd individually for each user when the append option is set" do
|
106
106
|
@new_resource.append(true)
|
107
|
-
expect(@provider).to receive(:shell_out!).with("gpasswd -a lobster wheel")
|
108
|
-
expect(@provider).to receive(:shell_out!).with("gpasswd -a rage wheel")
|
109
|
-
expect(@provider).to receive(:shell_out!).with("gpasswd -a fist wheel")
|
107
|
+
expect(@provider).to receive(:shell_out!).with("gpasswd", "-a", "lobster", "wheel")
|
108
|
+
expect(@provider).to receive(:shell_out!).with("gpasswd", "-a", "rage", "wheel")
|
109
|
+
expect(@provider).to receive(:shell_out!).with("gpasswd", "-a", "fist", "wheel")
|
110
110
|
@provider.modify_group_members
|
111
111
|
end
|
112
112
|
end
|
@@ -46,7 +46,7 @@ describe Chef::Provider::Group::Groupadd do
|
|
46
46
|
|
47
47
|
describe "#set_options" do
|
48
48
|
field_list = {
|
49
|
-
:
|
49
|
+
gid: "-g",
|
50
50
|
}
|
51
51
|
|
52
52
|
field_list.each do |attribute, option|
|
@@ -58,36 +58,37 @@ describe Chef::Provider::Group::Groupadd do
|
|
58
58
|
|
59
59
|
it "should set the option for #{attribute} if the new resources #{attribute} is not null" do
|
60
60
|
allow(new_resource).to receive(attribute).and_return("wowaweea")
|
61
|
-
expect(provider.set_options).to eql(
|
61
|
+
expect(provider.set_options).to eql([ option, new_resource.send(attribute), new_resource.group_name])
|
62
62
|
end
|
63
63
|
end
|
64
64
|
|
65
65
|
it "should combine all the possible options" do
|
66
|
-
|
66
|
+
match_array = []
|
67
67
|
field_list.sort { |a, b| a[0] <=> b[0] }.each do |attribute, option|
|
68
68
|
allow(new_resource).to receive(attribute).and_return("hola")
|
69
|
-
|
69
|
+
match_array << option
|
70
|
+
match_array << "hola"
|
70
71
|
end
|
71
|
-
|
72
|
-
expect(provider.set_options).to eql(
|
72
|
+
match_array << "aj"
|
73
|
+
expect(provider.set_options).to eql(match_array)
|
73
74
|
end
|
74
75
|
|
75
76
|
describe "when we want to create a system group" do
|
76
77
|
it "should not set groupadd_options '-r' when system is false" do
|
77
78
|
new_resource.system(false)
|
78
|
-
expect(provider.groupadd_options).
|
79
|
+
expect(provider.groupadd_options).to eq([])
|
79
80
|
end
|
80
81
|
|
81
82
|
it "should set groupadd -r if system is true" do
|
82
83
|
new_resource.system(true)
|
83
|
-
expect(provider.groupadd_options).to eq("
|
84
|
+
expect(provider.groupadd_options).to eq(["-r"])
|
84
85
|
end
|
85
86
|
|
86
87
|
context "on Solaris" do
|
87
88
|
before { node.automatic["platform"] = "solaris2" }
|
88
89
|
it "should not set groupadd -r if system is true" do
|
89
90
|
new_resource.system(true)
|
90
|
-
expect(provider.groupadd_options).
|
91
|
+
expect(provider.groupadd_options).to eql([])
|
91
92
|
end
|
92
93
|
end
|
93
94
|
end
|
@@ -95,26 +96,26 @@ describe Chef::Provider::Group::Groupadd do
|
|
95
96
|
describe "when we want to create a non_unique gid group" do
|
96
97
|
it "should not set groupadd_options '-o' when non_unique is false" do
|
97
98
|
new_resource.non_unique(false)
|
98
|
-
expect(provider.groupadd_options).
|
99
|
+
expect(provider.groupadd_options).to eq([])
|
99
100
|
end
|
100
101
|
|
101
102
|
it "should set groupadd -o if non_unique is true" do
|
102
103
|
new_resource.non_unique(true)
|
103
|
-
expect(provider.groupadd_options).to eq("
|
104
|
+
expect(provider.groupadd_options).to eq(["-o"])
|
104
105
|
end
|
105
106
|
end
|
106
107
|
end
|
107
108
|
|
108
109
|
describe "#create_group" do
|
109
110
|
before do
|
110
|
-
allow(provider).to receive(:
|
111
|
-
allow(provider).to receive(:set_options).and_return("
|
112
|
-
allow(provider).to receive(:groupadd_options).and_return(
|
111
|
+
allow(provider).to receive(:shell_out!).and_return(true)
|
112
|
+
allow(provider).to receive(:set_options).and_return("monkey")
|
113
|
+
allow(provider).to receive(:groupadd_options).and_return([])
|
113
114
|
allow(provider).to receive(:modify_group_members).and_return(true)
|
114
115
|
end
|
115
116
|
|
116
117
|
it "should run groupadd with the return of set_options" do
|
117
|
-
expect(provider).to receive(:
|
118
|
+
expect(provider).to receive(:shell_out!).with("groupadd", "monkey").and_return(true)
|
118
119
|
provider.create_group
|
119
120
|
end
|
120
121
|
|
@@ -126,13 +127,13 @@ describe Chef::Provider::Group::Groupadd do
|
|
126
127
|
|
127
128
|
describe "#manage_group" do
|
128
129
|
before do
|
129
|
-
allow(provider).to receive(:
|
130
|
-
allow(provider).to receive(:set_options).and_return("
|
130
|
+
allow(provider).to receive(:shell_out!).and_return(true)
|
131
|
+
allow(provider).to receive(:set_options).and_return("monkey")
|
131
132
|
end
|
132
133
|
|
133
134
|
it "should run groupmod with the return of set_options" do
|
134
135
|
allow(provider).to receive(:modify_group_members).and_return(true)
|
135
|
-
expect(provider).to receive(:
|
136
|
+
expect(provider).to receive(:shell_out!).with("groupmod", "monkey").and_return(true)
|
136
137
|
provider.manage_group
|
137
138
|
end
|
138
139
|
|
@@ -144,12 +145,12 @@ describe Chef::Provider::Group::Groupadd do
|
|
144
145
|
|
145
146
|
describe "#remove_group" do
|
146
147
|
before do
|
147
|
-
allow(provider).to receive(:
|
148
|
-
allow(provider).to receive(:set_options).and_return("
|
148
|
+
allow(provider).to receive(:shell_out!).and_return(true)
|
149
|
+
allow(provider).to receive(:set_options).and_return("monkey")
|
149
150
|
end
|
150
151
|
|
151
152
|
it "should run groupdel with the new resources group name" do
|
152
|
-
expect(provider).to receive(:
|
153
|
+
expect(provider).to receive(:shell_out!).with("groupdel", "aj").and_return(true)
|
153
154
|
provider.remove_group
|
154
155
|
end
|
155
156
|
end
|
@@ -162,30 +163,30 @@ describe Chef::Provider::Group::Groupadd do
|
|
162
163
|
|
163
164
|
describe "#load_current_resource" do
|
164
165
|
before do
|
165
|
-
allow(provider).to receive(:
|
166
|
-
allow(provider).to receive(:set_options).and_return("
|
166
|
+
allow(provider).to receive(:shell_out!).and_return(true)
|
167
|
+
allow(provider).to receive(:set_options).and_return("monkey")
|
167
168
|
end
|
168
169
|
|
169
170
|
before do
|
170
|
-
allow(File).to receive(:
|
171
|
+
allow(File).to receive(:exist?).and_return(false)
|
171
172
|
provider.define_resource_requirements
|
172
173
|
end
|
173
174
|
|
174
175
|
it "should raise an error if the required binary /usr/sbin/groupadd doesn't exist" do
|
175
|
-
expect(File).to receive(:
|
176
|
+
expect(File).to receive(:exist?).with("/usr/sbin/groupadd").and_return(false)
|
176
177
|
expect { provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Group)
|
177
178
|
end
|
178
179
|
|
179
180
|
it "should raise an error if the required binary /usr/sbin/groupmod doesn't exist" do
|
180
|
-
expect(File).to receive(:
|
181
|
-
expect(File).to receive(:
|
181
|
+
expect(File).to receive(:exist?).with("/usr/sbin/groupadd").and_return(true)
|
182
|
+
expect(File).to receive(:exist?).with("/usr/sbin/groupmod").and_return(false)
|
182
183
|
expect { provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Group)
|
183
184
|
end
|
184
185
|
|
185
186
|
it "should raise an error if the required binary /usr/sbin/groupdel doesn't exist" do
|
186
|
-
expect(File).to receive(:
|
187
|
-
expect(File).to receive(:
|
188
|
-
expect(File).to receive(:
|
187
|
+
expect(File).to receive(:exist?).with("/usr/sbin/groupadd").and_return(true)
|
188
|
+
expect(File).to receive(:exist?).with("/usr/sbin/groupmod").and_return(true)
|
189
|
+
expect(File).to receive(:exist?).with("/usr/sbin/groupdel").and_return(false)
|
189
190
|
expect { provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Group)
|
190
191
|
end
|
191
192
|
|
@@ -33,17 +33,17 @@ describe Chef::Provider::Group::Groupmod do
|
|
33
33
|
describe "manage_group" do
|
34
34
|
describe "when determining the current group state" do
|
35
35
|
it "should raise an error if the required binary /usr/sbin/group doesn't exist" do
|
36
|
-
expect(File).to receive(:
|
36
|
+
expect(File).to receive(:exist?).with("/usr/sbin/group").and_return(false)
|
37
37
|
expect { @provider.load_current_resource }.to raise_error(Chef::Exceptions::Group)
|
38
38
|
end
|
39
39
|
it "should raise an error if the required binary /usr/sbin/user doesn't exist" do
|
40
|
-
expect(File).to receive(:
|
41
|
-
expect(File).to receive(:
|
40
|
+
expect(File).to receive(:exist?).with("/usr/sbin/group").and_return(true)
|
41
|
+
expect(File).to receive(:exist?).with("/usr/sbin/user").and_return(false)
|
42
42
|
expect { @provider.load_current_resource }.to raise_error(Chef::Exceptions::Group)
|
43
43
|
end
|
44
44
|
|
45
45
|
it "shouldn't raise an error if the required binaries exist" do
|
46
|
-
allow(File).to receive(:
|
46
|
+
allow(File).to receive(:exist?).and_return(true)
|
47
47
|
expect { @provider.load_current_resource }.not_to raise_error
|
48
48
|
end
|
49
49
|
end
|
@@ -62,9 +62,9 @@ describe Chef::Provider::Group::Groupmod do
|
|
62
62
|
|
63
63
|
it "logs a message and sets group's members to 'none', then removes existing group members" do
|
64
64
|
expect(Chef::Log).to receive(:debug).with("group[wheel] setting group members to: none")
|
65
|
-
expect(@provider).to receive(:shell_out!).with("group mod -n wheel_bak wheel")
|
66
|
-
expect(@provider).to receive(:shell_out!).with("group add -g
|
67
|
-
expect(@provider).to receive(:shell_out!).with("group del wheel_bak")
|
65
|
+
expect(@provider).to receive(:shell_out!).with("group", "mod", "-n", "wheel_bak", "wheel")
|
66
|
+
expect(@provider).to receive(:shell_out!).with("group", "add", "-g", "123", "-o", "wheel")
|
67
|
+
expect(@provider).to receive(:shell_out!).with("group", "del", "wheel_bak")
|
68
68
|
@provider.manage_group
|
69
69
|
end
|
70
70
|
end
|
@@ -90,10 +90,10 @@ describe Chef::Provider::Group::Groupmod do
|
|
90
90
|
|
91
91
|
it "updates group membership correctly" do
|
92
92
|
allow(Chef::Log).to receive(:debug)
|
93
|
-
expect(@provider).to receive(:shell_out!).with("group mod -n wheel_bak wheel")
|
94
|
-
expect(@provider).to receive(:shell_out!).with("user mod -G wheel lobster")
|
95
|
-
expect(@provider).to receive(:shell_out!).with("group add -g
|
96
|
-
expect(@provider).to receive(:shell_out!).with("group del wheel_bak")
|
93
|
+
expect(@provider).to receive(:shell_out!).with("group", "mod", "-n", "wheel_bak", "wheel")
|
94
|
+
expect(@provider).to receive(:shell_out!).with("user", "mod", "-G", "wheel", "lobster")
|
95
|
+
expect(@provider).to receive(:shell_out!).with("group", "add", "-g", "123", "-o", "wheel")
|
96
|
+
expect(@provider).to receive(:shell_out!).with("group", "del", "wheel_bak")
|
97
97
|
@provider.manage_group
|
98
98
|
end
|
99
99
|
end
|
@@ -108,10 +108,10 @@ describe Chef::Provider::Group::Groupmod do
|
|
108
108
|
end
|
109
109
|
|
110
110
|
it "should run a group add command and some user mod commands" do
|
111
|
-
expect(@provider).to receive(:shell_out!).with("group add -g
|
112
|
-
expect(@provider).to receive(:shell_out!).with("user mod -G wheel lobster")
|
113
|
-
expect(@provider).to receive(:shell_out!).with("user mod -G wheel rage")
|
114
|
-
expect(@provider).to receive(:shell_out!).with("user mod -G wheel fist")
|
111
|
+
expect(@provider).to receive(:shell_out!).with("group", "add", "-g", "123", "wheel")
|
112
|
+
expect(@provider).to receive(:shell_out!).with("user", "mod", "-G", "wheel", "lobster")
|
113
|
+
expect(@provider).to receive(:shell_out!).with("user", "mod", "-G", "wheel", "rage")
|
114
|
+
expect(@provider).to receive(:shell_out!).with("user", "mod", "-G", "wheel", "fist")
|
115
115
|
@provider.create_group
|
116
116
|
end
|
117
117
|
end
|
@@ -125,7 +125,7 @@ describe Chef::Provider::Group::Groupmod do
|
|
125
125
|
end
|
126
126
|
|
127
127
|
it "should run a group del command" do
|
128
|
-
expect(@provider).to receive(:shell_out!).with("group del wheel")
|
128
|
+
expect(@provider).to receive(:shell_out!).with("group", "del", "wheel")
|
129
129
|
@provider.remove_group
|
130
130
|
end
|
131
131
|
end
|
@@ -37,19 +37,19 @@ describe Chef::Provider::Group::Pw do
|
|
37
37
|
|
38
38
|
describe "when setting options for the pw command" do
|
39
39
|
it "does not set the gid option if gids match or are unmanaged" do
|
40
|
-
expect(@provider.set_options).to eq("
|
40
|
+
expect(@provider.set_options).to eq(["wheel"])
|
41
41
|
end
|
42
42
|
|
43
43
|
it "sets the option for gid if it is not nil" do
|
44
44
|
@new_resource.gid(42)
|
45
|
-
expect(@provider.set_options).to eql("
|
45
|
+
expect(@provider.set_options).to eql(["wheel", "-g", 42])
|
46
46
|
end
|
47
47
|
end
|
48
48
|
|
49
49
|
describe "when creating a group" do
|
50
50
|
it "should run pw groupadd with the return of set_options and set_members_option" do
|
51
51
|
@new_resource.gid(23)
|
52
|
-
expect(@provider).to receive(:
|
52
|
+
expect(@provider).to receive(:shell_out!).with("pw", "groupadd", "wheel", "-g", "23", "-M", "root,aj").and_return(true)
|
53
53
|
@provider.create_group
|
54
54
|
end
|
55
55
|
end
|
@@ -59,8 +59,8 @@ describe Chef::Provider::Group::Pw do
|
|
59
59
|
it "should run pw groupmod with the return of set_options" do
|
60
60
|
@new_resource.gid(42)
|
61
61
|
@new_resource.members(["someone"])
|
62
|
-
expect(@provider).to receive(:
|
63
|
-
expect(@provider).to receive(:
|
62
|
+
expect(@provider).to receive(:shell_out!).with("pw", "groupmod", "wheel", "-g", "42", "-m", "someone").and_return(true)
|
63
|
+
expect(@provider).to receive(:shell_out!).with("pw", "groupmod", "wheel", "-g", "42", "-d", "root,aj").and_return(true)
|
64
64
|
@provider.manage_group
|
65
65
|
end
|
66
66
|
|
@@ -68,7 +68,7 @@ describe Chef::Provider::Group::Pw do
|
|
68
68
|
|
69
69
|
describe "when removing the group" do
|
70
70
|
it "should run pw groupdel with the new resources group name" do
|
71
|
-
expect(@provider).to receive(:
|
71
|
+
expect(@provider).to receive(:shell_out!).with("pw", "groupdel", "wheel").and_return(true)
|
72
72
|
@provider.remove_group
|
73
73
|
end
|
74
74
|
end
|
@@ -98,7 +98,7 @@ describe Chef::Provider::Group::Pw do
|
|
98
98
|
end
|
99
99
|
|
100
100
|
it "should set the -d option with the members joined by ','" do
|
101
|
-
expect(@provider.set_members_options).to eql([ "
|
101
|
+
expect(@provider.set_members_options).to eql([ ["-d", "all,your,base"] ])
|
102
102
|
end
|
103
103
|
end
|
104
104
|
|
@@ -114,24 +114,24 @@ describe Chef::Provider::Group::Pw do
|
|
114
114
|
end
|
115
115
|
|
116
116
|
it "should set the -m option with the members joined by ','" do
|
117
|
-
expect(@provider.set_members_options).to eql([ "
|
117
|
+
expect(@provider.set_members_options).to eql([[ "-m", "all,your,base" ]])
|
118
118
|
end
|
119
119
|
end
|
120
120
|
end
|
121
121
|
|
122
122
|
describe "load_current_resource" do
|
123
|
-
before
|
123
|
+
before(:each) do
|
124
124
|
@provider.action = :create
|
125
125
|
@provider.load_current_resource
|
126
126
|
@provider.define_resource_requirements
|
127
127
|
end
|
128
128
|
it "should raise an error if the required binary /usr/sbin/pw doesn't exist" do
|
129
|
-
expect(File).to receive(:
|
129
|
+
expect(File).to receive(:exist?).with("/usr/sbin/pw").and_return(false)
|
130
130
|
expect { @provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Group)
|
131
131
|
end
|
132
132
|
|
133
133
|
it "shouldn't raise an error if /usr/sbin/pw exists" do
|
134
|
-
allow(File).to receive(:
|
134
|
+
allow(File).to receive(:exist?).and_return(true)
|
135
135
|
expect { @provider.process_resource_requirements }.not_to raise_error
|
136
136
|
end
|
137
137
|
end
|
@@ -7,7 +7,7 @@
|
|
7
7
|
# you may not use this file except in compliance with the License.
|
8
8
|
# You may obtain a copy of the License at
|
9
9
|
#
|
10
|
-
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
11
|
#
|
12
12
|
# Unless required by applicable law or agreed to in writing, software
|
13
13
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
@@ -47,7 +47,7 @@ describe Chef::Provider::Group::Suse do
|
|
47
47
|
|
48
48
|
describe "when determining the current group state" do
|
49
49
|
before(:each) do
|
50
|
-
allow(File).to receive(:
|
50
|
+
allow(File).to receive(:exist?).and_return(true)
|
51
51
|
provider.action = :create
|
52
52
|
provider.define_resource_requirements
|
53
53
|
end
|
@@ -56,7 +56,7 @@ describe Chef::Provider::Group::Suse do
|
|
56
56
|
# for Chef::Provider::Group - no need to repeat it here. We'll
|
57
57
|
# include only what's specific to this provider.
|
58
58
|
it "should raise an error if the required binary /usr/sbin/groupmod doesn't exist" do
|
59
|
-
expect(File).to receive(:
|
59
|
+
expect(File).to receive(:exist?).with("/usr/sbin/groupmod").and_return(false)
|
60
60
|
expect { provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Group)
|
61
61
|
end
|
62
62
|
|
@@ -76,14 +76,14 @@ describe Chef::Provider::Group::Suse do
|
|
76
76
|
|
77
77
|
describe "#add_member" do
|
78
78
|
it "should call out to groupmod to add user" do
|
79
|
-
expect(provider).to receive(:shell_out!).with("groupmod -A new_user new_group")
|
79
|
+
expect(provider).to receive(:shell_out!).with("groupmod", "-A", "new_user", "new_group")
|
80
80
|
provider.add_member("new_user")
|
81
81
|
end
|
82
82
|
end
|
83
83
|
|
84
84
|
describe "#remove_member" do
|
85
85
|
it "should call out to groupmod to remove user" do
|
86
|
-
expect(provider).to receive(:shell_out!).with("groupmod -R new_user new_group")
|
86
|
+
expect(provider).to receive(:shell_out!).with("groupmod", "-R", "new_user", "new_group")
|
87
87
|
provider.remove_member("new_user")
|
88
88
|
end
|
89
89
|
end
|
@@ -46,18 +46,18 @@ describe Chef::Provider::Group::Usermod do
|
|
46
46
|
|
47
47
|
describe "with supplied members" do
|
48
48
|
platforms = {
|
49
|
-
"openbsd" => "-G",
|
50
|
-
"netbsd" => "-G",
|
51
|
-
"solaris" => "-a -G",
|
52
|
-
"suse" => "-a -G",
|
53
|
-
"opensuse" => "-a -G",
|
54
|
-
"smartos" => "-G",
|
55
|
-
"omnios" => "-G",
|
49
|
+
"openbsd" => [ "-G" ],
|
50
|
+
"netbsd" => [ "-G" ],
|
51
|
+
"solaris" => [ "-a", "-G" ],
|
52
|
+
"suse" => [ "-a", "-G" ],
|
53
|
+
"opensuse" => [ "-a", "-G" ],
|
54
|
+
"smartos" => [ "-G" ],
|
55
|
+
"omnios" => [ "-G" ],
|
56
56
|
}
|
57
57
|
|
58
58
|
before do
|
59
59
|
allow(@new_resource).to receive(:members).and_return(%w{all your base})
|
60
|
-
allow(File).to receive(:
|
60
|
+
allow(File).to receive(:exist?).and_return(true)
|
61
61
|
end
|
62
62
|
|
63
63
|
it "should raise an error when setting the entire group directly" do
|
@@ -85,9 +85,9 @@ describe Chef::Provider::Group::Usermod do
|
|
85
85
|
@provider.current_resource = current_resource
|
86
86
|
@node.automatic_attrs[:platform] = platform
|
87
87
|
allow(@new_resource).to receive(:append).and_return(true)
|
88
|
-
expect(@provider).to receive(:shell_out!).with("usermod
|
89
|
-
expect(@provider).to receive(:shell_out!).with("usermod
|
90
|
-
expect(@provider).to receive(:shell_out!).with("usermod
|
88
|
+
expect(@provider).to receive(:shell_out!).with("usermod", *flags, "wheel", "all")
|
89
|
+
expect(@provider).to receive(:shell_out!).with("usermod", *flags, "wheel", "your")
|
90
|
+
expect(@provider).to receive(:shell_out!).with("usermod", *flags, "wheel", "base")
|
91
91
|
@provider.modify_group_members
|
92
92
|
end
|
93
93
|
end
|
@@ -96,19 +96,19 @@ describe Chef::Provider::Group::Usermod do
|
|
96
96
|
|
97
97
|
describe "when loading the current resource" do
|
98
98
|
before(:each) do
|
99
|
-
allow(File).to receive(:
|
99
|
+
allow(File).to receive(:exist?).and_return(false)
|
100
100
|
@provider.action = :create
|
101
101
|
@provider.define_resource_requirements
|
102
102
|
end
|
103
103
|
|
104
104
|
it "should raise an error if the required binary /usr/sbin/usermod doesn't exist" do
|
105
|
-
allow(File).to receive(:
|
106
|
-
expect(File).to receive(:
|
105
|
+
allow(File).to receive(:exist?).and_return(true)
|
106
|
+
expect(File).to receive(:exist?).with("/usr/sbin/usermod").and_return(false)
|
107
107
|
expect { @provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Group)
|
108
108
|
end
|
109
109
|
|
110
110
|
it "shouldn't raise an error if the required binaries exist" do
|
111
|
-
allow(File).to receive(:
|
111
|
+
allow(File).to receive(:exist?).and_return(true)
|
112
112
|
expect { @provider.process_resource_requirements }.not_to raise_error
|
113
113
|
end
|
114
114
|
end
|