From 2c1c79bf5c656633e01de875f6e332de69582c26 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Natalie=20Klestrup=20R=C3=B6ijezon?= Date: Thu, 8 Aug 2024 15:52:40 +0200 Subject: [PATCH] Implement Error for error_boundary::InvalidObject MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Natalie Klestrup Röijezon --- kube-core/src/error_boundary.rs | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/kube-core/src/error_boundary.rs b/kube-core/src/error_boundary.rs index 9d27d1af3..d1314f993 100644 --- a/kube-core/src/error_boundary.rs +++ b/kube-core/src/error_boundary.rs @@ -1,10 +1,11 @@ //! Types for isolating deserialization failures. See [`DeserializeGuard`]. -use std::{borrow::Cow, fmt::Display}; +use std::borrow::Cow; use k8s_openapi::apimachinery::pkg::apis::meta::v1::ObjectMeta; use serde::Deserialize; use serde_value::DeserializerError; +use thiserror::Error; use crate::{PartialObjectMeta, Resource}; @@ -17,7 +18,8 @@ use crate::{PartialObjectMeta, Resource}; pub struct DeserializeGuard(pub Result); /// An object that failed to be deserialized by the [`DeserializeGuard`]. -#[derive(Debug, Clone)] +#[derive(Debug, Clone, Error)] +#[error("{error}")] pub struct InvalidObject { // Should ideally be D::Error, but we don't know what type it has outside of Deserialize::deserialize() // It *could* be Box, but we don't know that it is Send+Sync @@ -27,12 +29,6 @@ pub struct InvalidObject { pub metadata: ObjectMeta, } -impl Display for InvalidObject { - fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - self.error.fmt(f) - } -} - impl<'de, K> Deserialize<'de> for DeserializeGuard where K: Deserialize<'de>,