Skip to content

Commit

Permalink
AVRO-3974: [Rust] Support schema compatibility for Schema::Ref (#2847)
Browse files Browse the repository at this point in the history
Signed-off-by: Martin Tzvetanov Grigorov <[email protected]>
  • Loading branch information
martin-g authored Apr 11, 2024
1 parent 0fc3495 commit cd3e2df
Showing 1 changed file with 59 additions and 0 deletions.
59 changes: 59 additions & 0 deletions lang/rust/avro/src/schema_compatibility.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,28 @@ use std::{
ptr,
};

fn match_ref_schemas(
writers_schema: &Schema,
readers_schema: &Schema,
) -> Result<(), CompatibilityError> {
match (readers_schema, writers_schema) {
(Schema::Ref { name: r_name }, Schema::Ref { name: w_name }) => {
if r_name == w_name {
Ok(())
} else {
Err(CompatibilityError::NameMismatch {
writer_name: w_name.fullname(None),
reader_name: r_name.fullname(None),
})
}
}
_ => Err(CompatibilityError::WrongType {
writer_schema_type: format!("{:#?}", writers_schema),
reader_schema_type: format!("{:#?}", readers_schema),
}),
}
}

pub struct SchemaCompatibility;

struct Checker {
Expand Down Expand Up @@ -80,6 +102,7 @@ impl Checker {
}

match r_type {
SchemaKind::Ref => match_ref_schemas(writers_schema, readers_schema),
SchemaKind::Record => self.match_record_schemas(writers_schema, readers_schema),
SchemaKind::Map => {
if let Schema::Map(w_m) = writers_schema {
Expand Down Expand Up @@ -431,6 +454,7 @@ impl SchemaCompatibility {
SchemaKind::Duration => {
return Ok(());
}
SchemaKind::Ref => return match_ref_schemas(writers_schema, readers_schema),
_ => {
return Err(CompatibilityError::Inconclusive(String::from(
"readers_schema",
Expand Down Expand Up @@ -1710,4 +1734,39 @@ mod tests {

Ok(())
}

#[test]
fn avro_3974_can_read_schema_references() -> TestResult {
let schema_strs = vec![
r#"{
"type": "record",
"name": "Child",
"namespace": "avro",
"fields": [
{
"name": "val",
"type": "int"
}
]
}
"#,
r#"{
"type": "record",
"name": "Parent",
"namespace": "avro",
"fields": [
{
"name": "child",
"type": "avro.Child"
}
]
}
"#,
];

let schemas = Schema::parse_list(&schema_strs).unwrap();
SchemaCompatibility::can_read(&schemas[1], &schemas[1])?;

Ok(())
}
}

0 comments on commit cd3e2df

Please sign in to comment.