authentik/azure-pipelines.yml

379 lines
13 KiB
YAML
Raw Permalink Normal View History

trigger:
2020-05-28 18:15:18 +01:00
- master
resources:
2020-05-28 18:15:18 +01:00
- repo: self
variables:
2020-12-05 21:08:42 +00:00
POSTGRES_DB: authentik
POSTGRES_USER: authentik
2020-05-28 18:15:18 +01:00
POSTGRES_PASSWORD: "EK-5jnKfjrGRm<77"
${{ if startsWith(variables['Build.SourceBranch'], 'refs/heads/') }}:
branchName: ${{ replace(variables['Build.SourceBranchName'], 'refs/heads/', '') }}
${{ if startsWith(variables['Build.SourceBranch'], 'refs/pull/') }}:
branchName: ${{ replace(variables['System.PullRequest.SourceBranch'], 'refs/heads/', '') }}
stages:
2020-05-28 18:15:18 +01:00
- stage: Lint
jobs:
- job: pylint
pool:
vmImage: 'ubuntu-latest'
steps:
- task: UsePythonVersion@0
inputs:
2020-11-15 14:49:02 +00:00
versionSpec: '3.9'
2020-05-28 18:15:18 +01:00
- task: CmdLine@2
inputs:
script: |
2020-11-15 00:05:20 +00:00
sudo apt install -y libxmlsec1-dev pkg-config
2020-05-28 18:15:18 +01:00
sudo pip install -U wheel pipenv
pipenv install --dev
- task: CmdLine@2
inputs:
2020-12-05 21:08:42 +00:00
script: pipenv run pylint authentik tests lifecycle
2020-05-28 18:15:18 +01:00
- job: black
pool:
vmImage: 'ubuntu-latest'
steps:
- task: UsePythonVersion@0
inputs:
2020-11-15 14:49:02 +00:00
versionSpec: '3.9'
2020-05-28 18:15:18 +01:00
- task: CmdLine@2
inputs:
script: |
2020-11-15 00:05:20 +00:00
sudo apt install -y libxmlsec1-dev pkg-config
2020-05-28 18:15:18 +01:00
sudo pip install -U wheel pipenv
pipenv install --dev
- task: CmdLine@2
inputs:
2020-12-05 21:08:42 +00:00
script: pipenv run black --check authentik tests lifecycle
2020-05-28 18:15:18 +01:00
- job: prospector
pool:
vmImage: 'ubuntu-latest'
steps:
- task: UsePythonVersion@0
inputs:
2020-11-15 14:49:02 +00:00
versionSpec: '3.9'
2020-05-28 18:15:18 +01:00
- task: CmdLine@2
inputs:
script: |
2020-11-15 00:05:20 +00:00
sudo apt install -y libxmlsec1-dev pkg-config
2020-05-28 18:15:18 +01:00
sudo pip install -U wheel pipenv
pipenv install --dev
pipenv install --dev prospector --skip-lock
- task: CmdLine@2
inputs:
2020-09-26 18:17:42 +01:00
script: pipenv run prospector
2020-05-28 18:15:18 +01:00
- job: bandit
pool:
vmImage: 'ubuntu-latest'
steps:
- task: UsePythonVersion@0
inputs:
2020-11-15 14:49:02 +00:00
versionSpec: '3.9'
2020-05-28 18:15:18 +01:00
- task: CmdLine@2
inputs:
script: |
2020-11-15 00:05:20 +00:00
sudo apt install -y libxmlsec1-dev pkg-config
2020-05-28 18:15:18 +01:00
sudo pip install -U wheel pipenv
pipenv install --dev
- task: CmdLine@2
inputs:
2020-12-05 21:08:42 +00:00
script: pipenv run bandit -r authentik tests lifecycle
2020-05-28 18:15:18 +01:00
- job: pyright
pool:
vmImage: ubuntu-latest
steps:
- task: UseNode@1
inputs:
version: '12.x'
2020-05-28 18:15:18 +01:00
- task: UsePythonVersion@0
inputs:
2020-11-15 14:49:02 +00:00
versionSpec: '3.9'
2020-05-28 18:15:18 +01:00
- task: CmdLine@2
inputs:
2020-10-16 21:29:59 +01:00
script: npm install -g pyright@1.1.79
2020-05-28 18:15:18 +01:00
- task: CmdLine@2
inputs:
script: |
2020-11-15 00:05:20 +00:00
sudo apt install -y libxmlsec1-dev pkg-config
2020-05-28 18:15:18 +01:00
sudo pip install -U wheel pipenv
pipenv install --dev
- task: CmdLine@2
inputs:
script: pipenv run pyright e2e lifecycle
2020-05-28 18:29:28 +01:00
- stage: Test
jobs:
- job: migrations
pool:
vmImage: 'ubuntu-latest'
steps:
- task: UsePythonVersion@0
inputs:
2020-11-15 14:49:02 +00:00
versionSpec: '3.9'
2020-05-28 18:29:28 +01:00
- task: DockerCompose@0
displayName: Run services
inputs:
2020-07-14 21:55:30 +01:00
dockerComposeFile: 'scripts/ci.docker-compose.yml'
2020-05-28 18:29:28 +01:00
action: 'Run services'
buildImages: false
- task: CmdLine@2
inputs:
script: |
2020-11-15 00:05:20 +00:00
sudo apt install -y libxmlsec1-dev pkg-config
2020-05-28 18:29:28 +01:00
sudo pip install -U wheel pipenv
pipenv install --dev
- task: CmdLine@2
inputs:
script: pipenv run ./manage.py migrate
- job: migrations_from_previous_release
pool:
vmImage: 'ubuntu-latest'
steps:
- task: UsePythonVersion@0
inputs:
versionSpec: '3.8'
- task: UsePythonVersion@0
inputs:
2020-11-15 14:49:02 +00:00
versionSpec: '3.9'
- task: DockerCompose@0
displayName: Run services
inputs:
dockerComposeFile: 'scripts/ci.docker-compose.yml'
action: 'Run services'
buildImages: false
- task: CmdLine@2
displayName: Prepare Last tagged release
inputs:
script: |
2020-12-05 21:08:42 +00:00
# Copy current, latest config to local
cp authentik/lib/default.yml local.env.yml
git checkout $(git describe --abbrev=0 --match 'version/*')
2020-11-15 00:05:20 +00:00
sudo apt install -y libxmlsec1-dev pkg-config
sudo pip install -U wheel pipenv
pipenv install --dev
- task: CmdLine@2
displayName: Migrate to last tagged release
inputs:
2020-12-05 21:08:42 +00:00
script:
pipenv run ./manage.py migrate
- task: CmdLine@2
displayName: Install current branch
inputs:
script: |
set -x
git checkout ${{ variables.branchName }}
pipenv sync --dev
- task: CmdLine@2
displayName: Migrate to current branch
inputs:
2020-12-05 21:08:42 +00:00
script: |
pipenv run python -m lifecycle.migrate
pipenv run ./manage.py migrate
2020-07-10 16:25:19 +01:00
- job: coverage_unittest
pool:
vmImage: 'ubuntu-latest'
steps:
- task: UsePythonVersion@0
inputs:
2020-11-15 14:49:02 +00:00
versionSpec: '3.9'
- task: DockerCompose@0
displayName: Run services
inputs:
2020-07-14 21:55:30 +01:00
dockerComposeFile: 'scripts/ci.docker-compose.yml'
action: 'Run services'
buildImages: false
- task: CmdLine@2
inputs:
script: |
2020-11-15 00:05:20 +00:00
sudo apt install -y libxmlsec1-dev pkg-config
sudo pip install -U wheel pipenv
pipenv install --dev
- task: CmdLine@2
displayName: Run full test suite
inputs:
script: |
pipenv run make coverage
- task: CmdLine@2
inputs:
script: |
mkdir output-unittest
mv unittest.xml output-unittest/unittest.xml
mv .coverage output-unittest/coverage
- task: PublishPipelineArtifact@1
inputs:
targetPath: 'output-unittest/'
artifact: 'coverage-unittest'
publishLocation: 'pipeline'
- job: coverage_integration
2020-05-28 18:29:28 +01:00
pool:
vmImage: 'ubuntu-latest'
2020-05-28 18:29:28 +01:00
steps:
- task: UsePythonVersion@0
inputs:
2020-11-15 14:49:02 +00:00
versionSpec: '3.9'
2020-05-28 18:29:28 +01:00
- task: DockerCompose@0
displayName: Run services
inputs:
2020-07-14 21:55:30 +01:00
dockerComposeFile: 'scripts/ci.docker-compose.yml'
2020-05-28 18:29:28 +01:00
action: 'Run services'
buildImages: false
- task: CmdLine@2
inputs:
script: |
sudo apt install -y libxmlsec1-dev pkg-config
sudo pip install -U wheel pipenv
pipenv install --dev
- task: CmdLine@2
displayName: Install K3d and prepare
2020-10-14 19:28:24 +01:00
inputs:
script: |
wget -q -O - https://raw.githubusercontent.com/rancher/k3d/main/install.sh | bash
k3d cluster create
k3d kubeconfig write -o ~/.kube/config --overwrite
- task: CmdLine@2
displayName: Run full test suite
inputs:
script: |
pipenv run make test-integration
- task: CmdLine@2
inputs:
script: |
mkdir output-integration
mv unittest.xml output-integration/unittest.xml
mv .coverage output-integration/coverage
- task: PublishPipelineArtifact@1
inputs:
targetPath: 'output-integration/'
artifact: 'coverage-integration'
publishLocation: 'pipeline'
- job: coverage_e2e
pool:
name: coventry
steps:
- task: UsePythonVersion@0
inputs:
versionSpec: '3.9'
- task: DockerCompose@0
displayName: Run services
inputs:
dockerComposeFile: 'scripts/ci.docker-compose.yml'
action: 'Run services'
buildImages: false
2020-05-28 18:29:28 +01:00
- task: CmdLine@2
inputs:
script: |
2020-11-15 00:05:20 +00:00
sudo apt install -y libxmlsec1-dev pkg-config
2020-05-28 18:29:28 +01:00
sudo pip install -U wheel pipenv
pipenv install --dev --python python3.9
- task: DockerCompose@0
displayName: Run ChromeDriver
2020-05-28 18:29:28 +01:00
inputs:
dockerComposeFile: 'tests/e2e/ci.docker-compose.yml'
action: 'Run a specific service'
serviceName: 'chrome'
- task: CmdLine@2
displayName: Build static files for e2e
inputs:
script: |
cd web
2020-10-09 10:33:02 +01:00
npm i
npm run build
- task: CmdLine@2
displayName: Run full test suite
inputs:
2020-09-16 08:08:10 +01:00
script: |
pipenv run make test-e2e
2020-09-16 08:08:10 +01:00
- task: CmdLine@2
condition: always()
displayName: Cleanup
inputs:
script: |
docker stop $(docker ps -aq)
docker container prune -f
- task: CmdLine@2
displayName: Prepare unittests and coverage for upload
inputs:
script: |
mkdir output-e2e
mv unittest.xml output-e2e/unittest.xml
mv .coverage output-e2e/coverage
- task: PublishPipelineArtifact@1
condition: failed()
displayName: Upload screenshots if selenium tests fail
inputs:
targetPath: 'selenium_screenshots/'
artifact: 'selenium screenshots'
publishLocation: 'pipeline'
- task: PublishPipelineArtifact@1
inputs:
targetPath: 'output-e2e/'
artifact: 'coverage-e2e'
publishLocation: 'pipeline'
2020-07-10 16:25:19 +01:00
- stage: test_combine
jobs:
- job: test_coverage_combine
pool:
vmImage: 'ubuntu-latest'
steps:
- task: DownloadPipelineArtifact@2
inputs:
buildType: 'current'
artifactName: 'coverage-e2e'
path: "coverage-e2e/"
- task: DownloadPipelineArtifact@2
inputs:
buildType: 'current'
artifactName: 'coverage-integration'
path: "coverage-integration/"
- task: DownloadPipelineArtifact@2
inputs:
buildType: 'current'
artifactName: 'coverage-unittest'
path: "coverage-unittest/"
- task: UsePythonVersion@0
inputs:
2020-11-15 14:49:02 +00:00
versionSpec: '3.9'
2020-05-28 18:29:28 +01:00
- task: CmdLine@2
inputs:
script: |
2020-11-15 00:05:20 +00:00
sudo apt install -y libxmlsec1-dev pkg-config
sudo pip install -U wheel pipenv
pipenv install --dev
pipenv run coverage combine coverage-e2e/coverage coverage-unittest/coverage coverage-integration/coverage
pipenv run coverage xml
pipenv run coverage html
- task: PublishCodeCoverageResults@1
inputs:
codeCoverageTool: 'Cobertura'
summaryFileLocation: 'coverage.xml'
pathToSources: '$(System.DefaultWorkingDirectory)'
- task: PublishTestResults@2
condition: succeededOrFailed()
inputs:
testResultsFormat: 'JUnit'
testResultsFiles: |
coverage-e2e/unittest.xml
coverage-integration/unittest.xml
coverage-unittest/unittest.xml
mergeTestResults: true
2020-05-28 18:29:28 +01:00
- task: CmdLine@2
env:
CODECOV_TOKEN: $(CODECOV_TOKEN)
2020-05-28 18:29:28 +01:00
inputs:
script: bash <(curl -s https://codecov.io/bash)
2020-05-28 18:44:25 +01:00
- stage: Build
jobs:
2020-05-28 18:46:10 +01:00
- job: build_server
2020-05-28 18:44:25 +01:00
pool:
vmImage: 'ubuntu-latest'
2020-05-28 20:00:30 +01:00
steps:
- task: Docker@2
inputs:
containerRegistry: 'dockerhub'
2020-12-05 21:08:42 +00:00
repository: 'beryju/authentik'
2020-05-28 20:00:30 +01:00
command: 'buildAndPush'
Dockerfile: 'Dockerfile'
tags: "gh-${{ variables.branchName }}"