* remove pyright Signed-off-by: Jens Langhammer <jens@goauthentik.io> * remove pylint Signed-off-by: Jens Langhammer <jens@goauthentik.io> * replace pylint with ruff Signed-off-by: Jens Langhammer <jens@goauthentik.io> * ruff fix Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space> * fix UP038 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix DJ012 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix default arg Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix UP031 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * rename stage type to view Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix DJ008 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix remaining upgrade Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix PLR2004 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix B904 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix PLW2901 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix remaining issues Signed-off-by: Jens Langhammer <jens@goauthentik.io> * prevent ruff from breaking the code Signed-off-by: Jens Langhammer <jens@goauthentik.io> * stages/prompt: refactor field building Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space> * fix tests Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix lint Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fully remove isort Signed-off-by: Jens Langhammer <jens@goauthentik.io> --------- Signed-off-by: Jens Langhammer <jens@goauthentik.io> Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space> Co-authored-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
		
			
				
	
	
		
			97 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
"""Test Controllers"""
 | 
						|
 | 
						|
import pytest
 | 
						|
import yaml
 | 
						|
from django.test import TestCase
 | 
						|
from structlog.stdlib import get_logger
 | 
						|
 | 
						|
from authentik.core.tests.utils import create_test_flow
 | 
						|
from authentik.outposts.controllers.kubernetes import KubernetesController
 | 
						|
from authentik.outposts.models import KubernetesServiceConnection, Outpost, OutpostType
 | 
						|
from authentik.outposts.tasks import outpost_connection_discovery
 | 
						|
from authentik.providers.proxy.controllers.k8s.ingress import IngressReconciler
 | 
						|
from authentik.providers.proxy.controllers.kubernetes import ProxyKubernetesController
 | 
						|
from authentik.providers.proxy.models import ProxyMode, ProxyProvider
 | 
						|
 | 
						|
LOGGER = get_logger()
 | 
						|
 | 
						|
 | 
						|
class TestProxyKubernetes(TestCase):
 | 
						|
    """Test Controllers"""
 | 
						|
 | 
						|
    controller: KubernetesController | None
 | 
						|
 | 
						|
    def setUp(self):
 | 
						|
        # Ensure that local connection have been created
 | 
						|
        outpost_connection_discovery()
 | 
						|
        self.controller = None
 | 
						|
 | 
						|
    def tearDown(self) -> None:
 | 
						|
        if self.controller:
 | 
						|
            for log in self.controller.down_with_logs():
 | 
						|
                LOGGER.info(log)
 | 
						|
        return super().tearDown()
 | 
						|
 | 
						|
    @pytest.mark.timeout(120)
 | 
						|
    def test_kubernetes_controller_static(self):
 | 
						|
        """Test Kubernetes Controller"""
 | 
						|
        provider: ProxyProvider = ProxyProvider.objects.create(
 | 
						|
            name="test",
 | 
						|
            internal_host="http://localhost",
 | 
						|
            external_host="http://localhost",
 | 
						|
            authorization_flow=create_test_flow(),
 | 
						|
        )
 | 
						|
        service_connection = KubernetesServiceConnection.objects.first()
 | 
						|
        outpost: Outpost = Outpost.objects.create(
 | 
						|
            name="test",
 | 
						|
            type=OutpostType.PROXY,
 | 
						|
            service_connection=service_connection,
 | 
						|
        )
 | 
						|
        outpost.providers.add(provider)
 | 
						|
        outpost.save()
 | 
						|
 | 
						|
        self.controller = ProxyKubernetesController(outpost, service_connection)
 | 
						|
        manifest = self.controller.get_static_deployment()
 | 
						|
        self.assertEqual(len(list(yaml.load_all(manifest, Loader=yaml.SafeLoader))), 4)
 | 
						|
 | 
						|
    @pytest.mark.timeout(120)
 | 
						|
    def test_kubernetes_controller_ingress(self):
 | 
						|
        """Test Kubernetes Controller's Ingress"""
 | 
						|
        provider: ProxyProvider = ProxyProvider.objects.create(
 | 
						|
            name="test",
 | 
						|
            internal_host="http://localhost",
 | 
						|
            external_host="https://localhost",
 | 
						|
            authorization_flow=create_test_flow(),
 | 
						|
        )
 | 
						|
        provider2: ProxyProvider = ProxyProvider.objects.create(
 | 
						|
            name="test2",
 | 
						|
            internal_host="http://otherhost",
 | 
						|
            external_host="https://otherhost",
 | 
						|
            mode=ProxyMode.FORWARD_SINGLE,
 | 
						|
            authorization_flow=create_test_flow(),
 | 
						|
        )
 | 
						|
 | 
						|
        service_connection = KubernetesServiceConnection.objects.first()
 | 
						|
        outpost: Outpost = Outpost.objects.create(
 | 
						|
            name="test",
 | 
						|
            type=OutpostType.PROXY,
 | 
						|
            service_connection=service_connection,
 | 
						|
        )
 | 
						|
        outpost.providers.add(provider)
 | 
						|
 | 
						|
        self.controller = ProxyKubernetesController(outpost, service_connection)
 | 
						|
 | 
						|
        ingress_rec = IngressReconciler(self.controller)
 | 
						|
        ingress = ingress_rec.retrieve()
 | 
						|
 | 
						|
        self.assertEqual(len(ingress.spec.rules), 1)
 | 
						|
        self.assertEqual(ingress.spec.rules[0].host, "localhost")
 | 
						|
 | 
						|
        # add provider, check again
 | 
						|
        outpost.providers.add(provider2)
 | 
						|
        ingress = ingress_rec.retrieve()
 | 
						|
 | 
						|
        self.assertEqual(len(ingress.spec.rules), 2)
 | 
						|
        self.assertEqual(ingress.spec.rules[0].host, "localhost")
 | 
						|
        self.assertEqual(ingress.spec.rules[1].host, "otherhost")
 |