* add nginx forward_auth e2e tests Signed-off-by: Jens Langhammer <jens@goauthentik.io> * add envoy Signed-off-by: Jens Langhammer <jens@goauthentik.io> * cleanup Signed-off-by: Jens Langhammer <jens@goauthentik.io> * remove even more duplicate code Signed-off-by: Jens Langhammer <jens@goauthentik.io> * cleanup more Signed-off-by: Jens Langhammer <jens@goauthentik.io> * add traefik static config Signed-off-by: Jens Langhammer <jens@goauthentik.io> * more cleanup, don't generate dex config cause they support env variables Signed-off-by: Jens Langhammer <jens@goauthentik.io> * use default dex entrypoint to use templating Signed-off-by: Jens Langhammer <jens@goauthentik.io> * remove options that are always set as default Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix compose flag Signed-off-by: Jens Langhammer <jens@goauthentik.io> * add caddy Signed-off-by: Jens Langhammer <jens@goauthentik.io> * merge python files Signed-off-by: Jens Langhammer <jens@goauthentik.io> * use whoami api to check better Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix envoy config Signed-off-by: Jens Langhammer <jens@goauthentik.io> * set invalidation flow Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix logout checks Signed-off-by: Jens Langhammer <jens@goauthentik.io> --------- Signed-off-by: Jens Langhammer <jens@goauthentik.io>
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
"""test SCIM Source"""
 | 
						|
 | 
						|
from pprint import pformat
 | 
						|
from time import sleep
 | 
						|
 | 
						|
from docker.types import Healthcheck
 | 
						|
 | 
						|
from authentik.lib.generators import generate_id
 | 
						|
from authentik.lib.utils.http import get_http_session
 | 
						|
from authentik.sources.scim.models import SCIMSource
 | 
						|
from tests.e2e.utils import SeleniumTestCase, retry
 | 
						|
 | 
						|
TEST_POLL_MAX = 25
 | 
						|
 | 
						|
 | 
						|
class TestSourceSCIM(SeleniumTestCase):
 | 
						|
    """test SCIM Source flow"""
 | 
						|
 | 
						|
    def setUp(self):
 | 
						|
        self.slug = generate_id()
 | 
						|
        super().setUp()
 | 
						|
        self.run_container(
 | 
						|
            image=(
 | 
						|
                "ghcr.io/suvera/scim2-compliance-test-utility@sha256:eca913bb73"
 | 
						|
                "c46892cd1fb2dfd2fef1c5881e6abc5cb0eec7e92fb78c1b933ece"
 | 
						|
            ),
 | 
						|
            ports={"8080": "8080"},
 | 
						|
            healthcheck=Healthcheck(
 | 
						|
                test=["CMD", "curl", "http://localhost:8080"],
 | 
						|
                interval=5 * 1_000 * 1_000_000,
 | 
						|
                start_period=1 * 1_000 * 1_000_000,
 | 
						|
            ),
 | 
						|
        )
 | 
						|
 | 
						|
    @retry()
 | 
						|
    def test_scim_conformance(self):
 | 
						|
        source = SCIMSource.objects.create(
 | 
						|
            name=generate_id(),
 | 
						|
            slug=generate_id(),
 | 
						|
        )
 | 
						|
        session = get_http_session()
 | 
						|
        test_launch = session.post(
 | 
						|
            "http://localhost:8080/test/run",
 | 
						|
            data={
 | 
						|
                "endPoint": self.live_server_url + f"/source/scim/{source.slug}/v2",
 | 
						|
                "username": "foo",
 | 
						|
                "password": source.token.key,
 | 
						|
                "jwtToken": None,
 | 
						|
                "usersCheck": 1,
 | 
						|
                "groupsCheck": 1,
 | 
						|
                "checkIndResLocation": 1,
 | 
						|
            },
 | 
						|
        )
 | 
						|
        self.assertEqual(test_launch.status_code, 200)
 | 
						|
        test_id = test_launch.json()["id"]
 | 
						|
        attempt = 0
 | 
						|
        while attempt <= TEST_POLL_MAX:
 | 
						|
            test_status = session.get(
 | 
						|
                "http://localhost:8080/test/status",
 | 
						|
                params={"runId": test_id},
 | 
						|
            )
 | 
						|
            self.assertEqual(test_status.status_code, 200)
 | 
						|
            body = test_status.json()
 | 
						|
            if any([data["title"] == "--DONE--" for data in body["data"]]):
 | 
						|
                break
 | 
						|
            attempt += 1
 | 
						|
            sleep(1)
 | 
						|
        for test in body["data"]:
 | 
						|
            # Workaround, the test expects DELETE requests to return 204 and have
 | 
						|
            # the content type set to the JSON SCIM one, which is not what most HTTP servers do
 | 
						|
            if test["requestMethod"] == "DELETE" and test["responseCode"] == 204:  # noqa: PLR2004
 | 
						|
                continue
 | 
						|
            if test["title"] == "--DONE--":
 | 
						|
                break
 | 
						|
            self.assertTrue(test["success"], pformat(test))
 |