From 7fed5e405bb6f553fb2b1aa49c465d5ab1866f2a Mon Sep 17 00:00:00 2001 From: niebayes Date: Thu, 4 Jan 2024 16:23:51 +0800 Subject: [PATCH] chore: add unit tests for build records --- src/log-store/src/kafka/util/record.rs | 31 +++++++++++++++++++++++++- 1 file changed, 30 insertions(+), 1 deletion(-) diff --git a/src/log-store/src/kafka/util/record.rs b/src/log-store/src/kafka/util/record.rs index fb812dc9d1d5..df89bf6f6703 100644 --- a/src/log-store/src/kafka/util/record.rs +++ b/src/log-store/src/kafka/util/record.rs @@ -482,7 +482,36 @@ mod tests { /// Tests that the `build_records` works as expected. #[test] - fn test_build_records() {} + fn test_build_records() { + let max_record_size = 128; + + // On a small entry. + let ns = NamespaceImpl { + region_id: 1, + topic: "greptimedb_wal_topic".to_string(), + }; + let entry = new_test_entry([b'1'; 100], 0, ns.clone()); + let records = build_records(entry.clone(), max_record_size); + assert!(records.len() == 1); + assert_eq!(entry.data, records[0].data); + + // On a large entry. + let entry = new_test_entry([b'1'; 150], 0, ns.clone()); + let records = build_records(entry.clone(), max_record_size); + assert!(records.len() == 2); + assert_eq!(&records[0].data, &[b'1'; 128]); + assert_eq!(&records[1].data, &[b'1'; 22]); + + // On a way-too large entry. + let entry = new_test_entry([b'1'; 5000], 0, ns.clone()); + let records = build_records(entry.clone(), max_record_size); + let matched = entry + .data + .chunks(max_record_size) + .enumerate() + .all(|(i, chunk)| records[i].data == chunk); + assert!(matched); + } /// Tests that Record and KafkaRecord are able to be converted back and forth. #[test]