The GitHub master
and branch builds will build the core Airbyte infrastructure (scheduler, ui, etc) as well as the images for all connectors. Integration tests (tests that run a connector's image against an external resource) can be run one of three ways.
First, you can run the image locally. Connectors should have instructions in the connector's README on how to create or pull credentials necessary for the test. Also, during local development, there is usually a main
entrypoint for Java integrations or main_dev.py
for Python integrations that let you run your connector without containerization, which is fastest for iteration.
Using the following tools:
- flake8
- black
- isort
- mypy
Airbyte CI/CD workflows use them during "test/publish" commands obligatorily.
All their settings are aggregated into the single file pyproject.toml
into Airbyte project root.
Locally all these tools can be launched by the following gradle command:
./gradlew --no-daemon :airbyte-integrations:connectors:<connector_name>:airbytePythonFormat
For instance:
./gradlew --no-daemon :airbyte-integrations:connectors:source-s3:airbytePythonFormat
./gradlew --no-daemon :airbyte-integrations:connectors:source-salesforce:airbytePythonFormat
{% hint style="warning" %} This option is not available to PRs from forks, so it is effectively limited to Airbyte employees. {% endhint %}
If you don't want to handle secrets, you're making a relatively minor change, or you want to ensure the connector's integration test will run remotely, you should request builds on GitHub. You can request an integration test run by creating a comment with a slash command.
Here are some example commands:
/test connector=all
- Runs integration tests for all connectors in a single GitHub workflow. Some of our integration tests interact with rate-limited resources, so please use this judiciously./test connector=source-sendgrid
- Runs integration tests for a single connector on the latest PR commit./test connector=connectors/source-sendgrid
- Runs integration tests for a single connector on the latest PR commit./test connector=source-sendgrid ref=master
- Runs integration tests for a single connector on a different branch./test connector=source-sendgrid ref=d5c53102
- Runs integration tests for a single connector on a specific commit.
A command dispatcher GitHub workflow will launch on comment submission. This dispatcher will add an 👀 reaction to the comment when it starts processing. If there is an error dispatching your request, an error will be appended to your comment. If it launches the test run successfully, a 🚀 reaction will appear on your comment.
Once the integration test workflow launches, it will append a link to the workflow at the end of the comment. A success or failure response will also be added upon workflow completion.
Integration tests can also be manually requested by clicking "Run workflow" and specifying the connector and GitHub ref.
In order for users to reference the new versions of a connector, it needs to be published and available in the dockerhub with the latest tag updated.
As seen previously, GitHub workflow can be triggered by comment submission. Publishing docker images to the dockerhub repository can also be submitted likewise:
Note that integration tests can be triggered with a slightly different syntax for arguments. This second set is required to distinguish between connectors
and bases
folders. Thus, it is also easier to switch between the /test
and /publish
commands:
/test connector=connectors/source-sendgrid
- Runs integration tests for a single connector on the latest PR commit./publish connector=connectors/source-sendgrid
- Publish the docker image if it doesn't exist for a single connector on the latest PR commit.
Commits to master
attempt to launch integration tests. Two workflows launch for each commit: one is a launcher for integration tests, the other is the core build (the same as the default for PR and branch builds).
Since some of our connectors use rate-limited external resources, we don't want to overload from multiple commits to master. If a certain threshold of master
integration tests are running, the integration test launcher passes but does not launch any tests. This can manually be re-run if necessary. The master
build also runs every few hours automatically, and will launch the integration tests at that time.