2014-03-18 19:02:20 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
'''
|
|
|
|
:codeauthor: :email:`Nicole Thomas <nicole@saltstack.com>`
|
|
|
|
'''
|
|
|
|
|
|
|
|
# Import Python Libs
|
2014-11-21 19:05:13 +00:00
|
|
|
from __future__ import absolute_import
|
2014-03-18 19:02:20 +00:00
|
|
|
import random
|
|
|
|
import string
|
|
|
|
|
|
|
|
# Import Salt Testing Libs
|
2017-04-03 16:04:09 +00:00
|
|
|
from tests.support.case import ModuleCase
|
2017-04-04 17:57:27 +00:00
|
|
|
from tests.support.helpers import destructiveTest, skip_if_not_root
|
2014-03-18 19:02:20 +00:00
|
|
|
|
|
|
|
# Import Salt Libs
|
|
|
|
from salt.exceptions import CommandExecutionError
|
|
|
|
|
2014-11-22 11:11:41 +00:00
|
|
|
# Import 3rd-party libs
|
|
|
|
from salt.ext.six.moves import range # pylint: disable=import-error,redefined-builtin
|
|
|
|
|
2014-03-18 19:02:20 +00:00
|
|
|
|
|
|
|
def __random_string(size=6):
|
|
|
|
'''
|
|
|
|
Generates a random username
|
|
|
|
'''
|
|
|
|
return 'RS-' + ''.join(
|
|
|
|
random.choice(string.ascii_uppercase + string.digits)
|
|
|
|
for x in range(size)
|
|
|
|
)
|
|
|
|
|
|
|
|
# Create group name strings for tests
|
|
|
|
ADD_GROUP = __random_string()
|
2014-03-18 20:34:36 +00:00
|
|
|
DEL_GROUP = __random_string()
|
|
|
|
CHANGE_GROUP = __random_string()
|
2016-03-10 23:18:08 +00:00
|
|
|
ADD_USER = __random_string()
|
|
|
|
REP_USER_GROUP = __random_string()
|
2014-03-18 19:02:20 +00:00
|
|
|
|
2016-03-21 20:18:29 +00:00
|
|
|
|
2017-03-29 18:15:15 +00:00
|
|
|
@destructiveTest
|
2017-04-04 17:57:27 +00:00
|
|
|
@skip_if_not_root
|
2017-04-03 16:04:09 +00:00
|
|
|
class MacGroupModuleTest(ModuleCase):
|
2014-03-18 19:02:20 +00:00
|
|
|
'''
|
|
|
|
Integration tests for the mac_group module
|
|
|
|
'''
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
'''
|
|
|
|
Sets up test requirements
|
|
|
|
'''
|
|
|
|
os_grain = self.run_function('grains.item', ['kernel'])
|
|
|
|
if os_grain['kernel'] not in 'Darwin':
|
|
|
|
self.skipTest(
|
|
|
|
'Test not applicable to \'{kernel}\' kernel'.format(
|
|
|
|
**os_grain
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
2017-03-29 18:15:15 +00:00
|
|
|
def test_mac_group_add(self):
|
2014-03-18 19:02:20 +00:00
|
|
|
'''
|
|
|
|
Tests the add group function
|
|
|
|
'''
|
|
|
|
try:
|
|
|
|
self.run_function('group.add', [ADD_GROUP, 3456])
|
|
|
|
group_info = self.run_function('group.info', [ADD_GROUP])
|
|
|
|
self.assertEqual(group_info['name'], ADD_GROUP)
|
|
|
|
except CommandExecutionError:
|
|
|
|
self.run_function('group.delete', [ADD_GROUP])
|
|
|
|
raise
|
|
|
|
|
2017-03-29 18:15:15 +00:00
|
|
|
def test_mac_group_delete(self):
|
2014-03-18 20:34:36 +00:00
|
|
|
'''
|
|
|
|
Tests the delete group function
|
|
|
|
'''
|
|
|
|
# Create a group to delete - If unsuccessful, skip the test
|
|
|
|
if self.run_function('group.add', [DEL_GROUP, 4567]) is not True:
|
|
|
|
self.run_function('group.delete', [DEL_GROUP])
|
|
|
|
self.skipTest('Failed to create a group to delete')
|
|
|
|
|
|
|
|
try:
|
|
|
|
# Now try to delete the added group
|
|
|
|
ret = self.run_function('group.delete', [DEL_GROUP])
|
|
|
|
self.assertTrue(ret)
|
|
|
|
except CommandExecutionError:
|
|
|
|
raise
|
|
|
|
|
2017-03-29 18:15:15 +00:00
|
|
|
def test_mac_group_chgid(self):
|
2014-03-18 20:34:36 +00:00
|
|
|
'''
|
|
|
|
Tests changing the group id
|
|
|
|
'''
|
|
|
|
# Create a group to delete - If unsuccessful, skip the test
|
|
|
|
if self.run_function('group.add', [CHANGE_GROUP, 5678]) is not True:
|
|
|
|
self.run_function('group.delete', [CHANGE_GROUP])
|
|
|
|
self.skipTest('Failed to create a group to manipulate')
|
|
|
|
|
|
|
|
try:
|
|
|
|
self.run_function('group.chgid', [CHANGE_GROUP, 6789])
|
|
|
|
group_info = self.run_function('group.info', [CHANGE_GROUP])
|
|
|
|
self.assertEqual(group_info['gid'], 6789)
|
|
|
|
except AssertionError:
|
|
|
|
self.run_function('group.delete', [CHANGE_GROUP])
|
|
|
|
raise
|
|
|
|
|
2017-03-29 18:15:15 +00:00
|
|
|
def test_mac_adduser(self):
|
2016-03-10 23:18:08 +00:00
|
|
|
'''
|
|
|
|
Tests adding user to the group
|
|
|
|
'''
|
|
|
|
# Create a group to use for test - If unsuccessful, skip the test
|
|
|
|
if self.run_function('group.add', [ADD_GROUP, 5678]) is not True:
|
|
|
|
self.run_function('group.delete', [ADD_GROUP])
|
|
|
|
self.skipTest('Failed to create a group to manipulate')
|
|
|
|
|
|
|
|
try:
|
|
|
|
self.run_function('group.adduser', [ADD_GROUP, ADD_USER])
|
|
|
|
group_info = self.run_function('group.info', [ADD_GROUP])
|
|
|
|
self.assertEqual(ADD_USER, ''.join(group_info['members']))
|
|
|
|
except AssertionError:
|
|
|
|
self.run_function('group.delete', [ADD_GROUP])
|
|
|
|
raise
|
|
|
|
|
2017-03-29 18:15:15 +00:00
|
|
|
def test_mac_deluser(self):
|
2016-03-10 23:18:08 +00:00
|
|
|
'''
|
|
|
|
Test deleting user from a group
|
|
|
|
'''
|
|
|
|
# Create a group to use for test - If unsuccessful, skip the test
|
|
|
|
if self.run_function('group.add', [ADD_GROUP, 5678]) and \
|
2016-03-21 20:18:29 +00:00
|
|
|
self.run_function('group.adduser', [ADD_GROUP, ADD_USER]) is not True:
|
2016-03-10 23:18:08 +00:00
|
|
|
self.run_function('group.delete', [ADD_GROUP])
|
|
|
|
self.skipTest('Failed to create a group to manipulate')
|
|
|
|
|
|
|
|
delusr = self.run_function('group.deluser', [ADD_GROUP, ADD_USER])
|
|
|
|
self.assertTrue(delusr)
|
|
|
|
|
|
|
|
group_info = self.run_function('group.info', [ADD_GROUP])
|
|
|
|
self.assertNotIn(ADD_USER, ''.join(group_info['members']))
|
|
|
|
|
2017-03-29 18:15:15 +00:00
|
|
|
def test_mac_members(self):
|
2016-03-10 23:18:08 +00:00
|
|
|
'''
|
|
|
|
Test replacing members of a group
|
|
|
|
'''
|
|
|
|
if self.run_function('group.add', [ADD_GROUP, 5678]) and \
|
2016-03-21 20:55:03 +00:00
|
|
|
self.run_function('group.adduser', [ADD_GROUP, ADD_USER]) is not True:
|
2016-03-10 23:18:08 +00:00
|
|
|
self.run_function('group.delete', [ADD_GROUP])
|
2016-03-21 20:55:03 +00:00
|
|
|
self.skipTest('Failed to create the {0} group or add user {1} to group '
|
|
|
|
'to manipulate'.format(ADD_GROUP,
|
|
|
|
ADD_USER))
|
2016-03-10 23:18:08 +00:00
|
|
|
|
2016-03-21 20:55:03 +00:00
|
|
|
rep_group_mem = self.run_function('group.members',
|
|
|
|
[ADD_GROUP, REP_USER_GROUP])
|
2016-03-10 23:18:08 +00:00
|
|
|
self.assertTrue(rep_group_mem)
|
|
|
|
|
|
|
|
# ensure new user is added to group and previous user is removed
|
|
|
|
group_info = self.run_function('group.info', [ADD_GROUP])
|
|
|
|
self.assertIn(REP_USER_GROUP, str(group_info['members']))
|
|
|
|
self.assertNotIn(ADD_USER, str(group_info['members']))
|
|
|
|
|
2017-03-29 18:15:15 +00:00
|
|
|
def test_mac_getent(self):
|
2016-03-10 23:18:08 +00:00
|
|
|
'''
|
|
|
|
Test returning info on all groups
|
|
|
|
'''
|
|
|
|
if self.run_function('group.add', [ADD_GROUP, 5678]) and \
|
|
|
|
self.run_function('group.adduser', [ADD_GROUP, ADD_USER])is not True:
|
|
|
|
self.run_function('group.delete', [ADD_GROUP])
|
2016-03-21 20:55:03 +00:00
|
|
|
self.skipTest('Failed to create the {0} group or add user {1} to group '
|
|
|
|
'to manipulate'.format(ADD_GROUP,
|
|
|
|
ADD_USER))
|
2016-03-10 23:18:08 +00:00
|
|
|
|
|
|
|
getinfo = self.run_function('group.getent')
|
|
|
|
self.assertTrue(getinfo)
|
|
|
|
self.assertIn(ADD_GROUP, str(getinfo))
|
|
|
|
self.assertIn(ADD_USER, str(getinfo))
|
|
|
|
|
2017-03-29 18:15:15 +00:00
|
|
|
def tearDown(self):
|
2014-03-18 19:02:20 +00:00
|
|
|
'''
|
|
|
|
Clean up after tests
|
|
|
|
'''
|
2014-03-18 20:34:36 +00:00
|
|
|
# Delete ADD_GROUP
|
2014-03-18 19:02:20 +00:00
|
|
|
add_info = self.run_function('group.info', [ADD_GROUP])
|
|
|
|
if add_info:
|
|
|
|
self.run_function('group.delete', [ADD_GROUP])
|
|
|
|
|
2014-03-18 20:34:36 +00:00
|
|
|
# Delete DEL_GROUP if something failed
|
|
|
|
del_info = self.run_function('group.info', [DEL_GROUP])
|
|
|
|
if del_info:
|
|
|
|
self.run_function('group.delete', [DEL_GROUP])
|
|
|
|
|
|
|
|
# Delete CHANGE_GROUP
|
|
|
|
change_info = self.run_function('group.info', [CHANGE_GROUP])
|
|
|
|
if change_info:
|
|
|
|
self.run_function('group.delete', [CHANGE_GROUP])
|