7
from charmhelpers.contrib import bigdata
10
class TestDistConfig(unittest.TestCase):
12
Test that the ``dist.yaml`` settings were applied properly, such as users, groups, and dirs.
14
This is done as a remote test on the deployed unit rather than a regular
15
test under ``tests/`` because filling in the ``dist.yaml`` requires Juju
16
context (e.g., config).
20
cls.hadoop = bigdata.handlers.apache.HadoopBase()
22
def test_groups(self):
23
for name in self.hadoop.groups:
27
self.fail('Group {} is missing'.format(name))
30
for username, details in self.hadoop.users.items():
32
user = pwd.getpwnam(username)
34
self.fail('User {} is missing'.format(username))
35
for groupname in details['groups']:
37
group = grp.getgrnam(groupname)
39
self.fail('Group {} referenced by user {} does not exist'.format(
41
if group.gr_gid != user.pw_gid:
42
self.assertIn(username, group.gr_mem, 'User {} not in group {}'.format(
46
for name, details in self.hadoop.managed_dirs.items():
47
dirpath = details['path']
48
self.assertTrue(dirpath.isdir(), 'Dir {} is missing'.format(name))
50
owner = pwd.getpwuid(stat.st_uid).pw_name
51
group = grp.getgrgid(stat.st_gid).gr_name
52
perms = stat.st_mode & ~0o40000
53
self.assertEqual(owner, details.get('owner', 'root'),
54
'Dir {} ({}) has wrong owner: {}'.format(name, dirpath, owner))
55
self.assertEqual(group, details.get('group', 'root'),
56
'Dir {} ({}) has wrong group: {}'.format(name, dirpath, group))
57
self.assertEqual(perms, details.get('perms', 0o744),
58
'Dir {} ({}) has wrong perms: 0o{:o}'.format(name, dirpath, perms))
61
if __name__ == '__main__':