1pub mod audit_log;
13pub mod objects;
14pub mod objects_v74;
15pub mod objects_v75;
16pub mod objects_v76;
17pub mod objects_v77;
18pub mod objects_v78;
19pub mod objects_v79;
20pub mod objects_v80;
21pub mod objects_v81;
22pub mod objects_v82;
23pub mod objects_v83;
24pub mod objects_v84;
25pub mod objects_v85;
26pub mod objects_v86;
27pub mod objects_v87;
28pub mod serialization;
29
30pub const CATALOG_VERSION: u64 = 87;
36
37pub const MIN_CATALOG_VERSION: u64 = 74;
41
42#[cfg(test)]
43mod tests {
44 use std::collections::BTreeSet;
45 use std::fs;
46 use std::path::PathBuf;
47
48 use crate::{CATALOG_VERSION, MIN_CATALOG_VERSION};
49
50 #[mz_ore::test]
51 fn test_assert_snapshots_exist() {
52 let src_dir: PathBuf = [env!("CARGO_MANIFEST_DIR"), "src"].iter().collect();
53
54 let mut filenames: BTreeSet<_> = fs::read_dir(src_dir)
56 .expect("failed to read src dir")
57 .map(|entry| entry.expect("failed to read dir entry").file_name())
58 .map(|filename| filename.to_str().expect("utf8").to_string())
59 .filter(|filename| filename.starts_with("objects_v"))
60 .collect();
61
62 for version in MIN_CATALOG_VERSION..=CATALOG_VERSION {
64 let filename = format!("objects_v{version}.rs");
65 assert!(
66 filenames.remove(&filename),
67 "Missing snapshot for v{version}."
68 );
69 }
70
71 if !filenames.is_empty()
73 && filenames.remove(&format!("objects_v{}.proto", CATALOG_VERSION + 1))
74 {
75 panic!(
76 "Found snapshot for v{}, please also bump `CATALOG_VERSION`.",
77 CATALOG_VERSION + 1
78 )
79 }
80
81 assert!(
83 filenames.is_empty(),
84 "Found snapshots for unsupported catalog versions {filenames:?}.\n\
85 If you just increased `MIN_CATALOG_VERSION`, then please delete the old snapshots. \
86 If you created a new snapshot, please bump `CATALOG_VERSION`."
87 );
88 }
89
90 #[mz_ore::test]
91 fn test_assert_current_snapshot() {
92 let src_dir: PathBuf = [env!("CARGO_MANIFEST_DIR"), "src"].iter().collect();
93 let current_rs = src_dir.join("objects.rs");
94 let snapshot_rs = src_dir.join(format!("objects_v{CATALOG_VERSION}.rs"));
95
96 let current = fs::read_to_string(current_rs).expect("read current");
97 let snapshot = fs::read_to_string(snapshot_rs).expect("read snapshot");
98
99 similar_asserts::assert_eq!(current, snapshot);
104 }
105}