Example #1
0
    def test_list_users(self):
        """Tests that we list all users, regardless
           of batchsize requested.
           Note, this test takes some time due to the large number of
           users created to test the default batchsize.
           {
               User: user1,
               User: user2,...
               User: userN
           }
           Tests that list_users(batchsize=-1)
                      == list_users(batchsize=[0, N])
                      == list_users()
        """
        # Login
        ts = TSApiWrapper(DISABLE_SSL)
        ts.login(HOSTPORT, USERNAME, PASSWORD)

        users = ["user" + str(i) for i in range(250)]
        # Create ts user objects
        for u in users:
            res = ts.create_user(u, u)
            sleep_time, create_count = 0.5, 0
            while res.status != Constants.OPERATION_SUCCESS:
                # Check if we have tried creating too many times
                if create_count > 3:
                    break
                # Sleep for @sleep_time seconds, so we do not choke ts instance
                time.sleep(sleep_time)
                res = ts.create_user(u, u)
                sleep_time *= 2
                create_count += 1

        user_ids = set([
            ts.get_userid_with_name(user_name).data for user_name in users
        ])  # - set([None])
        # Check that all users were successfully created
        self.assertEqual(len(users), len(user_ids))

        # List all ts user objects (including default users Ex. 'system')
        for batchsize in [-1, 0, 100, 150, None]:
            users_batched = ts.list_users() if batchsize is None \
                            else ts.list_users(batchsize)
            users_batched = users_batched.data
            # Test if all returned users are unique
            self.assertTrue(len(users_batched) == len(set(users_batched)))
            # Get all user_ids from the returned list
            users_batched_ids = [user_obj.id for user_obj in users_batched]
            # Test if all relevant users are returned
            self.assertTrue(all([uid in users_batched_ids
                                 for uid in user_ids]))

        # Cleanup
        ts.delete_users(list(user_ids))
Example #2
0
    def test_get_batched_users(self):
        """Tests that we list a batch of users with an offset.
            {
               User: user0,
               User: user1,...
               User: user5
            }
            offset = 3, batch = 2 -> [user3, user4]
        """
        # Login
        ts = TSApiWrapper(DISABLE_SSL)
        ts.login(HOSTPORT, USERNAME, PASSWORD)

        users = ["batched_user" + str(i) for i in range(12)]
        # Create ts user objects
        for u in users:
            ts.create_user(u, u)
        user_ids = set(
            [ts.get_userid_with_name(user_name).data for user_name in users])

        # Test batched entities call with offset
        offset = 3
        batchsize = 2
        users_list_ids = [u.id for u in ts.list_users().data]
        users_batched = ts._get_batched_entities("User", offset,
                                                 batchsize).data[0]
        users_batched_ids = [u.id for u in users_batched]
        self.assertEqual(users_batched_ids,
                         users_list_ids[offset:offset + batchsize])

        # Cleanup
        ts.delete_users(list(user_ids))
Example #3
0
    def test_create_user_weak_password(self):
        """Tests user creation with weak password"""
        new_user = "******"
        ts = TSApiWrapper(DISABLE_SSL)
        ts.login(HOSTPORT, USERNAME, PASSWORD)

        #######################################################################

        # Test for LDAP_USER create/delete with weak password
        # Assert user doesn't exist in TS.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertFalse(flag)
        # Create LDAP user with weak password
        weak_password = "******"
        status = ts.create_user(new_user, new_user, TSApiWrapper.LDAP_USER,
                                weak_password).status
        self.assertEqual(status, Constants.OPERATION_FAILURE)
        # Assert user doesn't exist in TS.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertFalse(flag)
Example #4
0
    def test_create_delete_user(self):
        """Tests creation and deletion of user by name 'newxyzuser'."""
        new_user = "******"
        ts = TSApiWrapper(DISABLE_SSL)
        ts.login(HOSTPORT, USERNAME, PASSWORD)

        #######################################################################

        # Test for LOCAL_USER create/delete.
        # Assert user doesnt exist in TS.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertFalse(flag)
        # Create LOCAL user
        ts.create_user(new_user, new_user)
        # Assert user exists in TS now.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertTrue(flag)
        # Assert by default user type is set to LOCAL_USER.
        for user in ts.list_users().data:
            if user.name == new_user:
                self.assertEqual(TSApiWrapper.LOCAL_USER, user.type)
        # Create user again and check we get USER_ALREADY_EXISTS status.
        status = ts.create_user(new_user, new_user).status
        self.assertEqual(status, Constants.USER_ALREADY_EXISTS)

        # Get user id with name.
        user_id = ts.get_userid_with_name(new_user).data
        # Delete user.
        ts.delete_users([user_id])
        # Assert user no longer exists in TS System.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertFalse(flag)

        #######################################################################

        # Test for LDAP_USER create/delete.
        # Assert user doesnt exist in TS.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertFalse(flag)
        # Create LDAP user
        ts.create_user(new_user, new_user, TSApiWrapper.LDAP_USER)
        # Assert user exists in TS now.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertTrue(flag)
        # Assert user type is set to LDAP_USER.
        for user in ts.list_users().data:
            if user.name == new_user:
                self.assertEqual(TSApiWrapper.LDAP_USER, user.type)
        # Create user again and check we get USER_ALREADY_EXISTS status.
        status = ts.create_user(new_user, new_user,
                                TSApiWrapper.LDAP_USER).status
        self.assertEqual(status, Constants.USER_ALREADY_EXISTS)

        # Get user id with name.
        user_id = ts.get_userid_with_name(new_user).data
        # Delete user.
        ts.delete_users([user_id])
        # Assert user no longer exists in TS System.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertFalse(flag)

        #######################################################################

        # Test for SAML_USER create/delete.
        # Assert user doesnt exist in TS.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertFalse(flag)
        # Create SAML user
        ts.create_user(new_user, new_user, TSApiWrapper.SAML_USER)
        # Assert user exists in TS now.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertTrue(flag)
        # Assert user type is set to SAML_USER.
        for user in ts.list_users().data:
            if user.name == new_user:
                self.assertEqual(TSApiWrapper.SAML_USER, user.type)
        # Create user again and check we get USER_ALREADY_EXISTS status.
        status = ts.create_user(new_user, new_user,
                                TSApiWrapper.SAML_USER).status
        self.assertEqual(status, Constants.USER_ALREADY_EXISTS)

        # Get user id with name.
        user_id = ts.get_userid_with_name(new_user).data
        # Delete user.
        ts.delete_users([user_id])
        # Assert user no longer exists in TS System.
        flag = new_user in [user.name for user in ts.list_users().data]
        self.assertFalse(flag)