From 60ed7fecd4216213ea3f8075084a45e89d8ff02c Mon Sep 17 00:00:00 2001 From: Aaron McCarty Date: Mon, 6 Jan 2025 18:16:36 -0800 Subject: [PATCH] fix missing branch param in computed attributes logic --- backend/infrahub/core/node/__init__.py | 2 +- .../test_mutation_create_jinja2_attributes.py | 30 +++++++++---------- changelog/5385.fixed.md | 1 + 3 files changed, 17 insertions(+), 16 deletions(-) create mode 100644 changelog/5385.fixed.md diff --git a/backend/infrahub/core/node/__init__.py b/backend/infrahub/core/node/__init__.py index 36d9b0c8bf..4305d36ebb 100644 --- a/backend/infrahub/core/node/__init__.py +++ b/backend/infrahub/core/node/__init__.py @@ -399,7 +399,7 @@ async def _process_macros(self, db: InfrahubDatabase) -> None: peer = await relationship_attribute.get_peer(db=db, raise_on_error=True) related_node = await registry.manager.get_one_by_id_or_default_filter( - db=db, id=peer.id, kind=attribute_path.active_relationship_schema.peer + db=db, id=peer.id, kind=attribute_path.active_relationship_schema.peer, branch=self._branch.name ) attribute: BaseAttribute = getattr( diff --git a/backend/tests/unit/graphql/test_mutation_create_jinja2_attributes.py b/backend/tests/unit/graphql/test_mutation_create_jinja2_attributes.py index 6e417b75fb..78cfbf07f5 100644 --- a/backend/tests/unit/graphql/test_mutation_create_jinja2_attributes.py +++ b/backend/tests/unit/graphql/test_mutation_create_jinja2_attributes.py @@ -16,15 +16,15 @@ async def test_create_with_jinja2_computed_attributes_on_related_node( - db: InfrahubDatabase, default_branch: Branch, node_group_schema: None, data_schema: None + db: InfrahubDatabase, default_branch: Branch, node_group_schema: None, data_schema: None, branch: Branch ) -> None: schema = SchemaRoot(**internal_schema) - registry.schema.register_schema(schema=schema, branch=default_branch.name) - default_branch.update_schema_hash() - await default_branch.save(db=db) - await load_schema(db, schema=SchemaRoot(nodes=[CHILD, THING])) + registry.schema.register_schema(schema=schema, branch=branch.name) + branch.update_schema_hash() + await branch.save(db=db) + await load_schema(db, branch_name=branch.name, schema=SchemaRoot(nodes=[CHILD, THING])) - fred = await Node.init(schema=TestKind.CHILD, db=db) + fred = await Node.init(schema=TestKind.CHILD, db=db, branch=branch) await fred.new(db=db, name="Fred", height=110) await fred.save(db=db) @@ -45,7 +45,7 @@ async def test_create_with_jinja2_computed_attributes_on_related_node( } } """ - gql_params = await prepare_graphql_params(db=db, include_subscription=False, branch=default_branch) + gql_params = await prepare_graphql_params(db=db, include_subscription=False, branch=branch) result = await graphql( schema=gql_params.schema, source=query, @@ -61,19 +61,19 @@ async def test_create_with_jinja2_computed_attributes_on_related_node( async def test_create_with_jinja2_computed_attributes_on_hierarchial_node( - db: InfrahubDatabase, default_branch: Branch, node_group_schema: None, data_schema: None + db: InfrahubDatabase, default_branch: Branch, node_group_schema: None, data_schema: None, branch: Branch ) -> None: schema = SchemaRoot(**internal_schema) - registry.schema.register_schema(schema=schema, branch=default_branch.name) - default_branch.update_schema_hash() - await default_branch.save(db=db) - await load_schema(db, schema=LOCATION_SCHEMA) + registry.schema.register_schema(schema=schema, branch=branch.name) + branch.update_schema_hash() + await branch.save(db=db) + await load_schema(db, branch_name=branch.name, schema=LOCATION_SCHEMA) - continent = await Node.init(schema=TestKind.CONTINENT, db=db) + continent = await Node.init(schema=TestKind.CONTINENT, db=db, branch=branch) await continent.new(db=db, name="Europe", shortname="eu") await continent.save(db=db) - country = await Node.init(schema=TestKind.COUNTRY, db=db) + country = await Node.init(schema=TestKind.COUNTRY, db=db, branch=branch) await country.new(db=db, name="Sweden", shortname="se", parent=continent) await country.save(db=db) @@ -94,7 +94,7 @@ async def test_create_with_jinja2_computed_attributes_on_hierarchial_node( } } """ - gql_params = await prepare_graphql_params(db=db, include_subscription=False, branch=default_branch) + gql_params = await prepare_graphql_params(db=db, include_subscription=False, branch=branch) result = await graphql( schema=gql_params.schema, source=query, diff --git a/changelog/5385.fixed.md b/changelog/5385.fixed.md new file mode 100644 index 0000000000..b337977282 --- /dev/null +++ b/changelog/5385.fixed.md @@ -0,0 +1 @@ +Fix an issue that would prevent creating a node on a branch with a computed attribute that referenced another node on that branch \ No newline at end of file