# -*- coding: utf-8 -*- # Import python libs from __future__ import absolute_import import os import string import random # Import Salt Testing libs import tests.integration as integration from tests.support.unit import skipIf from tests.support.helpers import ( destructiveTest, requires_system_grains ) # Import salt libs import salt.utils # Import 3rd-party libs from salt.ext.six.moves import range # pylint: disable=import-error,redefined-builtin IS_ADMIN = False if salt.utils.is_windows(): import salt.utils.win_functions current_user = salt.utils.win_functions.get_current_user() if current_user == 'SYSTEM': IS_ADMIN = True else: IS_ADMIN = salt.utils.win_functions.is_admin(current_user) else: IS_ADMIN = os.geteuid() == 0 @destructiveTest @skipIf(not salt.utils.is_linux(), 'These tests can only be run on linux') @skipIf(not IS_ADMIN, 'You must be root to run these tests') class UseraddModuleTestLinux(integration.ModuleCase): def setUp(self): super(UseraddModuleTestLinux, self).setUp() os_grain = self.run_function('grains.item', ['kernel']) if os_grain['kernel'] not in ('Linux', 'Darwin'): self.skipTest( 'Test not applicable to \'{kernel}\' kernel'.format( **os_grain ) ) def __random_string(self, size=6): return 'RS-' + ''.join( random.choice(string.ascii_uppercase + string.digits) for x in range(size) ) @requires_system_grains def test_groups_includes_primary(self, grains=None): # Let's create a user, which usually creates the group matching the # name uname = self.__random_string() if self.run_function('user.add', [uname]) is not True: # Skip because creating is not what we're testing here self.run_function('user.delete', [uname, True, True]) self.skipTest('Failed to create user') try: uinfo = self.run_function('user.info', [uname]) if grains['os_family'] in ('Suse',): self.assertIn('users', uinfo['groups']) else: self.assertIn(uname, uinfo['groups']) # This uid is available, store it uid = uinfo['uid'] self.run_function('user.delete', [uname, True, True]) # Now, a weird group id gname = self.__random_string() if self.run_function('group.add', [gname]) is not True: self.run_function('group.delete', [gname, True, True]) self.skipTest('Failed to create group') ginfo = self.run_function('group.info', [gname]) # And create the user with that gid if self.run_function('user.add', [uname, uid, ginfo['gid']]) is False: # Skip because creating is not what we're testing here self.run_function('user.delete', [uname, True, True]) self.skipTest('Failed to create user') uinfo = self.run_function('user.info', [uname]) self.assertIn(gname, uinfo['groups']) except AssertionError: self.run_function('user.delete', [uname, True, True]) raise def test_user_primary_group(self, grains=None): ''' Tests the primary_group function ''' name = 'saltyuser' # Create a user to test primary group function if self.run_function('user.add', [name]) is not True: self.run_function('user.delete', [name]) self.skipTest('Failed to create a user') try: # Test useradd.primary_group primary_group = self.run_function('user.primary_group', [name]) uid_info = self.run_function('user.info', [name]) self.assertIn(primary_group, uid_info['groups']) except: self.run_function('user.delete', [name]) raise @destructiveTest @skipIf(not salt.utils.is_windows(), 'These tests can only be run on Windows') @skipIf(not IS_ADMIN, 'You must be Administrator to run these tests') class UseraddModuleTestWindows(integration.ModuleCase): def __random_string(self, size=6): return 'RS-' + ''.join( random.choice(string.ascii_uppercase + string.digits) for x in range(size)) def test_add_user(self): ''' Test adding a user ''' user_name = self.__random_string() try: if self.run_function('user.add', [user_name]) is False: self.run_function('user.delete', [user_name, True, True]) self.skipTest('Failed to create user') user_list = self.run_function('user.list_users') self.assertIn(user_name, user_list) except AssertionError: raise finally: self.run_function('user.delete', [user_name, True, True]) def test_add_group(self): ''' Test adding a user ''' group_name = self.__random_string() try: if self.run_function('group.add', [group_name]) is False: # Skip because creating is not what we're testing here self.run_function('group.delete', [group_name, True, True]) self.skipTest('Failed to create group') group_list = self.run_function('group.list_groups') self.assertIn(group_name, group_list) except AssertionError: raise finally: self.run_function('group.delete', [group_name]) def test_add_user_to_group(self): ''' Test adding a user to a group ''' group_name = self.__random_string() user_name = self.__random_string() try: # Let's create a group if self.run_function( 'group.add', [group_name])['result'] is not True: self.run_function('group.delete', [group_name, True, True]) self.skipTest('Failed to create group') # And create the user as a member of that group if self.run_function( 'user.add', [user_name], groups=group_name) is False: self.run_function('user.delete', [user_name, True, True]) self.skipTest('Failed to create user') user_info = self.run_function('user.info', [user_name]) self.assertIn(group_name, user_info['groups']) except AssertionError: raise finally: self.run_function('user.delete', [user_name, True, True]) self.run_function('group.delete', [group_name])