Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Clarify and improve controls of latest_version for version commands #207

Merged
merged 4 commits into from
May 8, 2024
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 8 additions & 1 deletion dbt_meshify/cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,14 @@
"--latest",
"-l",
is_flag=True,
help="Makes the newest version the latest version when incrementing model versions",
help="Makes the newest version the latest version when creating model versions",
)

increment = click.option(
"--increment",
"--i",
is_flag=True,
help="Increments the latest_version setting by 1 when creating model versions",
)


Expand Down
38 changes: 34 additions & 4 deletions dbt_meshify/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
from dbt_meshify.storage.dbt_project_editors import DbtSubprojectCreator
from dbt_meshify.utilities.contractor import Contractor
from dbt_meshify.utilities.linker import Linker
from dbt_meshify.utilities.versioner import ModelVersioner
from dbt_meshify.utilities.versioner import LatestVersionBehavior, ModelVersioner

from .cli import (
TupleCompatibleCommand,
Expand All @@ -27,6 +27,7 @@
exclude_projects,
get_version,
group_yml_path,
increment,
latest,
owner,
owner_email,
Expand Down Expand Up @@ -373,19 +374,33 @@ def add_version(
@select
@selector
@latest
@increment
@click.option("--defined-in", default=None)
def bump_version(
select,
exclude,
project_path,
selector,
latest: bool,
increment: bool,
defined_in: Optional[Path],
read_catalog,
) -> List[ChangeSet]:
"""
Create new model versions for all selected models.
"""

if latest and increment:
raise FatalMeshifyException(
"Cannot specify both --latest and --prerelease. Please choose one or the other."
dave-connors-3 marked this conversation as resolved.
Show resolved Hide resolved
)

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good call 👍🏻

latest_version_behavior = LatestVersionBehavior.Prerelease
if latest:
latest_version_behavior = LatestVersionBehavior.Latest
elif increment:
latest_version_behavior = LatestVersionBehavior.Increment

path = Path(project_path).expanduser().resolve()

logger.info(f"Reading dbt project at {path}")
Expand All @@ -412,7 +427,9 @@ def bump_version(
continue

changes: ChangeSet = versioner.bump_version(
model=model_node, prerelease=not (latest), defined_in=defined_in
model=model_node,
latest_version_behavior=latest_version_behavior,
defined_in=defined_in,
)
change_set.extend(changes)

Expand All @@ -429,19 +446,32 @@ def bump_version(
@select
@selector
@latest
@increment
@click.option("--defined-in", default=None)
def version(
select,
exclude,
project_path,
selector,
latest: bool,
increment: bool,
defined_in: Optional[Path],
read_catalog,
) -> List[ChangeSet]:
"""
Increment the models to the next version, and create in the initial version if it has not yet been defined.
"""
if latest and increment:
raise FatalMeshifyException(
"Cannot specify both --latest and --prerelease. Please choose one or the other."
dave-connors-3 marked this conversation as resolved.
Show resolved Hide resolved
)

latest_version_behavior = LatestVersionBehavior.Prerelease
if latest:
latest_version_behavior = LatestVersionBehavior.Latest
elif increment:
latest_version_behavior = LatestVersionBehavior.Increment

path = Path(project_path).expanduser().resolve()

logger.info(f"Reading dbt project at {path}")
Expand Down Expand Up @@ -474,7 +504,7 @@ def version(
versioner.bump_version(
model=model_node,
defined_in=defined_in,
prerelease=not (latest),
latest_version_behavior=latest_version_behavior,
)
)

Expand All @@ -498,7 +528,7 @@ def version(
bump_change: ChangeSet = versioner.bump_version(
model=model_node,
defined_in=defined_in,
prerelease=not (latest),
latest_version_behavior=latest_version_behavior,
model_override=model_add_change.data,
)

Expand Down
29 changes: 24 additions & 5 deletions dbt_meshify/utilities/versioner.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
from enum import Enum
from pathlib import Path
from typing import Any, Dict, Optional, Union

Expand All @@ -16,6 +17,14 @@
from dbt_meshify.storage.file_manager import FileManager, YAMLFileManager


class LatestVersionBehavior(str, Enum):
"""An operation describes the type of work being performed."""
dave-connors-3 marked this conversation as resolved.
Show resolved Hide resolved

Prerelease = "prerelease"
Increment = "increment"
Latest = "latest"

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great use of enums!


class ModelVersionerException(Exception):
"""Exceptions raised during versioning of a Model."""

Expand Down Expand Up @@ -127,7 +136,7 @@ def add_version(self, model: ModelNode, defined_in: Optional[Path] = None) -> Ch
def bump_version(
self,
model: ModelNode,
prerelease: bool = False,
latest_version_behavior: LatestVersionBehavior = LatestVersionBehavior.Prerelease,
defined_in: Optional[Path] = None,
model_override: Optional[Dict] = None,
) -> ChangeSet:
Expand All @@ -149,12 +158,22 @@ def bump_version(
)

# Within dbt-core, if unset `latest_version` defaults to the greatest version identifier.
latest_version = model_yml.get("latest_version", greatest_version)

# Bump versions
current_latest_version = model_yml.get("latest_version", greatest_version)
new_greatest_version_number = greatest_version + 1
new_latest_version_number = latest_version if prerelease else latest_version + 1

# if prerelease, the latest version is unchanged
# if increment, the latest version is incremented by 1
# if latest, the latest version is set to the greatest version + 1 (newly created version)

latest_version_number_map = {
LatestVersionBehavior.Prerelease: current_latest_version,
LatestVersionBehavior.Increment: current_latest_version + 1,
LatestVersionBehavior.Latest: greatest_version + 1,
}

# import ipdb; ipdb.set_trace()
dave-connors-3 marked this conversation as resolved.
Show resolved Hide resolved

new_latest_version_number = latest_version_number_map[latest_version_behavior]
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is really clever. Great use of enums and dicts.

# Setup the new version definitions
new_version_data: Dict[str, Any] = {"v": new_greatest_version_number}
if defined_in:
Expand Down
10 changes: 9 additions & 1 deletion tests/integration/test_version_command.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
from tests.dbt_project_utils import setup_test_project, teardown_test_project

from ..sql_and_yml_fixtures import (
expected_versioned_model_yml_increment_latest_version,
expected_versioned_model_yml_increment_prerelease_version,
expected_versioned_model_yml_increment_prerelease_version_with_second_prerelease,
expected_versioned_model_yml_increment_version_no_prerelease,
Expand Down Expand Up @@ -239,10 +240,17 @@ def test_bump_version_fails_when_no_versions_present(
expected_versioned_model_yml_increment_prerelease_version,
["shared_model_v1.sql", "shared_model_v2.sql"],
["shared_model_v1.sql", "shared_model_v2.sql", "shared_model_v3.sql"],
["--increment"],
),
(
expected_versioned_model_yml_increment_version_with_prerelease,
expected_versioned_model_yml_increment_latest_version,
["shared_model_v1.sql", "shared_model_v2.sql"],
["shared_model_v1.sql", "shared_model_v2.sql", "shared_model_v3.sql"],
["--latest"],
),
],
ids=["1", "2", "3", "4", "5"],
ids=["1", "2", "3", "4", "5", "6"],
)
def test_bump_version_in_yml(
start_yml, end_yml, start_files, expected_files, command_options, project
Expand Down
11 changes: 11 additions & 0 deletions tests/sql_and_yml_fixtures.py
Original file line number Diff line number Diff line change
Expand Up @@ -262,6 +262,17 @@
- v: 3
"""

expected_versioned_model_yml_increment_latest_version = """
models:
- name: shared_model
latest_version: 3
description: "this is a test model"
versions:
- v: 1
- v: 2
- v: 3
"""

expected_versioned_model_yml_prerelease_defined_in = """
models:
- name: shared_model
Expand Down
18 changes: 14 additions & 4 deletions tests/unit/test_add_version_to_yml.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
import yaml

from dbt_meshify.storage.file_content_editors import ResourceFileEditor
from dbt_meshify.utilities.versioner import ModelVersioner
from dbt_meshify.utilities.versioner import LatestVersionBehavior, ModelVersioner

from ..dbt_project_fixtures import model, project # noqa: F401
from ..sql_and_yml_fixtures import (
Expand Down Expand Up @@ -59,7 +59,9 @@ def test_add_version_to_model_yml_increment_version_no_prerelease(
self, model, project, file_manager # noqa: F811
):
versioner = ModelVersioner(project=project, file_manager=file_manager)
changes = list(versioner.bump_version(model))
changes = list(
versioner.bump_version(model, latest_version_behavior=LatestVersionBehavior.Increment)
)
yml_dict = ResourceFileEditor.update_resource(
properties=read_yml(model_yml_increment_version), change=changes[0]
)
Expand All @@ -70,7 +72,9 @@ def test_add_version_to_model_yml_increment_version_with_prerelease(
self, model, project, file_manager # noqa: F811
):
versioner = ModelVersioner(project=project, file_manager=file_manager)
changes = list(versioner.bump_version(model, prerelease=True))
changes = list(
versioner.bump_version(model, latest_version_behavior=LatestVersionBehavior.Prerelease)
)
yml_dict = ResourceFileEditor.update_resource(
properties=read_yml(model_yml_increment_version), change=changes[0]
)
Expand All @@ -81,7 +85,13 @@ def test_add_version_to_model_yml_increment_version_defined_in(
self, model, project, file_manager # noqa: F811
):
versioner = ModelVersioner(project=project, file_manager=file_manager)
changes = list(versioner.bump_version(model, defined_in="daves_model", prerelease=True))
changes = list(
versioner.bump_version(
model,
latest_version_behavior=LatestVersionBehavior.Prerelease,
defined_in="daves_model",
)
)
yml_dict = ResourceFileEditor.update_resource(
properties=read_yml(model_yml_increment_version), change=changes[0]
)
Expand Down
Loading