Skip to content
Merged
Changes from all 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: 9 additions & 0 deletions python/pyiceberg/schema.py
Original file line number Diff line number Diff line change
Expand Up @@ -1367,3 +1367,12 @@ def _(file_type: DecimalType, read_type: IcebergType) -> IcebergType:
raise ResolveError(f"Cannot reduce precision from {file_type} to {read_type}")
else:
raise ResolveError(f"Cannot promote an decimal to {read_type}")


@promote.register(FixedType)
def _(file_type: FixedType, read_type: IcebergType) -> IcebergType:
if isinstance(read_type, UUIDType) and len(file_type) == 16:
# Since pyarrow reads parquet UUID as fixed 16-byte binary, the promotion is needed to ensure read compatibility
return read_type
else:
raise ResolveError(f"Cannot promote {file_type} to {read_type}")