1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
#
# Copyright:: Copyright (c) Chef Software Inc.
# License:: Apache License, Version 2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
require "spec_helper"
require "chef/mixin/shell_out"
metadata = {
requires_root: true,
linux_only: true,
}
describe "Chef::Resource::User with Chef::Provider::User::LinuxUser provider", metadata do
include Chef::Mixin::ShellOut
def clean_user
shell_out!("/usr/sbin/userdel #{username}")
rescue Mixlib::ShellOut::ShellCommandFailed
# Raised when the user is already cleaned
end
def ensure_file_cache_path_exists
path = Chef::Config["file_cache_path"]
FileUtils.mkdir_p(path) unless File.directory?(path)
end
def user_should_exist
expect(shell_out("grep -q #{username} /etc/passwd").error?).to be(false)
end
def check_password(pass, user)
expect(shell_out("grep ^#{user}: /etc/shadow | cut -d: -f2 | grep ^#{pass}$").exitstatus).to eq(0)
end
let(:node) do
n = Chef::Node.new
n.consume_external_attrs(OHAI_SYSTEM.data.dup, {})
n
end
let(:events) do
Chef::EventDispatch::Dispatcher.new
end
let(:run_context) do
Chef::RunContext.new(node, {}, events)
end
let(:username) do
"greatchef"
end
let(:uid) { nil }
let(:gid) do
# SLES 15 doesn't have the "20" group and
# so lets just pick the last group... no,
# Etc.group.map(&:gid).last does not work
Etc.enum_for(:group).map(&:gid).last
end
let(:home) { nil }
let(:manage_home) { false }
let(:password) { "XXXYYYZZZ" }
let(:comment) { "Great Chef" }
let(:shell) { "/bin/bash" }
let(:salt) { nil }
let(:user_resource) do
r = Chef::Resource::User::LinuxUser.new("TEST USER RESOURCE", run_context)
r.username(username)
r.uid(uid)
r.gid(gid)
r.home(home)
r.shell(shell)
r.comment(comment)
r.manage_home(manage_home)
r.password(password)
r.salt(salt)
r
end
before do
clean_user
ensure_file_cache_path_exists
end
after(:each) do
clean_user
end
describe "action :create" do
it "should create the user" do
user_resource.run_action(:create)
user_should_exist
check_password(password, username)
end
end
describe "when user exists" do
before do
existing_resource = user_resource.dup
existing_resource.run_action(:create)
user_should_exist
end
describe "when password is updated" do
it "should update the password of the user" do
user_resource.password("mykitchen")
user_resource.run_action(:create)
check_password("mykitchen", username)
end
end
end
end
|