forked from python-discord/site
-
Notifications
You must be signed in to change notification settings - Fork 0
/
azure-pipelines.yml
103 lines (89 loc) · 3.61 KB
/
azure-pipelines.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
# https://aka.ms/yaml
jobs:
- job: test
displayName: 'Test & Lint'
pool:
vmImage: ubuntu-16.04
variables:
PIP_CACHE_DIR: .cache/pip
PRE_COMMIT_HOME: $(Pipeline.Workspace)/pre-commit-cache
steps:
- task: UsePythonVersion@0
displayName: 'Set Python Version'
name: PythonVersion
inputs:
versionSpec: '3.7.x'
addToPath: true
- task: DockerCompose@0
displayName: 'Setup Database'
inputs:
action: Run a specific service
dockerComposeFile: docker-compose.yml
projectName: pydis_web
serviceName: postgres
ports: '7777:5432'
- script: |
pip install pipenv
pipenv install --dev --system
pip install flake8-formatter-junit-xml
displayName: 'Install Project Environment'
# Create an executable shell script which replaces the original pipenv binary.
# The shell script ignores the first argument and executes the rest of the args as a command.
# It makes the `pipenv run flake8` command in the pre-commit hook work by circumventing
# pipenv entirely, which is too dumb to know it should use the system interpreter rather than
# creating a new venv.
- script: |
printf '%s\n%s' '#!/bin/bash' '"${@:2}"' > $(PythonVersion.pythonLocation)/bin/pipenv \
&& chmod +x $(PythonVersion.pythonLocation)/bin/pipenv
displayName: 'Mock pipenv binary'
- task: Cache@2
displayName: 'Restore pre-commit environment'
inputs:
key: pre-commit | "$(PythonVersion.pythonLocation)" | .pre-commit-config.yaml
restoreKeys: |
pre-commit | "$(PythonVersion.pythonLocation)"
path: $(PRE_COMMIT_HOME)
# flake8 runs so it can generate the XML output. pre-commit will run it again to show stdout.
# flake8 standalone runs first to avoid any fixes pre-commit hooks may make.
- script: flake8 --format junit-xml --output-file TEST-lint.xml; pre-commit run --all-files
displayName: 'Run pre-commit hooks'
- script: |
python3 manage.py makemigrations --check
python3 manage.py migrate
coverage run \
manage.py test \
--testrunner xmlrunner.extra.djangotestrunner.XMLTestRunner \
--no-input
env:
CI: azure
DATABASE_URL: postgres://pysite:pysite@localhost:7777/pysite
METRICITY_DB_URL: postgres://pysite:pysite@localhost:7777/metricity
displayName: 'Run Tests'
- script: coverage report -m && coverage xml
displayName: 'Generate Coverage Reports'
- task: PublishTestResults@2
condition: succeededOrFailed()
displayName: 'Publish Test & Linting Results'
inputs:
testResultsFiles: '**/TEST-*.xml'
testRunTitle: 'Site Test Results'
- task: PublishCodeCoverageResults@1
displayName: 'Publish Coverage Results'
condition: succeededOrFailed()
inputs:
codeCoverageTool: Cobertura
summaryFileLocation: '**/coverage.xml'
- job: build
displayName: 'Build & Push Container'
dependsOn: test
condition: and(succeeded(), ne(variables['Build.Reason'], 'PullRequest'), eq(variables['Build.SourceBranch'], 'refs/heads/master'))
steps:
- task: Docker@2
displayName: 'Build & Push Container'
inputs:
containerRegistry: 'DockerHub'
repository: 'pythondiscord/site'
command: 'buildAndPush'
Dockerfile: 'docker/Dockerfile'
buildContext: '.'
tags: 'latest'