From d30fe41ff2fc39918933408ff2bf4b2e2df8b539 Mon Sep 17 00:00:00 2001 From: Stephane Geneix <147216312+stephane-airbyte@users.noreply.github.com> Date: Thu, 22 Feb 2024 09:04:02 -0800 Subject: [PATCH] airbyte-ci: augment the report for java connectors (#35317) Today we're missing the logs (both JVM and container logs) in java connector reports. This is creating a link to test artifacts. In the CI, the link will point to a zip file, while on a local run, it will point to a directory. In addition, we recently added the junit XML inlined with the test standard output and error, but that didn't really work as well as we'd hoped: The reports were slow to load, they were not ordered by time, the corresponding logs were lacking. There's still a possibility they'll be useful, so rather than removing them altogether, they will be bundled in the log zip (or directory). I'm also adding a button to copy the standard output or the standard error from a step into the clipboard. Finally, I'm reducing the max vertical size of an expanded step, so it doesn't go over 70%, which seems much cleaner to me. Here's an example of the result (from the child PR): https://storage.cloud.google.com/airbyte-ci-reports-multi/airbyte-ci/connectors/test/pull_request/stephane_02-09-add_background_thread_to_track_mssql_container_status/1708056420/d4683bfb7f90675c6b9e7c6d4bbad3f98c7a7550/source-mssql/3.7.0/output.html --- .../src/main/resources/log4j2-test.xml | 3 +- airbyte-ci/connectors/pipelines/README.md | 3 +- .../connectors/build_image/steps/__init__.py | 2 +- .../connectors/build_image/steps/common.py | 2 +- .../build_image/steps/java_connectors.py | 2 +- .../build_image/steps/normalization.py | 2 +- .../connectors/bump_version/pipeline.py | 14 +- .../migrate_to_base_image/pipeline.py | 24 +-- .../airbyte_ci/connectors/publish/pipeline.py | 2 +- .../airbyte_ci/connectors/reports.py | 67 ++++++-- .../connectors/test/steps/java_connectors.py | 14 +- .../test/steps/python_connectors.py | 10 +- .../test/steps/templates/test_report.html.j2 | 26 ++- .../connectors/upgrade_cdk/pipeline.py | 4 +- .../airbyte_ci/format/format_command.py | 6 +- .../pipelines/airbyte_ci/steps/gradle.py | 157 +++++++++--------- .../pipelines/pipelines/helpers/utils.py | 23 ++- .../pipelines/pipelines/models/artifacts.py | 47 ++++++ .../pipelines/pipelines/models/reports.py | 92 +++++----- .../pipelines/pipelines/models/steps.py | 8 +- .../connectors/pipelines/pyproject.toml | 2 +- .../connectors/pipelines/tests/test_bases.py | 2 +- .../test_python_connectors.py | 8 +- .../test_execution/test_run_steps.py | 16 +- .../pipelines/tests/test_publish.py | 4 +- .../test_tests/test_python_connectors.py | 8 +- 26 files changed, 339 insertions(+), 209 deletions(-) create mode 100644 airbyte-ci/connectors/pipelines/pipelines/models/artifacts.py diff --git a/airbyte-cdk/java/airbyte-cdk/dependencies/src/main/resources/log4j2-test.xml b/airbyte-cdk/java/airbyte-cdk/dependencies/src/main/resources/log4j2-test.xml index 5fa11880cfba..9c9e72c2c33f 100644 --- a/airbyte-cdk/java/airbyte-cdk/dependencies/src/main/resources/log4j2-test.xml +++ b/airbyte-cdk/java/airbyte-cdk/dependencies/src/main/resources/log4j2-test.xml @@ -7,8 +7,7 @@ %d{yyyy-MM-dd'T'HH:mm:ss,SSS}{GMT+0}`%replace{%X{log_source}}{^ -}{} > %replace{%m}{$${env:LOG_SCRUB_PATTERN:-\*\*\*\*\*}}{*****}%n ${sys:LOG_LEVEL:-${env:LOG_LEVEL:-INFO}} - ${env:AIRBYTE_LOG_SUBDIR:-${date:yyyy-MM-dd'T'HH:mm:ss}} - build/test-logs/${logSubDir} + build/test-logs/${date:yyyy-MM-dd'T'HH:mm:ss} diff --git a/airbyte-ci/connectors/pipelines/README.md b/airbyte-ci/connectors/pipelines/README.md index e63b59c46136..7d92fc08cad2 100644 --- a/airbyte-ci/connectors/pipelines/README.md +++ b/airbyte-ci/connectors/pipelines/README.md @@ -644,7 +644,8 @@ E.G.: running Poe tasks on the modified internal packages of the current branch: | Version | PR | Description | | ------- | ---------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------- | -| 4.3.2 | [#35536](https://github.com/airbytehq/airbyte/pull/35536) | Make QA checks run correctly on `*-strict-encrypt` connectors. | +| 4.4.0 | [#35317](https://github.com/airbytehq/airbyte/pull/35317) | Augment java connector reports to include full logs and junit test results | +| 4.3.2 | [#35536](https://github.com/airbytehq/airbyte/pull/35536) | Make QA checks run correctly on `*-strict-encrypt` connectors. | | 4.3.1 | [#35437](https://github.com/airbytehq/airbyte/pull/35437) | Do not run QA checks on publish, just MetadataValidation. | | 4.3.0 | [#35438](https://github.com/airbytehq/airbyte/pull/35438) | Optionally disable telemetry with environment variable. | | 4.2.4 | [#35325](https://github.com/airbytehq/airbyte/pull/35325) | Use `connectors_qa` for QA checks and remove redundant checks. | diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/__init__.py b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/__init__.py index 7a47568639a6..712062361242 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/__init__.py +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/__init__.py @@ -47,7 +47,7 @@ async def run_connector_build_pipeline(context: ConnectorContext, semaphore: any async with semaphore: async with context: build_result = await run_connector_build(context) - per_platform_built_containers = build_result.output_artifact + per_platform_built_containers = build_result.output step_results.append(build_result) if context.is_local and build_result.status is StepStatus.SUCCESS: load_image_result = await LoadContainerToLocalDockerHost(context, per_platform_built_containers, image_tag).run() diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/common.py b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/common.py index 687b566f8fa5..f7ae65bffcfc 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/common.py +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/common.py @@ -48,7 +48,7 @@ async def _run(self, *args: Any) -> StepResult: f"The {self.context.connector.technical_name} docker image " f"was successfully built for platform(s) {', '.join(self.build_platforms)}" ) - return StepResult(step=self, status=StepStatus.SUCCESS, stdout=success_message, output_artifact=build_results_per_platform) + return StepResult(step=self, status=StepStatus.SUCCESS, stdout=success_message, output=build_results_per_platform) async def _build_connector(self, platform: Platform, *args: Any, **kwargs: Any) -> Container: """Implement the generation of the image for the platform and return the corresponding container. diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/java_connectors.py b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/java_connectors.py index aa0b3448ba68..8d31bd5a714a 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/java_connectors.py +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/java_connectors.py @@ -59,7 +59,7 @@ async def run_connector_build(context: ConnectorContext) -> StepResult: build_connector_tar_result = await BuildConnectorDistributionTar(context).run() if build_connector_tar_result.status is not StepStatus.SUCCESS: return build_connector_tar_result - dist_dir = await build_connector_tar_result.output_artifact.directory(dist_tar_directory_path(context)) + dist_dir = await build_connector_tar_result.output.directory(dist_tar_directory_path(context)) return await BuildConnectorImages(context).run(dist_dir) diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/normalization.py b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/normalization.py index 0ac35aab7fa4..7a3bae6d0ac3 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/normalization.py +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/build_image/steps/normalization.py @@ -36,4 +36,4 @@ async def _run(self) -> StepResult: build_normalization_container = normalization.with_normalization(self.context, self.build_platform) else: build_normalization_container = self.context.dagger_client.container().from_(self.normalization_image) - return StepResult(step=self, status=StepStatus.SUCCESS, output_artifact=build_normalization_container) + return StepResult(step=self, status=StepStatus.SUCCESS, output=build_normalization_container) diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/bump_version/pipeline.py b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/bump_version/pipeline.py index 7b2fda58b3d5..329da37639b3 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/bump_version/pipeline.py +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/bump_version/pipeline.py @@ -55,7 +55,7 @@ async def _run(self) -> StepResult: step=self, status=StepStatus.SKIPPED, stdout="Connector does not have a documentation file.", - output_artifact=self.repo_dir, + output=self.repo_dir, ) try: updated_doc = self.add_changelog_entry(doc_path.read_text()) @@ -64,14 +64,14 @@ async def _run(self) -> StepResult: step=self, status=StepStatus.FAILURE, stdout=f"Could not add changelog entry: {e}", - output_artifact=self.repo_dir, + output=self.repo_dir, ) updated_repo_dir = self.repo_dir.with_new_file(str(doc_path), contents=updated_doc) return StepResult( step=self, status=StepStatus.SUCCESS, stdout=f"Added changelog entry to {doc_path}", - output_artifact=updated_repo_dir, + output=updated_repo_dir, ) def find_line_index_for_new_entry(self, markdown_text: str) -> int: @@ -118,7 +118,7 @@ async def _run(self) -> StepResult: step=self, status=StepStatus.SKIPPED, stdout="Can't retrieve the connector current version.", - output_artifact=self.repo_dir, + output=self.repo_dir, ) updated_metadata_str = self.get_metadata_with_bumped_version(current_version, self.new_version, current_metadata_str) repo_dir_with_updated_metadata = metadata_change_helpers.get_repo_dir_with_updated_metadata_str( @@ -134,7 +134,7 @@ async def _run(self) -> StepResult: step=self, status=StepStatus.SUCCESS, stdout=f"Updated dockerImageTag from {current_version} to {self.new_version} in {metadata_path}", - output_artifact=repo_dir_with_updated_metadata, + output=repo_dir_with_updated_metadata, ) @@ -164,7 +164,7 @@ async def run_connector_version_bump_pipeline( new_version, ) update_docker_image_tag_in_metadata_result = await update_docker_image_tag_in_metadata.run() - repo_dir_with_updated_metadata = update_docker_image_tag_in_metadata_result.output_artifact + repo_dir_with_updated_metadata = update_docker_image_tag_in_metadata_result.output steps_results.append(update_docker_image_tag_in_metadata_result) add_changelog_entry = AddChangelogEntry( @@ -176,7 +176,7 @@ async def run_connector_version_bump_pipeline( ) add_changelog_entry_result = await add_changelog_entry.run() steps_results.append(add_changelog_entry_result) - final_repo_dir = add_changelog_entry_result.output_artifact + final_repo_dir = add_changelog_entry_result.output await og_repo_dir.diff(final_repo_dir).export(str(git.get_git_repo_path())) report = ConnectorReport(context, steps_results, name="CONNECTOR VERSION BUMP RESULTS") context.report = report diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/migrate_to_base_image/pipeline.py b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/migrate_to_base_image/pipeline.py index 47fba701ff99..cb1f6d357d3a 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/migrate_to_base_image/pipeline.py +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/migrate_to_base_image/pipeline.py @@ -64,7 +64,7 @@ async def _run(self) -> StepResult: step=self, status=StepStatus.SKIPPED, stdout="Could not find a base image for this connector language.", - output_artifact=self.repo_dir, + output=self.repo_dir, ) metadata_path = self.context.connector.metadata_file_path @@ -76,7 +76,7 @@ async def _run(self) -> StepResult: step=self, status=StepStatus.SKIPPED, stdout="Connector does not have a base image metadata field.", - output_artifact=self.repo_dir, + output=self.repo_dir, ) if current_base_image_address == latest_base_image_address: @@ -84,7 +84,7 @@ async def _run(self) -> StepResult: step=self, status=StepStatus.SKIPPED, stdout="Connector already uses latest base image", - output_artifact=self.repo_dir, + output=self.repo_dir, ) updated_metadata = self.update_base_image_in_metadata(current_metadata, latest_base_image_address) updated_repo_dir = metadata_change_helpers.get_repo_dir_with_updated_metadata(self.repo_dir, metadata_path, updated_metadata) @@ -93,7 +93,7 @@ async def _run(self) -> StepResult: step=self, status=StepStatus.SUCCESS, stdout=f"Updated base image to {latest_base_image_address} in {metadata_path}", - output_artifact=updated_repo_dir, + output=updated_repo_dir, ) @@ -146,7 +146,7 @@ async def _run(self) -> StepResult: step=self, status=StepStatus.SKIPPED, stdout="Connector does not have a documentation file.", - output_artifact=self.repo_dir, + output=self.repo_dir, ) current_readme = await (await self.context.get_connector_dir(include=["README.md"])).file("README.md").contents() try: @@ -156,14 +156,14 @@ async def _run(self) -> StepResult: step=self, status=StepStatus.FAILURE, stdout=str(e), - output_artifact=self.repo_dir, + output=self.repo_dir, ) updated_repo_dir = await self.repo_dir.with_new_file(str(readme_path), contents=updated_readme) return StepResult( step=self, status=StepStatus.SUCCESS, stdout=f"Added build instructions to {readme_path}", - output_artifact=updated_repo_dir, + output=updated_repo_dir, ) def add_build_instructions(self, og_doc_content: str) -> str: @@ -276,7 +276,7 @@ async def run_connector_base_image_upgrade_pipeline(context: ConnectorContext, s ) update_base_image_in_metadata_result = await update_base_image_in_metadata.run() steps_results.append(update_base_image_in_metadata_result) - final_repo_dir = update_base_image_in_metadata_result.output_artifact + final_repo_dir = update_base_image_in_metadata_result.output await og_repo_dir.diff(final_repo_dir).export(str(git.get_git_repo_path())) report = ConnectorReport(context, steps_results, name="BASE IMAGE UPGRADE RESULTS") context.report = report @@ -324,7 +324,7 @@ async def run_connector_migration_to_base_image_pipeline( new_version = get_bumped_version(context.connector.version, "patch") bump_version_in_metadata = BumpDockerImageTagInMetadata( context, - update_base_image_in_metadata_result.output_artifact, + update_base_image_in_metadata_result.output, new_version, ) bump_version_in_metadata_result = await bump_version_in_metadata.run() @@ -333,7 +333,7 @@ async def run_connector_migration_to_base_image_pipeline( # ADD CHANGELOG ENTRY add_changelog_entry = AddChangelogEntry( context, - bump_version_in_metadata_result.output_artifact, + bump_version_in_metadata_result.output, new_version, "Base image migration: remove Dockerfile and use the python-connector-base image", pull_request_number, @@ -344,13 +344,13 @@ async def run_connector_migration_to_base_image_pipeline( # UPDATE DOC add_build_instructions_to_doc = AddBuildInstructionsToReadme( context, - add_changelog_entry_result.output_artifact, + add_changelog_entry_result.output, ) add_build_instructions_to_doc_results = await add_build_instructions_to_doc.run() steps_results.append(add_build_instructions_to_doc_results) # EXPORT MODIFIED FILES BACK TO HOST - final_repo_dir = add_build_instructions_to_doc_results.output_artifact + final_repo_dir = add_build_instructions_to_doc_results.output await og_repo_dir.diff(final_repo_dir).export(str(git.get_git_repo_path())) report = ConnectorReport(context, steps_results, name="MIGRATE TO BASE IMAGE RESULTS") context.report = report diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/publish/pipeline.py b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/publish/pipeline.py index 849a9348f115..88c917211946 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/publish/pipeline.py +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/publish/pipeline.py @@ -313,7 +313,7 @@ def create_connector_report(results: List[StepResult]) -> ConnectorReport: if build_connector_results.status is not StepStatus.SUCCESS: return create_connector_report(results) - built_connector_platform_variants = list(build_connector_results.output_artifact.values()) + built_connector_platform_variants = list(build_connector_results.output.values()) push_connector_image_results = await PushConnectorImageToRegistry(context).run(built_connector_platform_variants) results.append(push_connector_image_results) diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/reports.py b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/reports.py index b8265c4385a1..594b9573ee57 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/reports.py +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/reports.py @@ -6,13 +6,15 @@ import json import webbrowser from dataclasses import dataclass -from typing import TYPE_CHECKING +from pathlib import Path +from types import MappingProxyType +from typing import TYPE_CHECKING, Dict -from anyio import Path from connector_ops.utils import console # type: ignore from jinja2 import Environment, PackageLoader, select_autoescape from pipelines.consts import GCS_PUBLIC_DOMAIN from pipelines.helpers.utils import format_duration +from pipelines.models.artifacts import Artifact from pipelines.models.reports import Report from pipelines.models.steps import StepStatus from rich.console import Group @@ -42,13 +44,19 @@ def report_output_prefix(self) -> str: def html_report_file_name(self) -> str: return self.filename + ".html" + def file_remote_storage_key(self, file_name: str) -> str: + return f"{self.report_output_prefix}/{file_name}" + @property def html_report_remote_storage_key(self) -> str: - return f"{self.report_output_prefix}/{self.html_report_file_name}" + return self.file_remote_storage_key(self.html_report_file_name) + + def file_url(self, file_name: str) -> str: + return f"{GCS_PUBLIC_DOMAIN}/{self.pipeline_context.ci_report_bucket}/{self.file_remote_storage_key(file_name)}" @property def html_report_url(self) -> str: - return f"{GCS_PUBLIC_DOMAIN}/{self.pipeline_context.ci_report_bucket}/{self.html_report_remote_storage_key}" + return self.file_url(self.html_report_file_name) def to_json(self) -> str: """Create a JSON representation of the connector test report. @@ -81,7 +89,7 @@ def to_json(self) -> str: } ) - async def to_html(self) -> str: + def to_html(self) -> str: env = Environment( loader=PackageLoader("pipelines.airbyte_ci.connectors.test.steps"), autoescape=select_autoescape(), @@ -91,7 +99,18 @@ async def to_html(self) -> str: template = env.get_template("test_report.html.j2") template.globals["StepStatus"] = StepStatus template.globals["format_duration"] = format_duration - local_icon_path = await Path(f"{self.pipeline_context.connector.code_directory}/icon.svg").resolve() + local_icon_path = Path(f"{self.pipeline_context.connector.code_directory}/icon.svg").resolve() + step_result_to_artifact_links: Dict[str, List[Dict]] = {} + for step_result in self.steps_results: + for artifact in step_result.artifacts: + if artifact.gcs_url: + url = artifact.gcs_url + elif artifact.local_path: + url = artifact.local_path.resolve().as_uri() + else: + continue + step_result_to_artifact_links.setdefault(step_result.step.title, []).append({"name": artifact.name, "url": url}) + template_context = { "connector_name": self.pipeline_context.connector.technical_name, "step_results": self.steps_results, @@ -104,6 +123,8 @@ async def to_html(self) -> str: "git_revision": self.pipeline_context.git_revision, "commit_url": None, "icon_url": local_icon_path.as_uri(), + "report": self, + "step_result_to_artifact_links": MappingProxyType(step_result_to_artifact_links), } if self.pipeline_context.is_ci: @@ -116,18 +137,32 @@ async def to_html(self) -> str: ] = f"https://raw.githubusercontent.com/airbytehq/airbyte/{self.pipeline_context.git_revision}/{self.pipeline_context.connector.code_directory}/icon.svg" return template.render(template_context) + async def save_html_report(self) -> None: + """Save the report as HTML, upload it to GCS if the pipeline is running in CI""" + + html_report_path = self.report_dir_path / self.html_report_file_name + report_dir = self.pipeline_context.dagger_client.host().directory(str(self.report_dir_path)) + local_html_report_file = report_dir.with_new_file(self.html_report_file_name, self.to_html()).file(self.html_report_file_name) + html_report_artifact = Artifact(name="HTML Report", content_type="text/html", content=local_html_report_file) + await html_report_artifact.save_to_local_path(html_report_path) + absolute_path = html_report_path.absolute() + self.pipeline_context.logger.info(f"Report saved locally at {absolute_path}") + if self.remote_storage_enabled and self.pipeline_context.ci_gcs_credentials_secret and self.pipeline_context.ci_report_bucket: + gcs_url = await html_report_artifact.upload_to_gcs( + dagger_client=self.pipeline_context.dagger_client, + bucket=self.pipeline_context.ci_report_bucket, + key=self.html_report_remote_storage_key, + gcs_credentials=self.pipeline_context.ci_gcs_credentials_secret, + ) + self.pipeline_context.logger.info(f"HTML report uploaded to {gcs_url}") + + elif self.pipeline_context.enable_report_auto_open: + self.pipeline_context.logger.info("Opening HTML report in browser.") + webbrowser.open(absolute_path.as_uri()) + async def save(self) -> None: - local_html_path = await self.save_local(self.html_report_file_name, await self.to_html()) - absolute_path = await local_html_path.resolve() - if self.pipeline_context.enable_report_auto_open: - self.pipeline_context.logger.info(f"HTML report saved locally: {absolute_path}") - if self.pipeline_context.enable_report_auto_open: - self.pipeline_context.logger.info("Opening HTML report in browser.") - webbrowser.open(absolute_path.as_uri()) - if self.remote_storage_enabled: - await self.save_remote(local_html_path, self.html_report_remote_storage_key, "text/html") - self.pipeline_context.logger.info(f"HTML report uploaded to {self.html_report_url}") await super().save() + await self.save_html_report() def print(self) -> None: """Print the test report to the console in a nice way.""" diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/java_connectors.py b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/java_connectors.py index c69a0ac4fb42..a4259b8f67c8 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/java_connectors.py +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/java_connectors.py @@ -38,7 +38,7 @@ class IntegrationTests(GradleTask): gradle_task_name = "integrationTestJava" mount_connector_secrets = True bind_to_docker_host = True - with_test_report = True + with_test_artifacts = True @property def default_params(self) -> STEP_PARAMS: @@ -80,7 +80,7 @@ class UnitTests(GradleTask): title = "Java Connector Unit Tests" gradle_task_name = "test" bind_to_docker_host = True - with_test_report = True + with_test_artifacts = True def _create_integration_step_args_factory(context: ConnectorContext) -> Callable: @@ -90,14 +90,14 @@ def _create_integration_step_args_factory(context: ConnectorContext) -> Callable async def _create_integration_step_args(results: RESULTS_DICT) -> Dict[str, Optional[File]]: - connector_container = results["build"].output_artifact[LOCAL_BUILD_PLATFORM] + connector_container = results["build"].output[LOCAL_BUILD_PLATFORM] connector_image_tar_file, _ = await export_container_to_tarball(context, connector_container, LOCAL_BUILD_PLATFORM) if context.connector.supports_normalization: tar_file_name = f"{context.connector.normalization_repository}_{context.git_revision}.tar" build_normalization_results = results["build_normalization"] - normalization_container = build_normalization_results.output_artifact + normalization_container = build_normalization_results.output normalization_tar_file, _ = await export_container_to_tarball( context, normalization_container, LOCAL_BUILD_PLATFORM, tar_file_name=tar_file_name ) @@ -138,9 +138,7 @@ def _get_acceptance_test_steps(context: ConnectorContext) -> List[StepToRun]: StepToRun( id=CONNECTOR_TEST_STEP_ID.ACCEPTANCE, step=AcceptanceTests(context, True), - args=lambda results: { - "connector_under_test_container": results[CONNECTOR_TEST_STEP_ID.BUILD].output_artifact[LOCAL_BUILD_PLATFORM] - }, + args=lambda results: {"connector_under_test_container": results[CONNECTOR_TEST_STEP_ID.BUILD].output[LOCAL_BUILD_PLATFORM]}, depends_on=[CONNECTOR_TEST_STEP_ID.BUILD], ), ] @@ -159,7 +157,7 @@ def get_test_steps(context: ConnectorContext) -> STEP_TREE: id=CONNECTOR_TEST_STEP_ID.BUILD, step=BuildConnectorImages(context), args=lambda results: { - "dist_dir": results[CONNECTOR_TEST_STEP_ID.BUILD_TAR].output_artifact.directory(dist_tar_directory_path(context)) + "dist_dir": results[CONNECTOR_TEST_STEP_ID.BUILD_TAR].output.directory(dist_tar_directory_path(context)) }, depends_on=[CONNECTOR_TEST_STEP_ID.BUILD_TAR], ), diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/python_connectors.py b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/python_connectors.py index c19c807fcea0..c7cc04cea7f3 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/python_connectors.py +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/python_connectors.py @@ -253,7 +253,7 @@ def get_test_steps(context: ConnectorContext) -> STEP_TREE: StepToRun( id=CONNECTOR_TEST_STEP_ID.UNIT, step=UnitTests(context), - args=lambda results: {"connector_under_test": results[CONNECTOR_TEST_STEP_ID.BUILD].output_artifact[LOCAL_BUILD_PLATFORM]}, + args=lambda results: {"connector_under_test": results[CONNECTOR_TEST_STEP_ID.BUILD].output[LOCAL_BUILD_PLATFORM]}, depends_on=[CONNECTOR_TEST_STEP_ID.BUILD], ) ], @@ -261,21 +261,19 @@ def get_test_steps(context: ConnectorContext) -> STEP_TREE: StepToRun( id=CONNECTOR_TEST_STEP_ID.INTEGRATION, step=IntegrationTests(context), - args=lambda results: {"connector_under_test": results[CONNECTOR_TEST_STEP_ID.BUILD].output_artifact[LOCAL_BUILD_PLATFORM]}, + args=lambda results: {"connector_under_test": results[CONNECTOR_TEST_STEP_ID.BUILD].output[LOCAL_BUILD_PLATFORM]}, depends_on=[CONNECTOR_TEST_STEP_ID.BUILD], ), StepToRun( id=CONNECTOR_TEST_STEP_ID.AIRBYTE_LIB_VALIDATION, step=AirbyteLibValidation(context), - args=lambda results: {"connector_under_test": results[CONNECTOR_TEST_STEP_ID.BUILD].output_artifact[LOCAL_BUILD_PLATFORM]}, + args=lambda results: {"connector_under_test": results[CONNECTOR_TEST_STEP_ID.BUILD].output[LOCAL_BUILD_PLATFORM]}, depends_on=[CONNECTOR_TEST_STEP_ID.BUILD], ), StepToRun( id=CONNECTOR_TEST_STEP_ID.ACCEPTANCE, step=AcceptanceTests(context, context.concurrent_cat), - args=lambda results: { - "connector_under_test_container": results[CONNECTOR_TEST_STEP_ID.BUILD].output_artifact[LOCAL_BUILD_PLATFORM] - }, + args=lambda results: {"connector_under_test_container": results[CONNECTOR_TEST_STEP_ID.BUILD].output[LOCAL_BUILD_PLATFORM]}, depends_on=[CONNECTOR_TEST_STEP_ID.BUILD], ), ], diff --git a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/templates/test_report.html.j2 b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/templates/test_report.html.j2 index 7835305a7535..d0027605d0bf 100644 --- a/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/templates/test_report.html.j2 +++ b/airbyte-ci/connectors/pipelines/pipelines/airbyte_ci/connectors/test/steps/templates/test_report.html.j2 @@ -82,7 +82,7 @@ transition: max-height .25s ease-in-out; } .toggle:checked + .lbl-toggle + .collapsible-content { - max-height: 100vh; + max-height: 70vh; } .toggle:checked + .lbl-toggle { border-bottom-right-radius: 0; @@ -110,6 +110,14 @@ } +

{{ connector_name }} test report