183 lines
5.3 KiB
Python
183 lines
5.3 KiB
Python
# -*- coding: utf-8 -*-
|
|
# type: ignore
|
|
from __future__ import annotations
|
|
|
|
import http
|
|
|
|
from django.test import Client
|
|
from django.urls import reverse
|
|
import pytest
|
|
from pytest_django import asserts
|
|
|
|
from hotpocket_backend_testing.services.accounts import AuthKeysTestingService
|
|
from hotpocket_common.url import URL
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_ok(authenticated_client: Client,
|
|
extension_auth_source_extension,
|
|
account,
|
|
):
|
|
# When
|
|
result = authenticated_client.get(
|
|
reverse('ui.integrations.extension.authenticate'),
|
|
follow=False,
|
|
)
|
|
|
|
# Then
|
|
assert result.status_code == http.HTTPStatus.FOUND
|
|
assert 'Location' in result.headers
|
|
|
|
redirect_url = URL(result.headers['Location'])
|
|
assert redirect_url.raw_path == reverse('ui.integrations.extension.post_authenticate')
|
|
assert 'auth_key' in redirect_url.query
|
|
|
|
assert 'extension_source' in authenticated_client.session
|
|
assert authenticated_client.session['extension_source'] == extension_auth_source_extension
|
|
|
|
assert 'extension_session_token' in authenticated_client.session
|
|
|
|
AuthKeysTestingService().assert_created(
|
|
key=redirect_url.query['auth_key'][0],
|
|
account_uuid=account.pk,
|
|
)
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
'source_fixture_name',
|
|
['extension_auth_source_desktop', 'extension_auth_source_mobile'],
|
|
)
|
|
@pytest.mark.django_db
|
|
def test_ok_with_source(source_fixture_name,
|
|
request: pytest.FixtureRequest,
|
|
authenticated_client: Client,
|
|
extension_auth_session_token,
|
|
):
|
|
# Given
|
|
source = request.getfixturevalue(source_fixture_name)
|
|
|
|
# When
|
|
result = authenticated_client.get(
|
|
reverse(
|
|
'ui.integrations.extension.authenticate',
|
|
query=[
|
|
('source', source),
|
|
('session_token', extension_auth_session_token),
|
|
],
|
|
),
|
|
follow=False,
|
|
)
|
|
|
|
# Then
|
|
assert result.status_code == http.HTTPStatus.FOUND
|
|
assert 'Location' in result.headers
|
|
|
|
redirect_url = URL(result.headers['Location'])
|
|
assert redirect_url.raw_path == reverse('ui.integrations.extension.post_authenticate')
|
|
assert 'auth_key' in redirect_url.query
|
|
|
|
assert 'extension_source' in authenticated_client.session
|
|
assert authenticated_client.session['extension_source'] == source
|
|
|
|
assert 'extension_session_token' in authenticated_client.session
|
|
assert authenticated_client.session['extension_session_token'] == extension_auth_session_token
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_source_without_session_token(authenticated_client: Client,
|
|
extension_auth_source_desktop,
|
|
):
|
|
# Given
|
|
with pytest.raises(AssertionError) as exception_info:
|
|
# When
|
|
_ = authenticated_client.get(
|
|
reverse(
|
|
'ui.integrations.extension.authenticate',
|
|
query=[
|
|
('source', extension_auth_source_desktop),
|
|
],
|
|
),
|
|
follow=False,
|
|
)
|
|
|
|
# Then
|
|
assert exception_info.value.args[0] == 'Session token missing'
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_source_without_empty_session_token(authenticated_client: Client,
|
|
extension_auth_source_desktop,
|
|
):
|
|
# Given
|
|
with pytest.raises(AssertionError) as exception_info:
|
|
# When
|
|
_ = authenticated_client.get(
|
|
reverse(
|
|
'ui.integrations.extension.authenticate',
|
|
query=[
|
|
('source', extension_auth_source_desktop),
|
|
('session_token', ''),
|
|
],
|
|
),
|
|
follow=False,
|
|
)
|
|
|
|
# Then
|
|
assert exception_info.value.args[0] == 'Session token missing'
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_unknown_source(authenticated_client: Client, extension_auth_session_token):
|
|
# Given
|
|
with pytest.raises(ValueError) as exception_info:
|
|
# When
|
|
_ = authenticated_client.get(
|
|
reverse(
|
|
'ui.integrations.extension.authenticate',
|
|
query=[
|
|
('source', 'thisisntright'),
|
|
('session_token', extension_auth_session_token),
|
|
],
|
|
),
|
|
follow=False,
|
|
)
|
|
|
|
# Then
|
|
assert exception_info.value.args[0] == 'Unknown source: `thisisntright`'
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_inactive_account(inactive_account_client: Client):
|
|
# When
|
|
result = inactive_account_client.get(
|
|
reverse('ui.integrations.extension.authenticate'),
|
|
)
|
|
|
|
# Then
|
|
asserts.assertRedirects(
|
|
result,
|
|
reverse(
|
|
'ui.accounts.login',
|
|
query=[('next', reverse('ui.integrations.extension.authenticate'))],
|
|
),
|
|
fetch_redirect_response=False,
|
|
)
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_anonymous(client: Client):
|
|
# When
|
|
result = client.get(
|
|
reverse('ui.integrations.extension.authenticate'),
|
|
)
|
|
|
|
# Then
|
|
asserts.assertRedirects(
|
|
result,
|
|
reverse(
|
|
'ui.accounts.login',
|
|
query=[('next', reverse('ui.integrations.extension.authenticate'))],
|
|
),
|
|
fetch_redirect_response=False,
|
|
)
|