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

[CDF-23608] ✍ Lookup asset external #1325

Merged
merged 36 commits into from
Jan 6, 2025
Merged
Show file tree
Hide file tree
Changes from 35 commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
3e75bcd
test: extend testing
doctrino Jan 1, 2025
3518dcd
fix: implemented emtpy
doctrino Jan 1, 2025
3bc4d0c
tests: updated mocking
doctrino Jan 1, 2025
84e9999
fix: quote version key in location filter
doctrino Jan 1, 2025
ca9c216
feat: added data modeling type
doctrino Jan 1, 2025
59038a6
tests: updated test
doctrino Jan 1, 2025
d5349d2
tests: regen
doctrino Jan 1, 2025
651497b
feat: support data modeling type
doctrino Jan 1, 2025
faa738a
tests: update mock lookup
doctrino Jan 1, 2025
e651803
build: changelog
doctrino Jan 1, 2025
23dfbde
fix: introduced bugs
doctrino Jan 1, 2025
84d0958
fix; bug bug
doctrino Jan 1, 2025
9cbd3be
fix; bug bug bug
doctrino Jan 1, 2025
0d02410
tests: standardize
doctrino Jan 1, 2025
5530e99
tests: standardize 2
doctrino Jan 1, 2025
ce5129a
tests: set cpu and memory outside limits
doctrino Dec 18, 2024
4413d27
tests: try to recreate issue
doctrino Dec 18, 2024
9e241a4
docs: documented case
doctrino Dec 30, 2024
c97e2d3
fix: redeployment issue
doctrino Dec 30, 2024
710e03b
feat: added warning on mistake
doctrino Dec 30, 2024
729d45d
style: warning message
doctrino Dec 30, 2024
6e5d94d
feat; introduce ToolkitClientConfig
doctrino Jan 1, 2025
d04e293
style: better return value
doctrino Jan 1, 2025
3041834
refactor: renaming
doctrino Jan 1, 2025
c0c250a
Update cognite_toolkit/_cdf_tk/client/_toolkit_client.py
doctrino Jan 1, 2025
f38ff21
docs; better docs
doctrino Jan 1, 2025
00d9ee8
refactor: deal with special behavior
doctrino Jan 1, 2025
c91e4df
tests: added failing test
doctrino Jan 1, 2025
539af06
refactor; extending test
doctrino Jan 1, 2025
4580617
fix: set correct kind file name
doctrino Jan 1, 2025
0e19035
fix: added missing verbose flags
doctrino Jan 1, 2025
0cd1c1f
fix: added asset external ID lookup in sequence
doctrino Jan 2, 2025
58fe86e
Update CHANGELOG.cdf-tk.md
doctrino Jan 6, 2025
5941d58
Merge remote-tracking branch 'origin/main' into add-verbose-to-all-cmds
doctrino Jan 6, 2025
b8c9d77
Merge branch 'add-verbose-to-all-cmds' into lookup-asset-external-id
doctrino Jan 6, 2025
595b5f8
Merge remote-tracking branch 'origin/main' into lookup-asset-external-id
doctrino Jan 6, 2025
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
3 changes: 3 additions & 0 deletions CHANGELOG.cdf-tk.md
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,9 @@ Changes are grouped as follows:
the required value no longer triggers a redeploy.
- `LocationFilters` now parses the `version` key of `View` and `DataModel` correctly as a string.
- `LocationFilters` now converts an empty string of `dataSetExternalId` to `0` instead of ignoring it.
- All commands now has a verbose flag `--verbose`. Not all commands have an `--verbose` output, but
error handling has a more verbose output which applies to all commands.
- Toolkit now looks up the `assetExternalId` in the `Sequence` resource when deploying.

## [0.3.23] - 2024-12-13

Expand Down
16 changes: 16 additions & 0 deletions cognite_toolkit/_cdf_tk/apps/_auth_app.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,14 @@ def init(
help="If you verify, and you pass this flag no changes to CDF will be made.",
),
] = False,
verbose: Annotated[
bool,
typer.Option(
"--verbose",
"-v",
help="Turn on to get more verbose output when running the command",
),
] = False,
) -> None:
"""Sets the OIDC parameters required to authenticate and authorize the Cognite Toolkit in Cognite Data Fusion.
Expand Down Expand Up @@ -74,6 +82,14 @@ def verify(
"If you include this flag, the execution will stop if the user or service principal does not have the required capabilities.",
),
] = False,
verbose: Annotated[
bool,
typer.Option(
"--verbose",
"-v",
help="Turn on to get more verbose output when running the command",
),
] = False,
) -> None:
"""Verify that the current user or service principal has the required capabilities to run the CDF Toolkit commands."""
cmd = AuthCommand()
Expand Down
24 changes: 24 additions & 0 deletions cognite_toolkit/_cdf_tk/apps/_modules_app.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,14 @@ def init(
help="Clean target directory if it exists",
),
] = False,
verbose: Annotated[
bool,
typer.Option(
"--verbose",
"-v",
help="Turn on to get more verbose output when running the command",
),
] = False,
) -> None:
"""Initialize or upgrade a new CDF project with templates interactively."""

Expand Down Expand Up @@ -100,6 +108,14 @@ def add(
help="Path to project directory with the modules. This is used to search for available functions.",
),
] = CDF_TOML.cdf.default_organization_dir,
verbose: Annotated[
bool,
typer.Option(
"--verbose",
"-v",
help="Turn on to get more verbose output when running the command",
),
] = False,
) -> None:
"""Add one or more new module(s) to the project."""
cmd = ModulesCommand()
Expand Down Expand Up @@ -179,6 +195,14 @@ def list(
help="Build environment to use.",
),
] = CDF_TOML.cdf.default_env,
verbose: Annotated[
bool,
typer.Option(
"--verbose",
"-v",
help="Turn on to get more verbose output when running the command",
),
] = False,
) -> None:
"""List all available modules in the project."""
cmd = ModulesCommand()
Expand Down
32 changes: 32 additions & 0 deletions cognite_toolkit/_cdf_tk/apps/_run.py
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,14 @@ def run_transformation(
help="External id of the transformation to run.",
),
],
verbose: Annotated[
bool,
typer.Option(
"--verbose",
"-v",
help="Turn on to get more verbose output when running the command",
),
] = False,
) -> None:
"""This command will run the specified transformation using a one-time session."""
cmd = RunTransformationCommand()
Expand Down Expand Up @@ -93,6 +101,14 @@ def run_workflow(
help="Whether to wait for the workflow to complete.",
),
] = False,
verbose: Annotated[
bool,
typer.Option(
"--verbose",
"-v",
help="Turn on to get more verbose output when running the command",
),
] = False,
) -> None:
"""This command will run the specified workflow."""
cmd = RunWorkflowCommand()
Expand Down Expand Up @@ -158,6 +174,14 @@ def run_local(
help="Whether to rebuild the environment before running the function.",
),
] = False,
verbose: Annotated[
bool,
typer.Option(
"--verbose",
"-v",
help="Turn on to get more verbose output when running the command",
),
] = False,
) -> None:
"""This command will run the specified function locally."""
cmd = RunFunctionCommand()
Expand Down Expand Up @@ -214,6 +238,14 @@ def run_cdf(
help="Whether to wait for the function to complete.",
),
] = False,
verbose: Annotated[
bool,
typer.Option(
"--verbose",
"-v",
help="Turn on to get more verbose output when running the command",
),
] = False,
) -> None:
"""This command will run the specified function (assuming it is deployed) in CDF."""
cmd = RunFunctionCommand()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -274,12 +274,16 @@ def get_required_capability(
def load_resource(self, resource: dict[str, Any], is_dry_run: bool = False) -> SequenceWrite:
if ds_external_id := resource.pop("dataSetExternalId", None):
resource["dataSetId"] = self.client.lookup.data_sets.id(ds_external_id, is_dry_run)
if asset_external_id := resource.pop("assetExternalId", None):
resource["assetId"] = self.client.lookup.assets.id(asset_external_id)
return SequenceWrite._load(resource)

def dump_resource(self, resource: Sequence, local: dict[str, Any]) -> dict[str, Any]:
dumped = resource.as_write().dump()
if data_set_id := dumped.pop("dataSetId", None):
dumped["dataSetExternalId"] = self.client.lookup.data_sets.external_id(data_set_id)
if asset_id := dumped.pop("assetId", None):
dumped["assetExternalId"] = self.client.lookup.assets.external_id(asset_id)
if not dumped.get("metadata") and "metadata" not in local:
dumped.pop("metadata", None)
local_col_by_id = {col["externalId"]: col for col in local.get("columns", []) if "externalId" in col}
Expand Down
Loading