mirror of
https://github.com/php/php-src.git
synced 2026-03-24 00:02:20 +01:00
Merge branch 'PHP-8.3' into PHP-8.4
* PHP-8.3: Adjust nightly-results.yml for test.yml Improve displayed workflow_call name Combine push.yml and root.yml into test.yml Rename push.yml to test.yml Rename nightly.yml to test-suite.yml
This commit is contained in:
22
.github/nightly_matrix.php
vendored
22
.github/nightly_matrix.php
vendored
@@ -1,11 +1,11 @@
|
||||
<?php
|
||||
|
||||
const BRANCHES = [
|
||||
['ref' => 'master', 'version' => [8, 6]],
|
||||
['ref' => 'PHP-8.5', 'version' => [8, 5]],
|
||||
['ref' => 'PHP-8.4', 'version' => [8, 4]],
|
||||
['ref' => 'PHP-8.3', 'version' => [8, 3]],
|
||||
['ref' => 'PHP-8.2', 'version' => [8, 2]],
|
||||
['name' => 'master', 'ref' => 'refs/heads/master', 'version' => [8, 6]],
|
||||
['name' => 'PHP-8.5', 'ref' => 'refs/heads/PHP-8.5', 'version' => [8, 5]],
|
||||
['name' => 'PHP-8.4', 'ref' => 'refs/heads/PHP-8.4', 'version' => [8, 4]],
|
||||
['name' => 'PHP-8.3', 'ref' => 'refs/heads/PHP-8.3', 'version' => [8, 3]],
|
||||
['name' => 'PHP-8.2', 'ref' => 'refs/heads/PHP-8.2', 'version' => [8, 2]],
|
||||
];
|
||||
|
||||
function get_branch_commit_cache_file_path(): string {
|
||||
@@ -81,7 +81,7 @@ function select_jobs($repository, $trigger, $nightly, $labels, $php_version, $re
|
||||
: ['type' => ['asan']];
|
||||
$jobs['COMMUNITY']['config']['symfony_version'] = version_compare($php_version, '8.4', '>=') ? '8.1' : '7.4';
|
||||
}
|
||||
if (($all_jobs && $ref === 'master') || $test_coverage) {
|
||||
if (($all_jobs && $ref === 'refs/heads/master') || $test_coverage) {
|
||||
$jobs['COVERAGE'] = true;
|
||||
}
|
||||
if ($all_jobs || $test_libmysqlclient) {
|
||||
@@ -129,7 +129,7 @@ function select_jobs($repository, $trigger, $nightly, $labels, $php_version, $re
|
||||
if ($all_jobs || $test_opcache_variation) {
|
||||
$jobs['OPCACHE_VARIATION'] = true;
|
||||
}
|
||||
if (($all_jobs && $ref === 'master') || $test_pecl) {
|
||||
if (($all_jobs && $ref === 'refs/heads/master') || $test_pecl) {
|
||||
$jobs['PECL'] = true;
|
||||
}
|
||||
if ($all_jobs || !$no_jobs || $test_windows) {
|
||||
@@ -160,14 +160,14 @@ $discard_cache = $sunday
|
||||
if ($discard_cache) {
|
||||
@unlink(get_branch_commit_cache_file_path());
|
||||
}
|
||||
$branch = $argv[3] ?? 'master';
|
||||
$branches = $branch === 'master'
|
||||
$branch = $argv[3] ?? 'refs/heads/master';
|
||||
$nightly = $trigger === 'schedule' || $trigger === 'workflow_dispatch';
|
||||
$branches = $nightly && $branch === 'refs/heads/master'
|
||||
? get_branches()
|
||||
: [['ref' => $branch, 'version' => get_current_version()]];
|
||||
: [['name' => 'Suite', 'ref' => $branch, 'version' => get_current_version()]];
|
||||
|
||||
$labels = json_decode($argv[4] ?? '[]', true) ?? [];
|
||||
$labels = array_column($labels, 'name');
|
||||
$nightly = $trigger === 'schedule' || $trigger === 'workflow_dispatch';
|
||||
$all_variations = $nightly || in_array('CI: All variations', $labels, true);
|
||||
|
||||
$repository = $argv[5] ?? null;
|
||||
|
||||
4
.github/workflows/nightly-results.yml
vendored
4
.github/workflows/nightly-results.yml
vendored
@@ -2,13 +2,13 @@ name: Nightly results
|
||||
on:
|
||||
workflow_run:
|
||||
workflows:
|
||||
- Nightly
|
||||
- Test
|
||||
types:
|
||||
- completed
|
||||
jobs:
|
||||
on-failure:
|
||||
runs-on: ubuntu-latest
|
||||
if: ${{ github.repository == 'php/php-src' && github.event.workflow_run.conclusion == 'failure' }}
|
||||
if: ${{ github.repository == 'php/php-src' && github.event.workflow_run.event == 'schedule' && github.event.workflow_run.conclusion == 'failure' }}
|
||||
steps:
|
||||
- run: |
|
||||
export DEBIAN_FRONTEND=noninteractive
|
||||
|
||||
47
.github/workflows/root.yml
vendored
47
.github/workflows/root.yml
vendored
@@ -1,47 +0,0 @@
|
||||
name: Nightly
|
||||
on:
|
||||
schedule:
|
||||
- cron: "0 1 * * *"
|
||||
workflow_dispatch: ~
|
||||
permissions:
|
||||
contents: read
|
||||
jobs:
|
||||
GENERATE_MATRIX:
|
||||
name: Generate Matrix
|
||||
if: github.repository == 'php/php-src' || github.event_name == 'workflow_dispatch'
|
||||
runs-on: ubuntu-latest
|
||||
outputs:
|
||||
all_variations: ${{ steps.set-matrix.outputs.all_variations }}
|
||||
branches: ${{ steps.set-matrix.outputs.branches }}
|
||||
steps:
|
||||
- uses: actions/checkout@v6
|
||||
with:
|
||||
# Set fetch-depth to 0 to clone the full repository
|
||||
# including all branches. This is required to find
|
||||
# the correct commit hashes.
|
||||
fetch-depth: 0
|
||||
- name: Grab the commit mapping
|
||||
uses: actions/cache@v5
|
||||
with:
|
||||
path: branch-commit-cache.json
|
||||
# The cache key needs to change every time for the
|
||||
# cache to be updated after this job finishes.
|
||||
key: nightly-${{ github.run_id }}-${{ github.run_attempt }}
|
||||
restore-keys: |
|
||||
nightly-
|
||||
- name: Generate Matrix
|
||||
id: set-matrix
|
||||
run: php .github/nightly_matrix.php "${{ github.event_name }}" "${{ github.run_attempt }}" "${{ github.head_ref || github.ref_name }}" '[]' "${{ github.repository }}"
|
||||
NIGHTLY:
|
||||
needs: GENERATE_MATRIX
|
||||
name: ${{ matrix.branch.ref }}
|
||||
if: ${{ needs.GENERATE_MATRIX.outputs.branches != '[]' }}
|
||||
uses: ./.github/workflows/nightly.yml
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
branch: ${{ fromJson(needs.GENERATE_MATRIX.outputs.branches) }}
|
||||
with:
|
||||
all_variations: ${{ needs.GENERATE_MATRIX.outputs.all_variations == 'true' }}
|
||||
branch: ${{ toJSON(matrix.branch) }}
|
||||
secrets: inherit
|
||||
@@ -1,4 +1,4 @@
|
||||
name: Push
|
||||
name: Test
|
||||
on:
|
||||
push:
|
||||
paths-ignore: &ignore_paths
|
||||
@@ -21,6 +21,8 @@ on:
|
||||
paths-ignore: *ignore_paths
|
||||
branches:
|
||||
- '**'
|
||||
schedule:
|
||||
- cron: "0 1 * * *"
|
||||
workflow_dispatch: ~
|
||||
permissions:
|
||||
contents: read
|
||||
@@ -33,20 +35,35 @@ env:
|
||||
jobs:
|
||||
GENERATE_MATRIX:
|
||||
name: Generate Matrix
|
||||
if: github.repository == 'php/php-src' || github.event_name == 'pull_request'
|
||||
if: github.repository == 'php/php-src' || github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch'
|
||||
runs-on: ubuntu-latest
|
||||
outputs:
|
||||
all_variations: ${{ steps.set-matrix.outputs.all_variations }}
|
||||
branches: ${{ steps.set-matrix.outputs.branches }}
|
||||
steps:
|
||||
- uses: actions/checkout@v6
|
||||
with:
|
||||
# When running nightly, set fetch-depth to 0 to clone the full
|
||||
# repository including all branches. This is required to find the
|
||||
# correct commit hashes.
|
||||
fetch-depth: ${{ (github.event_name == 'schedule' || github.event_name == 'workflow_dispatch') && 0 || 1 }}
|
||||
- name: Grab the commit mapping
|
||||
if: ${{ github.event_name == 'schedule' || github.event_name == 'workflow_dispatch' }}
|
||||
uses: actions/cache@v5
|
||||
with:
|
||||
path: branch-commit-cache.json
|
||||
# The cache key needs to change every time for the
|
||||
# cache to be updated after this job finishes.
|
||||
key: nightly-${{ github.run_id }}-${{ github.run_attempt }}
|
||||
restore-keys: |
|
||||
nightly-
|
||||
- name: Generate Matrix
|
||||
id: set-matrix
|
||||
run: php .github/nightly_matrix.php "${{ github.event_name }}" "${{ github.run_attempt }}" "${{ github.ref }}" '${{ toJSON(github.event.pull_request.labels) }}' "${{ github.repository }}"
|
||||
PUSH:
|
||||
needs: GENERATE_MATRIX
|
||||
name: ${{ matrix.branch.ref }}
|
||||
uses: ./.github/workflows/nightly.yml
|
||||
name: ${{ matrix.branch.name }}
|
||||
uses: ./.github/workflows/test-suite.yml
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
Reference in New Issue
Block a user