chore: prevent CI double runs on push + pull_request (#26766)

This commit is contained in:
Maxime Beauchemin
2024-01-23 20:30:53 -08:00
committed by GitHub
parent 7da56a0744
commit c6772b6c78
17 changed files with 132 additions and 31 deletions

View File

@@ -3,6 +3,12 @@ on:
push:
paths:
- "superset/migrations/**"
branches:
- 'master'
pull_request:
paths:
- "superset/migrations/**"
types: [synchronize, opened, reopened, ready_for_review]
jobs:
check_db_migration_conflict:

View File

@@ -33,6 +33,13 @@ jobs:
matrix:
target: ["dev", "lean", "lean310", "websocket", "dockerize"]
platform: ["linux/amd64", "linux/arm64"]
exclude:
# disabling because slow! no python wheels for arm/py39 and
# QEMU is slow!
- target: "dev"
platform: "linux/arm64"
- target: "lean"
platform: "linux/arm64"
fail-fast: false
steps:
- name: "Checkout ${{ github.ref }} ( ${{ github.sha }} )"

View File

@@ -2,9 +2,10 @@ name: License Check
on:
push:
branches-ignore:
- "dependabot/**"
branches:
- 'master'
pull_request:
types: [synchronize, opened, reopened, ready_for_review]
jobs:
config:

54
.github/workflows/no-op.yml vendored Normal file
View File

@@ -0,0 +1,54 @@
# no-op.yml
#
# Purpose:
# This workflow provides a workaround for the "required status checks" feature in GitHub Actions
# when using path-specific conditions in other workflows. Required checks might remain in a "Pending"
# state if the conditions are not met, thus blocking pull requests from being merged.
# This no-op (no operation) workflow provides dummy success statuses for these required jobs when
# the real jobs do not run due to path-specific conditions.
#
# How it works:
# - It defines jobs with the same names as the required jobs in the main workflows.
# - These jobs simply execute a command (`exit 0`) to succeed immediately.
# - When a pull request is created or updated, both this no-op workflow and the main workflows are triggered.
# - If the main workflows' jobs don't run (due to path conditions), these no-op jobs provide successful statuses.
# - If the main workflows' jobs do run and fail, their failure statuses take precedence,
# ensuring that pull requests are not merged with failing checks.
#
# Usage:
# - Ensure that the job names in this workflow match exactly the names of the corresponding jobs in the main workflows.
# - This workflow should be kept as-is, without path-specific conditions.
name: No Operation Checks
on: pull_request
jobs:
frontend-build:
runs-on: ubuntu-latest
steps:
- name: No-op for frontend-build
run: |
echo "This is a no-op step for frontend-build to ensure a successful status."
exit 0
pre-commit:
strategy:
matrix:
python-version: ["3.9"]
runs-on: ubuntu-latest
steps:
- name: No-op for pre-commit
run: |
echo "This is a no-op step for pre-commit to ensure a successful status."
exit 0
python-lint:
strategy:
matrix:
python-version: ["3.9"]
runs-on: ubuntu-latest
steps:
- name: No-op for python-lint
run: |
echo "This is a no-op step for python-lint to ensure a successful status."
exit 0

View File

@@ -2,10 +2,14 @@ name: Prefer TypeScript
on:
push:
branches-ignore:
- "dependabot/**"
branches:
- 'master'
paths:
- "superset-frontend/src/**"
pull_request:
types: [synchronize, opened, reopened, ready_for_review]
paths:
- "superset-frontend/src/**"
jobs:
prefer_typescript:
if: github.ref == 'ref/heads/master' && github.event_name == 'pull_request'

View File

@@ -2,8 +2,8 @@ name: Superset CLI tests
on:
push:
branches-ignore:
- "dependabot/npm_and_yarn/**"
branches:
- 'master'
pull_request:
types: [synchronize, opened, reopened, ready_for_review]

View File

@@ -4,9 +4,12 @@ on:
push:
paths:
- "docs/**"
branches:
- 'master'
pull_request:
paths:
- "docs/**"
types: [synchronize, opened, reopened, ready_for_review]
jobs:
config:

View File

@@ -2,10 +2,8 @@ name: E2E
on:
push:
branches-ignore:
- "dependabot/**/docs/**"
paths-ignore:
- "docs/**"
branches:
- 'master'
pull_request:
types: [synchronize, opened, reopened, ready_for_review]

View File

@@ -2,11 +2,14 @@ name: Frontend
on:
push:
branches-ignore:
- "dependabot/**/docs/**"
- "dependabot/**/cypress-base/**"
branches:
- "master"
paths:
- "superset-frontend/**"
pull_request:
types: [synchronize, opened, reopened, ready_for_review]
paths:
- "superset-frontend/**"
jobs:
frontend-build:

View File

@@ -3,6 +3,8 @@ name: Lint and Test Charts
on:
pull_request:
types: [opened, edited, reopened, synchronize]
paths:
- "helm/**"
jobs:
lint-test:

View File

@@ -3,8 +3,8 @@ name: Python-Integration
on:
push:
branches-ignore:
- "dependabot/npm_and_yarn/**"
branches:
- 'master'
pull_request:
types: [synchronize, opened, reopened, ready_for_review]

View File

@@ -3,10 +3,14 @@ name: Python Misc
on:
push:
branches-ignore:
- "dependabot/npm_and_yarn/**"
branches:
- 'master'
paths:
- "superset/**"
pull_request:
types: [synchronize, opened, reopened, ready_for_review]
paths:
- "superset/**"
jobs:
python-lint:

View File

@@ -3,10 +3,14 @@ name: Python Presto/Hive
on:
push:
branches-ignore:
- "dependabot/npm_and_yarn/**"
branches:
- 'master'
paths:
- "superset/**"
pull_request:
types: [synchronize, opened, reopened, ready_for_review]
paths:
- "superset/**"
jobs:
test-postgres-presto:

View File

@@ -3,10 +3,14 @@ name: Python-Unit
on:
push:
branches-ignore:
- "dependabot/npm_and_yarn/**"
branches:
- 'master'
paths:
- "superset/**"
pull_request:
types: [synchronize, opened, reopened, ready_for_review]
paths:
- "superset/**"
jobs:
unit-tests:

View File

@@ -2,8 +2,8 @@ name: Translations
on:
push:
branches-ignore:
- "dependabot/npm_and_yarn/**"
branches:
- 'master'
pull_request:
types: [synchronize, opened, reopened, ready_for_review]

View File

@@ -1,11 +1,14 @@
name: WebSocket server
on:
push:
branches:
- 'master'
paths:
- "superset-websocket/**"
pull_request:
paths:
- "superset-websocket/**"
types: [synchronize, opened, reopened, ready_for_review]
jobs:
app-checks: