-
Notifications
You must be signed in to change notification settings - Fork 4.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
doc: Document our connectors QA checks
- Loading branch information
1 parent
aaf2d7a
commit edb0524
Showing
11 changed files
with
146 additions
and
5 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
81 changes: 81 additions & 0 deletions
81
airbyte-ci/connectors/connectors_qa/connectors_qa/generated/qa-checks.md
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,81 @@ | ||
# Airbyte connectors QA checks | ||
|
||
This document is listing all the static-analysis checks that are performed on the Airbyte connectors. | ||
These checks are running in our CI/CD pipeline and are used to ensure a connector is following the best practices and is respecting the Airbyte standards. | ||
Meeting these standards means that the connector will be able to be safely integrated into the Airbyte platform and released to registries (DockerHub, Pypi etc.). | ||
You can consider these checks as a set of guidelines to follow when developing a connector. | ||
They are by no mean replacing the need for a manual review of the connector codebase and the implementation of good test suites. | ||
|
||
|
||
## 📄 Documentation | ||
|
||
### Breaking changes must be accompanied by a migration guide | ||
*Applies to the following connector languages: java, low-code, python* | ||
|
||
When a breaking change is introduced we check that a migration guide is available. It should be stored under `./docs/integrations/<connector-type>s/<connector-name>-migrations.md`. | ||
This document should contain a section for each breaking change, in order of the version descending. It must explain users which action to take to migrate to the new version. | ||
### Connectors must have user facing documentation | ||
*Applies to the following connector languages: java, low-code, python* | ||
|
||
The user facing connector documentation should be stored under `./docs/integrations/<connector-type>s/<connector-name>.md`. | ||
### Connectors documentation follows our guidelines | ||
*Applies to the following connector languages: java, low-code, python* | ||
|
||
The user facing connector documentation should follow the guidelines defined in the [documentation standards](https://hackmd.io/Bz75cgATSbm7DjrAqgl4rw). | ||
### Connectors must have a changelog entry for each version | ||
*Applies to the following connector languages: java, low-code, python* | ||
|
||
Each new version of a connector must have a changelog entry defined in the user facing documentation in `./docs/integrations/<connector-type>s/<connector-name>.md`. | ||
|
||
## 📝 Metadata | ||
|
||
### Connectors must have valid metadata.yaml file | ||
*Applies to the following connector languages: java, low-code, python* | ||
|
||
Connectors must have a `metadata.yaml` file at the root of their directory. This file is used to build our connector registry. Its structure must follow our metadata schema. Field values are also validated. This is to ensure that all connectors have the required metadata fields and that the metadata is valid. More details in this [documentation](https://docs.airbyte.com/connector-development/connector-metadata-file). | ||
|
||
## 📦 Packaging | ||
|
||
### Connectors must use Poetry for dependency management | ||
*Applies to the following connector languages: python, low-code* | ||
|
||
Connectors must use [Poetry](https://python-poetry.org/) for dependency management. This is to ensure that all connectors use a dependency management tool which locks dependencies and ensures reproducible installs. | ||
### Connectors must be licensed under MIT or Elv2 | ||
*Applies to the following connector languages: java, low-code, python* | ||
|
||
Connectors must be licensed under the MIT or Elv2 license. This is to ensure that all connectors are licensed under a permissive license. More details in our [License FAQ](https://docs.airbyte.com/developer-guides/licenses/license-faq). | ||
### Connector license in metadata.yaml and pyproject.toml file must match | ||
*Applies to the following connector languages: python, low-code* | ||
|
||
Connectors license in metadata.yaml and pyproject.toml file must match. This is to ensure that all connectors are consistently licensed | ||
### Connector version must follow Semantic Versioning | ||
*Applies to the following connector languages: java, low-code, python* | ||
|
||
Connector version must follow the Semantic Versioning scheme. This is to ensure that all connectors follow a consistent versioning scheme. Refer to our [Semantic Versioning for Connectors](https://docs.airbyte.com/contributing-to-airbyte/#semantic-versioning-for-connectors) for more details. | ||
### Connector version in metadata.yaml and pyproject.toml file must match | ||
*Applies to the following connector languages: python, low-code* | ||
|
||
Connector version in metadata.yaml and pyproject.toml file must match. This is to ensure that connector release is consistent. | ||
### Python connectors must have PyPi publishing enabled | ||
*Applies to the following connector languages: python, low-code* | ||
|
||
Python connectors must have [PyPi](https://pypi.org/) publishing enabled in their `metadata.yaml` file. This is declared by setting `remoteRegistries.pypi.enabled` to `true` in metadata.yaml. This is to ensure that all connectors can be published to PyPi and can be used in `airbyte-lib`. | ||
|
||
## 💼 Assets | ||
|
||
### Connectors must have an icon | ||
*Applies to the following connector languages: java, low-code, python* | ||
|
||
Each connector must have an icon available in at the root of the connector code directory. It must be an SVG file named `icon.svg`. | ||
|
||
## 🔒 Security | ||
|
||
### Connectors must use HTTPS only | ||
*Applies to the following connector languages: java, low-code, python* | ||
|
||
Connectors must use HTTPS only when making requests to external services. | ||
### Python connectors must not use a Dockerfile and must declare their base image in metadata.yaml file | ||
*Applies to the following connector languages: python, low-code* | ||
|
||
Connectors must use our Python connector base image (`docker.io/airbyte/python-connector-base`), declared through the `connectorBuildOptions.baseImage` in their `metadata.yaml`. | ||
This is to ensure that all connectors use a base image which is maintained and has security updates. |
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
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
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
Empty file.
24 changes: 24 additions & 0 deletions
24
airbyte-ci/connectors/connectors_qa/tests/integration_tests/test_documentation.py
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,24 @@ | ||
# Copyright (c) 2023 Airbyte, Inc., all rights reserved. | ||
|
||
from importlib import resources | ||
|
||
import connectors_qa | ||
import pytest | ||
from asyncclick.testing import CliRunner | ||
from connectors_qa.cli import generate_documentation | ||
|
||
DOCUMENTATION_FILE_NAME = "qa-checks.md" | ||
DOCUMENTATION_IN_PACKAGE_PATH = resources.files(connectors_qa) / "generated" / DOCUMENTATION_FILE_NAME | ||
|
||
@pytest.mark.asyncio | ||
async def test_generated_qa_checks_documentation_is_up_to_date(tmp_path): | ||
# Arrange | ||
current_doc = DOCUMENTATION_IN_PACKAGE_PATH.read_text() | ||
newly_generated_doc_path = tmp_path / DOCUMENTATION_FILE_NAME | ||
|
||
# Act | ||
await CliRunner().invoke(generate_documentation, [str(tmp_path / "qa-checks.md")], catch_exceptions=False) | ||
|
||
# Assert | ||
suggested_command = f"connectors-qa generate-documentation connectors_qa/generated/{DOCUMENTATION_FILE_NAME}" | ||
assert newly_generated_doc_path.read_text() == current_doc, f"The generated documentation is not up to date. Please run `{suggested_command}` and commit the changes." |
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 @@ | ||
../../../airbyte-ci/connectors/connectors_qa/connectors_qa/generated/qa-checks.md |
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