Skip to content

Commit

Permalink
fix: enable self-referencing schemas
Browse files Browse the repository at this point in the history
  • Loading branch information
eliax1996 committed Sep 15, 2023
1 parent a33b4e1 commit 81bdb71
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 1 deletion.
7 changes: 6 additions & 1 deletion karapace/protobuf/schema.py
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,12 @@ def _process_nested_type(
one_of_parent_name = parent_name + "." + element_type.name
process_one_of(verifier, package_name, one_of_parent_name, one_of)
for field in element_type.fields:
verifier.add_used_type(parent_name, field.element_type)
# since we declare the subtype in the same level of the scope, it's legit
# use the same scoping when declare the dependent type.
if field.element_type in [defined_in_same_scope.name for defined_in_same_scope in element_type.nested_types]:
verifier.add_used_type(parent_name + "." + element_type.name, field.element_type)
else:
verifier.add_used_type(parent_name, field.element_type)
for nested_type in element_type.nested_types:
self._process_nested_type(verifier, package_name, parent_name + "." + element_type.name, nested_type)

Expand Down
25 changes: 25 additions & 0 deletions tests/integration/test_schema_protobuf.py
Original file line number Diff line number Diff line change
Expand Up @@ -620,6 +620,24 @@ class ReferenceTestCase(BaseTestCase):
}
"""

SELF_REFERENCED_SCHEMA = """\
syntax = "proto3";
package fancy.company.in.party.v1;
message MyFirstMessage {
string my_fancy_string = 1;
}
message AnotherMessage {
message WowANestedMessage {
enum BamFancyEnum {
// Hei! This is a comment!
MY_AWESOME_FIELD = 0;
}
BamFancyEnum im_tricky_im_referring_to_the_previous_enum = 1;
}
}
"""


@pytest.mark.parametrize(
"testcase",
Expand Down Expand Up @@ -1000,6 +1018,13 @@ async def test_references(testcase: ReferenceTestCase, registry_async_client: Cl
assert fetch_schema_res.status_code == 200


async def test_self_reference_schema(registry_async_client: Client) -> None:
body = {"schemaType": SchemaType.PROTOBUF, "schema": SELF_REFERENCED_SCHEMA}
res = await registry_async_client.post("subjects/self_referenced_schema_test/versions", json=body)

assert res.status_code == 200


async def test_protobuf_error(registry_async_client: Client) -> None:
testdata = TestCaseSchema(
schema_type=SchemaType.PROTOBUF,
Expand Down

0 comments on commit 81bdb71

Please sign in to comment.