From 37c7f18b77985e798895d5e8b1f6143e24447538 Mon Sep 17 00:00:00 2001 From: James MacMahon Date: Wed, 4 Dec 2024 17:13:21 -0500 Subject: [PATCH] Don't use LookupPath here! (#7197) It won't be able to get deleted Snapshot objects in order to kick off region snapshot replacements. --- .../datastore/region_snapshot_replacement.rs | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/nexus/db-queries/src/db/datastore/region_snapshot_replacement.rs b/nexus/db-queries/src/db/datastore/region_snapshot_replacement.rs index b970bb8962..4faaf228f9 100644 --- a/nexus/db-queries/src/db/datastore/region_snapshot_replacement.rs +++ b/nexus/db-queries/src/db/datastore/region_snapshot_replacement.rs @@ -11,7 +11,6 @@ use crate::db; use crate::db::datastore::SQL_BATCH_SIZE; use crate::db::error::public_error_from_diesel; use crate::db::error::ErrorHandler; -use crate::db::lookup::LookupPath; use crate::db::model::RegionSnapshot; use crate::db::model::RegionSnapshotReplacement; use crate::db::model::RegionSnapshotReplacementState; @@ -64,10 +63,19 @@ impl DataStore { opctx: &OpContext, request: RegionSnapshotReplacement, ) -> Result<(), Error> { - let (.., db_snapshot) = LookupPath::new(opctx, &self) - .snapshot_id(request.old_snapshot_id) - .fetch() - .await?; + // Note: if `LookupPath` is used here, it will not be able to retrieve + // deleted snapshots + let db_snapshot = match self + .snapshot_get(opctx, request.old_snapshot_id) + .await? + { + Some(db_snapshot) => db_snapshot, + None => { + return Err(Error::internal_error( + "cannot perform region snapshot replacement without snapshot volume" + )); + } + }; self.insert_region_snapshot_replacement_request_with_volume_id( opctx,