Skip to content

Commit

Permalink
Airbyte-ci: Ensure we set the working directory earlier (airbytehq#34136
Browse files Browse the repository at this point in the history
)
  • Loading branch information
bnchrch authored and jatinyadav-cc committed Feb 26, 2024
1 parent fa30edb commit 9656c4e
Show file tree
Hide file tree
Showing 4 changed files with 65 additions and 57 deletions.
1 change: 1 addition & 0 deletions airbyte-ci/connectors/pipelines/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -521,6 +521,7 @@ E.G.: running `pytest` on a specific test folder:

| Version | PR | Description |
| ------- | ---------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------- |
| 3.1.3 | [#34136](https://github.com/airbytehq/airbyte/pull/34136) | Fix issue where dagger excludes were not being properly applied |
| 3.1.2 | [#33972](https://github.com/airbytehq/airbyte/pull/33972) | Remove secrets scrubbing hack for --is-local and other small tweaks. |
| 3.1.1 | [#33979](https://github.com/airbytehq/airbyte/pull/33979) | Fix AssertionError on report existence again |
| 3.1.0 | [#33994](https://github.com/airbytehq/airbyte/pull/33994) | Log more context information in CI. |
Expand Down
62 changes: 6 additions & 56 deletions airbyte-ci/connectors/pipelines/pipelines/cli/airbyte_ci.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,20 @@

from __future__ import annotations

# Important: This import and function call must be the first import in this file
# This is needed to ensure that the working directory is the root of the airbyte repo
from pipelines.cli.ensure_repo_root import set_working_directory_to_root

set_working_directory_to_root()

import logging
import multiprocessing
import os
import sys
from pathlib import Path
from typing import Optional

import asyncclick as click
import docker # type: ignore
import git
from github import PullRequest
from pipelines import main_logger
from pipelines.cli.auto_update import __installed_version__, check_for_upgrade, pre_confirm_auto_update_flag
Expand All @@ -30,58 +34,6 @@
from pipelines.helpers.utils import get_current_epoch_time


def _validate_airbyte_repo(repo: git.Repo) -> bool:
"""Check if any of the remotes are the airbyte repo."""
expected_repo_name = "airbytehq/airbyte"
for remote in repo.remotes:
if expected_repo_name in remote.url:
return True

warning_message = f"""
⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️
It looks like you are not running this command from the airbyte repo ({expected_repo_name}).
If this command is run from outside the airbyte repo, it will not work properly.
Please run this command your local airbyte project.
⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️
"""

logging.warning(warning_message)

return False


def get_airbyte_repo() -> git.Repo:
"""Get the airbyte repo."""
repo = git.Repo(search_parent_directories=True)
_validate_airbyte_repo(repo)
return repo


def get_airbyte_repo_path_with_fallback() -> Path:
"""Get the path to the airbyte repo."""
try:
repo_path = get_airbyte_repo().working_tree_dir
if repo_path is not None:
return Path(str(get_airbyte_repo().working_tree_dir))
except git.exc.InvalidGitRepositoryError:
pass
logging.warning("Could not find the airbyte repo, falling back to the current working directory.")
path = Path.cwd()
logging.warning(f"Using {path} as the airbyte repo path.")
return path


def set_working_directory_to_root() -> None:
"""Set the working directory to the root of the airbyte repo."""
working_dir = get_airbyte_repo_path_with_fallback()
logging.info(f"Setting working directory to {working_dir}")
os.chdir(working_dir)


def log_context_info(ctx: click.Context) -> None:
main_logger.info(f"Running airbyte-ci version {__installed_version__}")
main_logger.info(f"Running dagger version {get_dagger_sdk_version()}")
Expand Down Expand Up @@ -241,7 +193,5 @@ async def airbyte_ci(ctx: click.Context) -> None: # noqa D103
log_context_info(ctx)


set_working_directory_to_root()

if __name__ == "__main__":
airbyte_ci()
57 changes: 57 additions & 0 deletions airbyte-ci/connectors/pipelines/pipelines/cli/ensure_repo_root.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
import logging
import os
from pathlib import Path

import git


def _validate_airbyte_repo(repo: git.Repo) -> bool:
"""Check if any of the remotes are the airbyte repo."""
expected_repo_name = "airbytehq/airbyte"
for remote in repo.remotes:
if expected_repo_name in remote.url:
return True

warning_message = f"""
⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️
It looks like you are not running this command from the airbyte repo ({expected_repo_name}).
If this command is run from outside the airbyte repo, it will not work properly.
Please run this command your local airbyte project.
⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️⚠️
"""

logging.warning(warning_message)

return False


def get_airbyte_repo() -> git.Repo:
"""Get the airbyte repo."""
repo = git.Repo(search_parent_directories=True)
_validate_airbyte_repo(repo)
return repo


def get_airbyte_repo_path_with_fallback() -> Path:
"""Get the path to the airbyte repo."""
try:
repo_path = get_airbyte_repo().working_tree_dir
if repo_path is not None:
return Path(str(get_airbyte_repo().working_tree_dir))
except git.exc.InvalidGitRepositoryError:
pass
logging.warning("Could not find the airbyte repo, falling back to the current working directory.")
path = Path.cwd()
logging.warning(f"Using {path} as the airbyte repo path.")
return path


def set_working_directory_to_root() -> None:
"""Set the working directory to the root of the airbyte repo."""
working_dir = get_airbyte_repo_path_with_fallback()
logging.info(f"Setting working directory to {working_dir}")
os.chdir(working_dir)
2 changes: 1 addition & 1 deletion airbyte-ci/connectors/pipelines/pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ build-backend = "poetry.core.masonry.api"

[tool.poetry]
name = "pipelines"
version = "3.1.2"
version = "3.1.3"
description = "Packaged maintained by the connector operations team to perform CI for connectors' pipelines"
authors = ["Airbyte <contact@airbyte.io>"]

Expand Down

0 comments on commit 9656c4e

Please sign in to comment.