Run tests #1879
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: Run tests | |
on: | |
pull_request_target: | |
types: [opened, synchronize, labeled] | |
schedule: | |
- cron: '0 0 * * *' | |
jobs: | |
access_check: | |
runs-on: ubuntu-latest | |
name: Access check | |
steps: | |
- name: Ensure pull-request is safe to run | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{secrets.GITHUB_TOKEN}} | |
script: | | |
if (context.eventName === 'schedule') { | |
return | |
} | |
// If the user that pushed the commit is a maintainer, skip the check | |
const collaborators = await github.rest.repos.listCollaborators({ | |
owner: context.repo.owner, | |
repo: context.repo.repo | |
}); | |
if (collaborators.data.some(c => c.login === context.actor)) { | |
console.log(`User ${context.actor} is allowed to run tests because they are a collaborator.`); | |
return | |
} | |
const issue_number = context.issue.number; | |
const repository = context.repo.repo; | |
const owner = context.repo.owner; | |
const response = await github.rest.issues.listLabelsOnIssue({ | |
owner, | |
repo: repository, | |
issue_number | |
}); | |
const labels = response.data.map(label => label.name); | |
let hasLabel = labels.includes('safe-to-test') | |
if (context.payload.action === 'synchronize' && hasLabel) { | |
hasLabel = false | |
await github.rest.issues.removeLabel({ | |
owner, | |
repo: repository, | |
issue_number, | |
name: 'safe-to-test' | |
}); | |
} | |
if (!hasLabel) { | |
throw "Action was not authorized. Exiting now." | |
} | |
php-tests: | |
runs-on: ubuntu-latest | |
needs: access_check | |
strategy: | |
matrix: | |
db: ['mysql', 'pgsql'] | |
payload: | |
- { queue: 'github-actions-laravel10-php84', laravel: '10.*', php: '8.4', 'testbench': '8.*'} | |
- { queue: 'github-actions-laravel10-php83', laravel: '10.*', php: '8.3', 'testbench': '8.*'} | |
- { queue: 'github-actions-laravel10-php82', laravel: '10.*', php: '8.2', 'testbench': '8.*'} | |
- { queue: 'github-actions-laravel10-php81', laravel: '10.*', php: '8.1', 'testbench': '8.*'} | |
- { queue: 'github-actions-laravel11-php82', laravel: '11.*', php: '8.2', 'testbench': '9.*' } | |
- { queue: 'github-actions-laravel11-php83', laravel: '11.*', php: '8.3', 'testbench': '9.*' } | |
- { queue: 'github-actions-laravel11-php84', laravel: '11.*', php: '8.4', 'testbench': '9.*' } | |
name: PHP ${{ matrix.payload.php }} - Laravel ${{ matrix.payload.laravel }} - DB ${{ matrix.db }} | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.event.pull_request.head.sha }} | |
- name: Setup PHP | |
uses: shivammathur/setup-php@v2 | |
with: | |
php-version: ${{ matrix.payload.php }} | |
extensions: mbstring, dom, fileinfo | |
coverage: none | |
- name: Set up MySQL and PostgreSQL | |
env: | |
CI_SERVICE_ACCOUNT_JSON_KEY: ${{ secrets.CI_SERVICE_ACCOUNT_JSON_KEY }} | |
run: | | |
touch .env | |
MYSQL_PORT=3307 POSTGRES_PORT=5432 docker compose up ${{ matrix.db }} -d | |
- name: Install dependencies | |
run: | | |
composer require "laravel/framework:${{ matrix.payload.laravel }}" "orchestra/testbench:${{ matrix.payload.testbench }}" --no-interaction --no-update | |
composer update --prefer-stable --prefer-dist --no-interaction | |
if [ "${{ matrix.db }}" = "mysql" ]; then | |
while ! mysqladmin ping --host=127.0.0.1 --user=cloudtasks --port=3307 --password=cloudtasks --silent; do | |
echo "Waiting for MySQL..." | |
sleep 1 | |
done | |
else | |
echo "Not waiting for MySQL." | |
fi | |
- name: Execute tests | |
env: | |
DB_DRIVER: ${{ matrix.db }} | |
DB_HOST: 127.0.0.1 | |
CI_CLOUD_TASKS_PROJECT_ID: ${{ secrets.CI_CLOUD_TASKS_PROJECT_ID }} | |
CI_CLOUD_TASKS_QUEUE: ${{ secrets.CI_CLOUD_TASKS_QUEUE }} | |
CI_CLOUD_TASKS_LOCATION: ${{ secrets.CI_CLOUD_TASKS_LOCATION }} | |
CI_CLOUD_TASKS_SERVICE_ACCOUNT_EMAIL: ${{ secrets.CI_CLOUD_TASKS_SERVICE_ACCOUNT_EMAIL }} | |
CI_SERVICE_ACCOUNT_JSON_KEY: ${{ secrets.CI_SERVICE_ACCOUNT_JSON_KEY }} | |
CI_CLOUD_TASKS_CUSTOM_QUEUE: ${{ matrix.payload.queue }} | |
run: | | |
echo $CI_SERVICE_ACCOUNT_JSON_KEY > tests/Support/gcloud-key-valid.json | |
touch .env | |
vendor/bin/phpunit |