Skip to content
Snippets Groups Projects
Select Git revision
  • 364163e7a0d4a86a757768921b99033f8f108f13
  • main default protected
  • renovate/main-ghcr.io-renovatebot-base-image-10.x
  • renovate/main-ghcr.io-containerbase-devcontainer-13.x
  • next
  • revert-31645-feat/rename-gradle-wrapper-validation-action
  • renovate/main-redis-5.x
  • fix/36615b-branch-reuse-no-cache
  • chore/punycode
  • fix/36615-branch-reuse-bug
  • refactor/pin-new-value
  • feat/36219--git-x509-signing
  • feat/structured-logger
  • hotfix/39.264.1
  • feat/skip-dangling
  • gh-readonly-queue/next/pr-36034-7a061c4ca1024a19e2c295d773d9642625d1c2be
  • hotfix/39.238.3
  • refactor/gitlab-auto-approve
  • feat/template-strings
  • gh-readonly-queue/next/pr-35654-137d934242c784e0c45d4b957362214f0eade1d7
  • fix/32307-global-extends-merging
  • 41.31.1
  • 41.31.0
  • 41.30.5
  • 41.30.4
  • 41.30.3
  • 41.30.2
  • 41.30.1
  • 41.30.0
  • 41.29.1
  • 41.29.0
  • 41.28.2
  • 41.28.1
  • 41.28.0
  • 41.27.1
  • 41.27.0
  • 41.26.2
  • 41.26.1
  • 41.26.0
  • 41.25.1
  • 41.25.0
41 results

gitea-helper.spec.ts

Blame
  • test_service.py 2.56 KiB
    import logging
    
    import pytest
    from plumbum import ProcessExecutionError
    from plumbum.cmd import docker
    
    logger = logging.getLogger()
    
    
    def _check_permissions(allowed_calls, forbidden_calls):
        for args in allowed_calls:
            docker(*args)
        for args in forbidden_calls:
            with pytest.raises(ProcessExecutionError):
                docker(*args)
    
    
    def test_default_permissions(proxy_factory):
        with proxy_factory() as test_container:
            allowed_calls = (("version",),)
            forbidden_calls = (
                ("pull", "alpine"),
                ("--rm", "alpine", "--name", test_container),
                ("logs", test_container),
                ("wait", test_container),
                ("rm", "-f", test_container),
                ("restart", test_container),
                ("network", "ls"),
                ("config", "ls"),
                ("service", "ls"),
                ("stack", "ls"),
                ("secret", "ls"),
                ("plugin", "ls"),
                ("info",),
                ("system", "info"),
                ("build", "."),
                ("buildx build", "."),
                ("swarm", "init"),
            )
            _check_permissions(allowed_calls, forbidden_calls)
    
    
    def test_container_permissions(proxy_factory):
        with proxy_factory(CONTAINERS=1) as test_container:
            allowed_calls = [
                ("logs", test_container),
                ("inspect", test_container),
            ]
            forbidden_calls = [
                ("wait", test_container),
                ("run", "--rm", "alpine"),
                ("rm", "-f", test_container),
                ("restart", test_container),
            ]
            _check_permissions(allowed_calls, forbidden_calls)
    
    
    def test_post_permissions(proxy_factory):
        with proxy_factory(POST=1) as test_container:
            allowed_calls = []
            forbidden_calls = [
                ("rm", "-f", test_container),
                ("pull", "alpine"),
                ("run", "--rm", "alpine"),
                ("network", "create", "foobar"),
            ]
            _check_permissions(allowed_calls, forbidden_calls)
    
    
    def test_network_post_permissions(proxy_factory):
        with proxy_factory(POST=1, NETWORKS=1):
            allowed_calls = [
                ("network", "ls"),
                ("network", "create", "foo"),
                ("network", "rm", "foo"),
            ]
            forbidden_calls = []
            _check_permissions(allowed_calls, forbidden_calls)
    
    
    def test_exec_permissions(proxy_factory):
        with proxy_factory(CONTAINERS=1, EXEC=1, POST=1) as container_id:
            allowed_calls = [
                ("exec", container_id, "ls"),
            ]
            forbidden_calls = []
            _check_permissions(allowed_calls, forbidden_calls)