|
1 | | - |
2 | 1 | use std::collections::BTreeMap; |
3 | 2 |
|
4 | 3 | use proptest::prelude::*; |
@@ -157,33 +156,33 @@ fn op_strategy() -> impl Strategy<Value = InsertRemoveGetOp> { |
157 | 156 | ] |
158 | 157 | } |
159 | 158 |
|
160 | | -proptest! { |
161 | | - #[test] |
162 | | - fn test_insert_remove_get(ops in prop::collection::vec(op_strategy(), 0..1000)) { |
163 | | - let mut pb = SortedIndexBuffer::default(); |
164 | | - let mut reference = BTreeMap::new(); |
165 | | - |
166 | | - for op in ops { |
167 | | - match op { |
168 | | - InsertRemoveGetOp::Insert(k, v) => { |
169 | | - pb.insert(k, v); |
170 | | - reference.insert(k, v); |
171 | | - } |
172 | | - InsertRemoveGetOp::Remove(k) => { |
173 | | - let v1 = pb.remove(k); |
174 | | - let v2 = reference.remove(&k); |
175 | | - assert_eq!(v1, v2); |
176 | | - } |
177 | | - InsertRemoveGetOp::Get(k) => { |
178 | | - let v1 = pb.get(k); |
179 | | - let v2 = reference.get(&k); |
180 | | - assert_eq!(v1, v2); |
181 | | - } |
| 159 | +#[test_strategy::proptest] |
| 160 | +fn test_insert_remove_get( |
| 161 | + #[strategy(prop::collection::vec(op_strategy(), 0..1000))] ops: Vec<InsertRemoveGetOp>, |
| 162 | +) { |
| 163 | + let mut pb = SortedIndexBuffer::default(); |
| 164 | + let mut reference = BTreeMap::new(); |
| 165 | + |
| 166 | + for op in ops { |
| 167 | + match op { |
| 168 | + InsertRemoveGetOp::Insert(k, v) => { |
| 169 | + pb.insert(k, v); |
| 170 | + reference.insert(k, v); |
| 171 | + } |
| 172 | + InsertRemoveGetOp::Remove(k) => { |
| 173 | + let v1 = pb.remove(k); |
| 174 | + let v2 = reference.remove(&k); |
| 175 | + assert_eq!(v1, v2); |
| 176 | + } |
| 177 | + InsertRemoveGetOp::Get(k) => { |
| 178 | + let v1 = pb.get(k); |
| 179 | + let v2 = reference.get(&k); |
| 180 | + assert_eq!(v1, v2); |
182 | 181 | } |
183 | | - pb.check_invariants_expensive(); |
184 | 182 | } |
185 | | - |
186 | | - // Final state should match |
187 | | - assert_same(pb.iter(), reference.iter().map(|(k, v)| (*k, v))); |
| 183 | + pb.check_invariants_expensive(); |
188 | 184 | } |
| 185 | + |
| 186 | + // Final state should match |
| 187 | + assert_same(pb.iter(), reference.iter().map(|(k, v)| (*k, v))); |
189 | 188 | } |
0 commit comments