# https://aka.ms/yaml variables: PIPENV_HIDE_EMOJIS: 1 PIPENV_IGNORE_VIRTUALENVS: 1 PIPENV_NOSPIN: 1 jobs: - job: test displayName: 'Lint & Test' pool: vmImage: ubuntu-18.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.8.x' addToPath: true - script: pip install pipenv displayName: 'Install pipenv' - script: pipenv install --dev --deploy --system displayName: 'Install project using pipenv' # 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) - script: 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 displayName: Run tests - script: coverage report -m && coverage xml -o coverage.xml displayName: Generate test coverage report - task: PublishCodeCoverageResults@1 displayName: 'Publish Coverage Results' condition: succeededOrFailed() inputs: codeCoverageTool: Cobertura summaryFileLocation: coverage.xml - task: PublishTestResults@2 condition: succeededOrFailed() displayName: 'Publish Test Results' inputs: testResultsFiles: '**/TEST-*.xml' testRunTitle: 'Bot Test Results' - 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/bot' command: 'buildAndPush' Dockerfile: 'Dockerfile' buildContext: '.' tags: 'latest'