diff options
Diffstat (limited to 'azure-pipelines.yml')
| -rw-r--r-- | azure-pipelines.yml | 39 | 
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 | 
