-
Notifications
You must be signed in to change notification settings - Fork 112
Expand file tree
/
Copy pathmanaged_map_unit_tests.rs
More file actions
109 lines (80 loc) · 2.77 KB
/
managed_map_unit_tests.rs
File metadata and controls
109 lines (80 loc) · 2.77 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
use multiversx_sc::types::{ManagedBuffer, ManagedMap};
use multiversx_sc_scenario::api::StaticApi;
// ManagedMap intentionally does not implement Send or Sync,
// since it holds a managed handle that is only valid on the thread of the original context.
static_assertions::assert_not_impl_any!(ManagedMap::<StaticApi>: Send, Sync);
#[test]
fn key_mutability_test() {
let mut map = ManagedMap::<StaticApi>::new();
let mut key = ManagedBuffer::from("hello");
let value = ManagedBuffer::from("world");
map.put(&key, &value);
let result = map.get(&key);
assert_eq!(result, value);
key.overwrite(b"more_text");
let result = map.get(&key);
assert!(result.is_empty());
}
#[test]
fn key_mutation_breaks_contains() {
let mut map = ManagedMap::<StaticApi>::new();
let mut key = ManagedBuffer::from("test_key");
let value = ManagedBuffer::from("test_value");
map.put(&key, &value);
assert!(map.contains(&key));
key.overwrite(b"different_key");
assert!(!map.contains(&key));
}
#[test]
fn key_mutation_breaks_remove() {
let mut map = ManagedMap::<StaticApi>::new();
let mut key = ManagedBuffer::from("removable");
let value = ManagedBuffer::from("value");
map.put(&key, &value);
key.overwrite(b"not_removable");
let removed = map.remove(&key);
assert!(removed.is_empty());
let still_there = map.get(&ManagedBuffer::from("removable"));
assert_eq!(still_there, value);
}
#[test]
fn multiple_keys_same_buffer_mutation() {
let mut map = ManagedMap::<StaticApi>::new();
let mut key_buffer = ManagedBuffer::from("key1");
let value1 = ManagedBuffer::from("value1");
map.put(&key_buffer, &value1);
key_buffer.overwrite(b"key2");
let value2 = ManagedBuffer::from("value2");
map.put(&key_buffer, &value2);
key_buffer.overwrite(b"key1");
let result1 = map.get(&key_buffer);
assert_eq!(result1, value1);
key_buffer.overwrite(b"key2");
let result2 = map.get(&key_buffer);
assert_eq!(result2, value2);
}
#[test]
fn key_mutation_then_restore() {
let mut map = ManagedMap::<StaticApi>::new();
let mut key = ManagedBuffer::from("original");
let value = ManagedBuffer::from("value");
map.put(&key, &value);
key.overwrite(b"changed");
assert!(map.get(&key).is_empty());
key.overwrite(b"original");
let result = map.get(&key);
assert_eq!(result, value);
}
#[test]
fn empty_key_mutation() {
let mut map = ManagedMap::<StaticApi>::new();
let mut key = ManagedBuffer::from("");
let value = ManagedBuffer::from("empty_key_value");
map.put(&key, &value);
key.overwrite(b"not_empty");
let result = map.get(&key);
assert!(result.is_empty());
key.overwrite(b"");
let result = map.get(&key);
assert_eq!(result, value);
}