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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
|
if __FILE__ == $0
$:.unshift '..'
$:.unshift '../../lib'
$puppetbase = "../.."
end
require 'etc'
require 'puppet/type'
require 'puppettest'
require 'test/unit'
class TestGroup < Test::Unit::TestCase
include TestPuppet
p = Puppet::Type.type(:group).provide :fake, :parent => TestPuppet::FakeProvider do
@name = :fake
apimethods :ensure, :gid
def create
@ensure = :present
end
def delete
@ensure = :absent
end
def exists?
if defined? @ensure and @ensure == :present
true
else
false
end
end
end
FakeGroupProvider = p
@@fakeproviders[:group] = p
def setup
super
Puppet::Type.type(:group).defaultprovider = FakeGroupProvider
end
def teardown
Puppet.type(:group).clear
Puppet::Type.type(:group).defaultprovider = nil
super
end
def mkgroup(name, hash = {})
group = nil
hash[:name] = name
assert_nothing_raised {
group = Puppet.type(:group).create(hash)
}
return group
end
def groupnames
%x{groups}.chomp.split(/ /)
end
def groupids
Process.groups
end
def attrtest_ensure(group)
group[:ensure] = :absent
comp = newcomp("ensuretest", group)
assert_apply(comp)
assert_equal(:absent, group.provider.ensure, "Group is still present")
group[:ensure] = :present
assert_events([:group_created], comp)
assert_equal(:present, group.provider.ensure, "Group is absent")
group[:ensure] = :absent
trans = assert_events([:group_removed], comp)
assert_equal(:absent, group.provider.ensure, "Group is present")
assert_rollback_events(trans, [:group_created], "group")
assert_equal(:present, group.provider.ensure, "Group is absent")
end
# This is a bit odd, since we're not actually doing anything on the machine.
# Just make sure we can set the gid and that it will work correctly.
def attrtest_gid(group)
# Check the validation.
assert_nothing_raised {
group[:gid] = "15"
}
assert_equal(15, group.should(:gid),
"Did not convert gid to number")
comp = newcomp(group)
trans = assert_events([:group_modified], comp, "group")
assert_equal(15, group.provider.gid, "GID was not changed")
assert_nothing_raised {
group[:gid] = 16
}
assert_equal(16, group.should(:gid),
"Did not keep gid as number")
# Now switch to 16
trans = assert_events([:group_modified], comp, "group")
assert_equal(16, group.provider.gid, "GID was not changed")
# And then rollback
assert_rollback_events(trans, [:group_modified], "group")
assert_equal(15, group.provider.gid, "GID was not changed")
end
def test_owngroups
groupnames().each { |group|
gobj = nil
comp = nil
assert_nothing_raised {
gobj = Puppet.type(:group).create(
:name => group,
:check => [:gid]
)
}
# Set a fake gid
gobj.provider.gid = rand(100)
assert_nothing_raised {
gobj.retrieve
}
assert(gobj.is(:gid), "Failed to retrieve gid")
}
end
def test_mkgroup
gobj = nil
comp = nil
name = "pptestgr"
assert_nothing_raised {
gobj = Puppet.type(:group).create(
:name => name,
:ensure => :present
)
comp = newcomp("groupmaker %s" % name, gobj)
}
trans = assert_events([:group_created], comp, "group")
assert(gobj.provider.exists?,
"Did not create group")
tests = Puppet.type(:group).validstates
gobj.retrieve
tests.each { |test|
if self.respond_to?("attrtest_%s" % test)
self.send("attrtest_%s" % test, gobj)
else
#$stderr.puts "Not testing attr %s of group" % test
end
}
assert_rollback_events(trans, [:group_removed], "group")
assert(! gobj.provider.exists?,
"Did not delete group")
end
end
|