-
Notifications
You must be signed in to change notification settings - Fork 4.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'airbytehq:master' into feature/github-files
- Loading branch information
Showing
2,952 changed files
with
175,068 additions
and
105,675 deletions.
There are no files selected for viewing
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
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
name: Connectors Insights | ||
|
||
on: | ||
schedule: | ||
- cron: "0 0,12 * * *" # Run every 12 hours UTC | ||
workflow_dispatch: | ||
inputs: | ||
rewrite: | ||
default: false | ||
jobs: | ||
connectors_insights: | ||
name: Connectors Insights generation | ||
runs-on: connector-nightly-xlarge | ||
timeout-minutes: 1440 # 24 hours | ||
steps: | ||
- name: Checkout Airbyte | ||
uses: actions/checkout@v4 | ||
- name: Get Dagger Engine Image | ||
uses: ./.github/actions/get-dagger-engine-image | ||
with: | ||
dagger_engine_image: "registry.dagger.io/engine:v0.9.6" | ||
- name: Set up Python | ||
uses: actions/setup-python@v5 | ||
with: | ||
python-version: "3.11" | ||
- name: Install Poetry | ||
uses: snok/install-poetry@v1 | ||
with: | ||
virtualenvs-create: true | ||
virtualenvs-in-project: true | ||
installer-parallel: true | ||
- name: Load cached venv | ||
id: cached-poetry-dependencies | ||
uses: actions/cache@v3 | ||
with: | ||
path: .venv | ||
key: venv-${{ runner.os }}-${{ steps.setup-python.outputs.python-version }}-${{ hashFiles('**/poetry.lock') }} | ||
- name: Install dependencies | ||
if: steps.cached-poetry-dependencies.outputs.cache-hit != 'true' | ||
run: poetry -C airbyte-ci/connectors/connectors_insights install --no-interaction --no-root | ||
- name: Install project | ||
run: poetry -C airbyte-ci/connectors/connectors_insights install --no-interaction | ||
- name: Write Google service account key to file | ||
run: echo "$GCP_SA_KEY" > $HOME/gcp-sa-key.json | ||
env: | ||
GCP_SA_KEY: ${{ secrets.METADATA_SERVICE_PROD_GCS_CREDENTIALS }} | ||
- name: Set GOOGLE_APPLICATION_CREDENTIALS | ||
run: echo "GOOGLE_APPLICATION_CREDENTIALS=$HOME/gcp-sa-key.json" >> $GITHUB_ENV | ||
- name: Run connectors insights | ||
run: | | ||
poetry -C airbyte-ci/connectors/connectors_insights run connectors-insights generate --gcs-uri=gs://prod-airbyte-cloud-connector-metadata-service/connector_insights --connector-directory airbyte-integrations/connectors/ --concurrency 10 ${{ inputs.rewrite == 'true' && '--rewrite' || ''}} |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
name: Connectors up-to-date | ||
concurrency: | ||
group: ${{ github.workflow }} | ||
cancel-in-progress: false | ||
|
||
on: | ||
schedule: | ||
# Runs everyday Saturday at 12:00 UTC | ||
- cron: "0 12 * * 6" | ||
workflow_dispatch: | ||
inputs: | ||
connectors-options: | ||
description: "Options to pass to the 'airbyte-ci connectors' command group." | ||
default: "--concurrency=10 --language=python --language=low-code" | ||
auto-merge: | ||
description: "Whether to auto-merge the PRs created by the action." | ||
default: "false" | ||
jobs: | ||
connectors_up_to_date: | ||
name: Connectors up-to-date | ||
runs-on: connector-nightly-xlarge | ||
permissions: | ||
pull-requests: write | ||
timeout-minutes: 1440 # 24 hours | ||
steps: | ||
- name: Checkout Airbyte | ||
uses: actions/checkout@v4 | ||
- name: Run airbyte-ci connectors up-to-date | ||
id: airbyte-ci-connectors-up-to-date | ||
uses: ./.github/actions/run-airbyte-ci | ||
with: | ||
context: "master" | ||
dagger_cloud_token: ${{ secrets.DAGGER_CLOUD_TOKEN_2 }} | ||
docker_hub_password: ${{ secrets.DOCKER_HUB_PASSWORD }} | ||
docker_hub_username: ${{ secrets.DOCKER_HUB_USERNAME }} | ||
gcp_gsm_credentials: ${{ secrets.GCP_GSM_CREDENTIALS }} | ||
gcs_credentials: ${{ secrets.METADATA_SERVICE_PROD_GCS_CREDENTIALS }} | ||
github_token: ${{ secrets.AUTO_MERGE_GITHUB_TOKEN }} | ||
sentry_dsn: ${{ secrets.SENTRY_AIRBYTE_CI_DSN }} | ||
s3_build_cache_access_key_id: ${{ secrets.SELF_RUNNER_AWS_ACCESS_KEY_ID }} | ||
s3_build_cache_secret_key: ${{ secrets.SELF_RUNNER_AWS_SECRET_ACCESS_KEY }} | ||
subcommand: "connectors ${{ github.event.inputs.connectors-options || '--concurrency=10 --language=python --language=low-code' }} up-to-date --create-prs ${{ github.event.inputs.auto-merge == 'false' && '' || '--auto-merge' }}" |
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,105 @@ | ||
name: Connector CI - Run Live Validation Tests | ||
|
||
concurrency: | ||
# This is the name of the concurrency group. It is used to prevent concurrent runs of the same workflow. | ||
# | ||
# - github.head_ref is only defined on PR runs, it makes sure that the concurrency group is unique for pull requests | ||
# ensuring that only one run per pull request is active at a time. | ||
# | ||
# - github.run_id is defined on all runs, it makes sure that the concurrency group is unique for workflow dispatches. | ||
# This allows us to run multiple workflow dispatches in parallel. | ||
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||
cancel-in-progress: true | ||
|
||
on: | ||
workflow_dispatch: | ||
inputs: | ||
connector_name: | ||
description: Connector name (e.g. source-faker) | ||
required: true | ||
connection_id: | ||
description: ID of the connection to test; use "auto" to let the connection retriever choose a connection | ||
required: true | ||
pr_url: | ||
description: URL of the PR containing the code change | ||
required: true | ||
streams: | ||
description: Streams to include in tests | ||
use_local_cdk: | ||
description: Use the local CDK when building the target connector | ||
default: "false" | ||
type: boolean | ||
|
||
jobs: | ||
live_tests: | ||
name: Live Tests | ||
runs-on: connector-test-large | ||
timeout-minutes: 360 # 6 hours | ||
steps: | ||
- name: Checkout Airbyte | ||
uses: actions/checkout@v4 | ||
- name: Check PAT rate limits | ||
run: | | ||
./tools/bin/find_non_rate_limited_PAT \ | ||
${{ secrets.GH_PAT_BUILD_RUNNER_OSS }} \ | ||
${{ secrets.GH_PAT_BUILD_RUNNER_BACKUP }} | ||
- name: Extract branch name [WORKFLOW DISPATCH] | ||
shell: bash | ||
if: github.event_name == 'workflow_dispatch' | ||
run: echo "branch=${GITHUB_REF#refs/heads/}" >> $GITHUB_OUTPUT | ||
id: extract_branch | ||
|
||
- name: Install Poetry | ||
id: install_poetry | ||
uses: snok/install-poetry@v1 | ||
|
||
- name: Make poetry venv in project | ||
id: poetry_venv | ||
run: poetry config virtualenvs.in-project true | ||
|
||
- name: Install Python packages | ||
id: install_python_packages | ||
working-directory: airbyte-ci/connectors/pipelines | ||
run: poetry install | ||
|
||
- name: Fetch last commit id from remote branch [WORKFLOW DISPATCH] | ||
if: github.event_name == 'workflow_dispatch' | ||
id: fetch_last_commit_id_wd | ||
run: echo "commit_id=$(git rev-parse origin/${{ steps.extract_branch.outputs.branch }})" >> $GITHUB_OUTPUT | ||
|
||
- name: Setup Stream Parameters | ||
if: github.event_name == 'workflow_dispatch' | ||
run: | | ||
if [ -z "${{ github.event.inputs.streams }}" ]; then | ||
echo "STREAM_PARAMS=" >> $GITHUB_ENV | ||
else | ||
STREAMS=$(echo "${{ github.event.inputs.streams }}" | sed 's/,/ --connector_live_tests.selected-streams=/g') | ||
echo "STREAM_PARAMS=--connector_live_tests.selected-streams=$STREAMS" >> $GITHUB_ENV | ||
fi | ||
- name: Setup Local CDK Flag | ||
if: github.event_name == 'workflow_dispatch' | ||
run: | | ||
if ${{ github.event.inputs.use_local_cdk }}; then | ||
echo "USE_LOCAL_CDK_FLAG=--use-local-cdk" >> $GITHUB_ENV | ||
else | ||
echo "USE_LOCAL_CDK_FLAG=" >> $GITHUB_ENV | ||
fi | ||
- name: Run Live Tests [WORKFLOW DISPATCH] | ||
if: github.event_name == 'workflow_dispatch' # TODO: consider using the matrix strategy (https://docs.github.com/en/actions/using-jobs/using-a-matrix-for-your-jobs). See https://github.com/airbytehq/airbyte/pull/37659#discussion_r1583380234 for details. | ||
uses: ./.github/actions/run-airbyte-ci | ||
with: | ||
context: "manual" | ||
dagger_cloud_token: ${{ secrets.DAGGER_CLOUD_TOKEN_2 }} | ||
docker_hub_password: ${{ secrets.DOCKER_HUB_PASSWORD }} | ||
docker_hub_username: ${{ secrets.DOCKER_HUB_USERNAME }} | ||
gcp_gsm_credentials: ${{ secrets.GCP_GSM_CREDENTIALS }} | ||
gcp_integration_tester_credentials: ${{ secrets.GCLOUD_INTEGRATION_TESTER }} | ||
sentry_dsn: ${{ secrets.SENTRY_AIRBYTE_CI_DSN }} | ||
git_branch: ${{ steps.extract_branch.outputs.branch }} | ||
git_revision: ${{ steps.fetch_last_commit_id_pr.outputs.commit_id }} | ||
github_token: ${{ secrets.GH_PAT_MAINTENANCE_OSS }} | ||
s3_build_cache_access_key_id: ${{ secrets.SELF_RUNNER_AWS_ACCESS_KEY_ID }} | ||
s3_build_cache_secret_key: ${{ secrets.SELF_RUNNER_AWS_SECRET_ACCESS_KEY }} | ||
subcommand: connectors ${{ env.USE_LOCAL_CDK_FLAG }} --name ${{ github.event.inputs.connector_name }} test --only-step connector_live_tests --connector_live_tests.test-suite=all --connector_live_tests.connection-id=${{ github.event.inputs.connection_id }} --connector_live_tests.pr-url=${{ github.event.inputs.pr_url }} ${{ env.STREAM_PARAMS }} --connector_live_tests.test-evaluation-mode=diagnostic |
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
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
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
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
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
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
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
Oops, something went wrong.