Beispiel #1
0
    async def test_enroll_sms_factor(self, fs):
        # Instantiate Mock Client
        client = MockOktaClient(fs)

        # Create User
        user_profile = models.UserProfile()
        user_profile.first_name = "John"
        user_profile.last_name = "Doe-SMS"
        user_profile.email = "*****@*****.**"
        user_profile.login = "******"

        create_user_req = models.CreateUserRequest({
            "credentials":
            models.UserCredentials({
                "password":
                models.PasswordCredential({"value": "Password150kta"})
            }),
            "profile":
            user_profile
        })

        created_user, _, err = await client.create_user(create_user_req)
        assert err is None
        assert isinstance(created_user, models.User)

        # Create and add factor
        sms_factor = models.SmsUserFactor({
            "profile":
            models.SmsUserFactorProfile({"phoneNumber": "+12345678901"})
        })

        enrolled_factor, _, err = await \
            client.enroll_factor(created_user.id, sms_factor)
        assert err is None
        assert isinstance(enrolled_factor, models.SmsUserFactor)

        # List factor to validate
        users_factors, _, err = await client.list_factors(created_user.id)
        assert err is None
        assert len(users_factors) > 0 and len(users_factors) == 1
        assert isinstance(users_factors[0], models.SmsUserFactor)
        assert users_factors[0].id == enrolled_factor.id
        assert users_factors[0].factor_type == models.FactorType.SMS
        assert users_factors[0].profile.phone_number ==\
            sms_factor.profile.phone_number

        # Deactivate + delete user
        _, err = await client.deactivate_user(created_user.id)
        assert err is None
        _, err = await client.deactivate_or_delete_user(created_user.id)
        assert err is None
Beispiel #2
0
    async def test_delete_factor(self, fs):
        # Instantiate Mock Client
        client = MockOktaClient(fs)

        # Create User
        user_profile = models.UserProfile()
        user_profile.first_name = "John"
        user_profile.last_name = "Doe-Delete-Factor"
        user_profile.email = "*****@*****.**"
        user_profile.login = "******"

        create_user_req = models.CreateUserRequest({
            "credentials":
            models.UserCredentials({
                "password":
                models.PasswordCredential({"value": "Password150kta"})
            }),
            "profile":
            user_profile
        })

        created_user, _, err = await client.create_user(create_user_req)
        assert err is None
        assert isinstance(created_user, models.User)

        # Create and add factor
        sms_factor = models.SmsUserFactor({
            "profile":
            models.SmsUserFactorProfile({"phoneNumber": "+12345678901"})
        })

        enrolled_factor, _, err = await \
            client.enroll_factor(created_user.id, sms_factor)
        assert err is None
        assert isinstance(enrolled_factor, models.SmsUserFactor)

        # Get factor to validate
        retrieved_user_factor, _, err = await client.get_factor(
            created_user.id, enrolled_factor.id)
        assert err is None
        assert isinstance(retrieved_user_factor, models.SmsUserFactor)
        assert retrieved_user_factor.id == enrolled_factor.id
        assert retrieved_user_factor.factor_type == models.FactorType.SMS
        assert retrieved_user_factor.profile.phone_number ==\
            sms_factor.profile.phone_number

        # Delete factor
        _, err = await client.delete_factor(created_user.id,
                                            enrolled_factor.id)
        assert err is None

        # Get factor to validate
        retrieved_user_factor, resp, err = await client.get_factor(
            created_user.id, enrolled_factor.id)
        assert err is not None
        assert isinstance(err, OktaAPIError)
        assert retrieved_user_factor is None
        assert resp.get_status() == HTTPStatus.NOT_FOUND

        # Deactivate + delete user
        _, err = await client.deactivate_user(created_user.id)
        assert err is None
        _, err = await client.deactivate_or_delete_user(created_user.id)
        assert err is None
Beispiel #3
0
    async def test_reset_factors(self):
        # Instantiate Mock Client
        client = MockOktaClient(fs)

        # Create User
        user_profile = models.UserProfile()
        user_profile.first_name = "John"
        user_profile.last_name = "Doe-Reset-Factor"
        user_profile.email = "*****@*****.**"
        user_profile.login = "******"

        create_user_req = models.CreateUserRequest({
            "credentials": models.UserCredentials({
                "password": models.PasswordCredential({
                    "value": "Password150kta"
                })
            }),
            "profile": user_profile
        })

        try:
            created_user, _, err = await client.create_user(create_user_req)
            assert err is None
            assert isinstance(created_user, models.User)

            # Create and add factor
            sms_factor = models.SmsUserFactor({
                "profile": models.SmsUserFactorProfile({
                    "phoneNumber": "+12345678901"
                })
            })

            enrolled_factor, _, err = await \
                client.enroll_factor(created_user.id, sms_factor)
            assert err is None
            assert isinstance(enrolled_factor, models.SmsUserFactor)

            # Get factor to validate
            retrieved_user_factor, _, err = await client.get_factor(
                created_user.id, enrolled_factor.id
            )
            assert err is None
            assert isinstance(retrieved_user_factor, models.SmsUserFactor)
            assert retrieved_user_factor.id == enrolled_factor.id
            assert retrieved_user_factor.factor_type == models.FactorType.SMS
            assert retrieved_user_factor.profile.phone_number ==\
                sms_factor.profile.phone_number

            # Reset factor
            _, err = await client.reset_factors(created_user.id)
            assert err is None

            # List factors to validate
            users_factors, _, err = await client.list_factors(created_user.id)
            assert err is None
            assert len(users_factors) == 0

        finally:
            errors = []
            # Deactivate + delete user
            try:
                _, err = await client.deactivate_user(created_user.id)
                assert err is None
            except Exception as exc:
                errors.append(exc)
            try:
                _, err = await client.deactivate_or_delete_user(created_user.id)
                assert err is None
            except Exception as exc:
                errors.append(exc)
            assert len(errors) == 0