use crate::{ArrowError, DataType, extension::ExtensionType};
#[derive(Debug, Default, Clone, Copy, PartialEq)]
pub struct Uuid;
impl ExtensionType for Uuid {
const NAME: &'static str = "arrow.uuid";
type Metadata = ();
fn metadata(&self) -> &Self::Metadata {
&()
}
fn serialize_metadata(&self) -> Option<String> {
None
}
fn deserialize_metadata(metadata: Option<&str>) -> Result<Self::Metadata, ArrowError> {
metadata.map_or_else(
|| Ok(()),
|_| {
Err(ArrowError::InvalidArgumentError(
"Uuid extension type expects no metadata".to_owned(),
))
},
)
}
fn supports_data_type(&self, data_type: &DataType) -> Result<(), ArrowError> {
match data_type {
DataType::FixedSizeBinary(16) => Ok(()),
data_type => Err(ArrowError::InvalidArgumentError(format!(
"Uuid data type mismatch, expected FixedSizeBinary(16), found {data_type}"
))),
}
}
fn try_new(data_type: &DataType, _metadata: Self::Metadata) -> Result<Self, ArrowError> {
Self.supports_data_type(data_type).map(|_| Self)
}
}
#[cfg(test)]
mod tests {
#[cfg(feature = "canonical_extension_types")]
use crate::extension::CanonicalExtensionType;
use crate::{
Field,
extension::{EXTENSION_TYPE_METADATA_KEY, EXTENSION_TYPE_NAME_KEY},
};
use super::*;
#[test]
fn valid() -> Result<(), ArrowError> {
let mut field = Field::new("", DataType::FixedSizeBinary(16), false);
field.try_with_extension_type(Uuid)?;
field.try_extension_type::<Uuid>()?;
#[cfg(feature = "canonical_extension_types")]
assert_eq!(
field.try_canonical_extension_type()?,
CanonicalExtensionType::Uuid(Uuid)
);
Ok(())
}
#[test]
#[should_panic(expected = "Extension type name missing")]
fn missing_name() {
let field = Field::new("", DataType::FixedSizeBinary(16), false);
field.extension_type::<Uuid>();
}
#[test]
#[should_panic(expected = "expected FixedSizeBinary(16), found FixedSizeBinary(8)")]
fn invalid_type() {
Field::new("", DataType::FixedSizeBinary(8), false).with_extension_type(Uuid);
}
#[test]
#[should_panic(expected = "Uuid extension type expects no metadata")]
fn with_metadata() {
let field = Field::new("", DataType::FixedSizeBinary(16), false).with_metadata(
[
(EXTENSION_TYPE_NAME_KEY.to_owned(), Uuid::NAME.to_owned()),
(EXTENSION_TYPE_METADATA_KEY.to_owned(), "".to_owned()),
]
.into_iter()
.collect(),
);
field.extension_type::<Uuid>();
}
}