aboutsummaryrefslogtreecommitdiffstats
path: root/azure-pipelines.yml
diff options
context:
space:
mode:
authorGravatar Shirayuki Nekomata <[email protected]>2020-05-26 17:31:31 +0700
committerGravatar GitHub <[email protected]>2020-05-26 17:31:31 +0700
commit971369e8cc0cdbbcf03c52dac403dc6c4f388ff0 (patch)
tree6772024cd793c01fb7c8fb6479fdd4f668d7a2a8 /azure-pipelines.yml
parentTags: always use top-most folder for role restrictions (diff)
parent[stats] Do not report modmail channels to stats (diff)
Merge branch 'master' into restricted_tags
Diffstat (limited to 'azure-pipelines.yml')
-rw-r--r--azure-pipelines.yml39
1 files changed, 29 insertions, 10 deletions
diff --git a/azure-pipelines.yml b/azure-pipelines.yml
index 16d1b7a2a..d56675029 100644
--- a/azure-pipelines.yml
+++ b/azure-pipelines.yml
@@ -1,9 +1,13 @@
# https://aka.ms/yaml
variables:
+ PIP_NO_CACHE_DIR: false
+ PIP_USER: 1
PIPENV_HIDE_EMOJIS: 1
PIPENV_IGNORE_VIRTUALENVS: 1
PIPENV_NOSPIN: 1
+ PRE_COMMIT_HOME: $(Pipeline.Workspace)/pre-commit-cache
+ PYTHONUSERBASE: $(Pipeline.Workspace)/py-user-base
jobs:
- job: test
@@ -12,22 +16,38 @@ jobs:
vmImage: ubuntu-18.04
variables:
- PIP_CACHE_DIR: ".cache/pip"
- PRE_COMMIT_HOME: $(Pipeline.Workspace)/pre-commit-cache
+ BOT_API_KEY: foo
+ BOT_SENTRY_DSN: blah
+ BOT_TOKEN: bar
+ REDDIT_CLIENT_ID: spam
+ REDDIT_SECRET: ham
+ WOLFRAM_API_KEY: baz
steps:
- task: UsePythonVersion@0
displayName: 'Set Python version'
- name: PythonVersion
+ name: python
inputs:
versionSpec: '3.8.x'
addToPath: true
+ - task: Cache@2
+ displayName: 'Restore Python environment'
+ inputs:
+ key: python | $(Agent.OS) | "$(python.pythonLocation)" | 0 | ./Pipfile | ./Pipfile.lock
+ cacheHitVar: PY_ENV_RESTORED
+ path: $(PYTHONUSERBASE)
+
+ - script: echo '##vso[task.prependpath]$(PYTHONUSERBASE)/bin'
+ displayName: 'Prepend PATH'
+
- script: pip install pipenv
displayName: 'Install pipenv'
+ condition: and(succeeded(), ne(variables.PY_ENV_RESTORED, 'true'))
- script: pipenv install --dev --deploy --system
displayName: 'Install project using pipenv'
+ condition: and(succeeded(), ne(variables.PY_ENV_RESTORED, 'true'))
# 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.
@@ -35,22 +55,21 @@ jobs:
# 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
+ printf '%s\n%s' '#!/bin/bash' '"${@:2}"' > $(python.pythonLocation)/bin/pipenv \
+ && chmod +x $(python.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)"
+ key: pre-commit | "$(python.pythonLocation)" | 0 | .pre-commit-config.yaml
path: $(PRE_COMMIT_HOME)
- - script: pre-commit run --all-files
+ # pre-commit's venv doesn't allow user installs - not that they're really needed anyway.
+ - script: export PIP_USER=0; pre-commit run --all-files
displayName: 'Run pre-commit hooks'
- - script: BOT_API_KEY=foo BOT_SENTRY_DSN=blah BOT_TOKEN=bar WOLFRAM_API_KEY=baz REDDIT_CLIENT_ID=spam REDDIT_SECRET=ham coverage run -m xmlrunner
+ - script: coverage run -m xmlrunner
displayName: Run tests
- script: coverage report -m && coverage xml -o coverage.xml