TEST #76
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: debug | |
on: | |
push: | |
branches: | |
- 'master' | |
- 'release/**' | |
tags: | |
- '**' | |
pull_request: | |
workflow_dispatch: | |
workflow_call: | |
inputs: | |
submodule: | |
description: Name of submodule to bump. | |
required: true | |
type: string | |
revision: | |
description: Git revision from submodule repository | |
required: true | |
type: string | |
concurrency: | |
# Update of a developer branch cancels the previously scheduled workflow | |
# run for this branch. However, the 'master' branch, release branch, and | |
# tag workflow runs are never canceled. | |
# | |
# We use a trick here: define the concurrency group as 'workflow run ID' + | |
# 'workflow run attempt' because it is a unique combination for any run. | |
# So it effectively discards grouping. | |
# | |
# Important: we cannot use `github.sha` as a unique identifier because | |
# pushing a tag may cancel a run that works on a branch push event. | |
group: ${{ ( | |
github.ref == 'refs/heads/master' || | |
startsWith(github.ref, 'refs/heads/release/') || | |
startsWith(github.ref, 'refs/tags/')) && | |
format('{0}-{1}', github.run_id, github.run_attempt) || | |
format('{0}-{1}-debug', github.workflow, github.ref) }} | |
cancel-in-progress: true | |
jobs: | |
debug: | |
# Run on push to the 'master' and release branches of tarantool/tarantool | |
# or on pull request if the 'notest' label is not set. | |
if: github.repository_owner == 'tarantool' && | |
( github.event_name != 'pull_request' || | |
( github.event_name == 'pull_request' && | |
!contains(github.event.pull_request.labels.*.name, 'notest') ) ) | |
runs-on: ubuntu-20.04-self-hosted | |
timeout-minutes: 60 | |
container: | |
image: docker.io/tarantool/testing:ubuntu-focal | |
# Mount /dev to the container to be able to mount a disk image inside it | |
# for successful run of the .github/actions/environment action. | |
volumes: | |
- /dev:/dev | |
# Our testing expects that the init process (PID 1) will | |
# reap orphan processes. At least the following test leans | |
# on it: app-tap/gh-4983-tnt-e-assert-false-hangs.test.lua. | |
# Add extra privileges to the container for successful run | |
# of the .github/actions/environment action. | |
options: '--init --privileged' | |
steps: | |
- name: Prepare checkout | |
uses: tarantool/actions/prepare-checkout@master | |
- name: Sources checkout | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
submodules: recursive | |
repository: tarantool/tarantool | |
ref: ${{ inputs.submodule && 'master' || github.ref }} | |
- name: Set environment | |
uses: ./.github/actions/environment | |
- name: Install deps | |
uses: ./.github/actions/install-deps-debian | |
- name: Optional submodule bump | |
if: ${{ inputs.submodule }} | |
uses: ./.github/actions/bump-submodule | |
with: | |
submodule: ${{ inputs.submodule }} | |
revision: ${{ inputs.revision }} | |
- name: Run testing | |
run: make -f .test.mk test-debug | |
- name: Send VK Teams message on failure | |
if: failure() | |
uses: ./.github/actions/report-job-status | |
with: | |
bot-token: ${{ secrets.VKTEAMS_BOT_TOKEN }} | |
- name: Collect artifacts | |
uses: actions/upload-artifact@v4 | |
if: failure() | |
with: | |
name: failure-logs | |
retention-days: 21 | |
path: ${{ env.VARDIR }}/artifacts | |
- name: Upload artifacts to S3 | |
uses: ./.github/actions/s3-upload-artifact | |
if: ( success() || failure() ) && ( github.ref == 'refs/heads/master' || | |
startsWith(github.ref, 'refs/heads/release/') || | |
startsWith(github.ref, 'refs/tags/') ) | |
with: | |
job-name: ${{ github.job }} | |
access-key-id: ${{ secrets.MULTIVAC_S3_ACCESS_KEY_ID }} | |
secret-access-key: ${{ secrets.MULTIVAC_S3_SECRET_ACCESS_KEY }} | |
source: ${{ env.VARDIR }}/artifacts |