2019-06-05 23:15:39 +02:00
|
|
|
function testNumeric<K extends number>(): void {
|
2018-06-21 00:57:46 +02:00
|
|
|
var set = new Set<K>();
|
2018-01-15 00:08:06 +01:00
|
|
|
|
2018-06-21 00:57:46 +02:00
|
|
|
// insert new
|
|
|
|
for (let k: K = 0; k < 100; ++k) {
|
|
|
|
assert(!set.has(k));
|
|
|
|
set.add(k);
|
|
|
|
assert(set.has(k));
|
|
|
|
}
|
|
|
|
assert(set.size == 100);
|
2018-01-15 00:08:06 +01:00
|
|
|
|
2018-06-21 00:57:46 +02:00
|
|
|
// insert duplicate
|
|
|
|
for (let k: K = 50; k < 100; ++k) {
|
|
|
|
assert(set.has(k));
|
|
|
|
set.add(k);
|
|
|
|
assert(set.has(k));
|
|
|
|
}
|
|
|
|
assert(set.size == 100);
|
2018-01-15 00:08:06 +01:00
|
|
|
|
2018-06-21 00:57:46 +02:00
|
|
|
// delete
|
|
|
|
for (let k: K = 0; k < 50; ++k) {
|
|
|
|
assert(set.has(k));
|
|
|
|
set.delete(k);
|
|
|
|
assert(!set.has(k));
|
|
|
|
}
|
|
|
|
assert(set.size == 50);
|
2018-01-15 00:08:06 +01:00
|
|
|
|
2018-06-21 00:57:46 +02:00
|
|
|
// insert + delete
|
|
|
|
for (let k: K = 0; k < 50; ++k) {
|
|
|
|
assert(!set.has(k));
|
|
|
|
set.add(k);
|
|
|
|
assert(set.has(k));
|
|
|
|
set.delete(k);
|
|
|
|
assert(!set.has(k));
|
|
|
|
}
|
|
|
|
assert(set.size == 50);
|
2018-01-15 00:08:06 +01:00
|
|
|
|
2018-06-21 00:57:46 +02:00
|
|
|
// clear
|
|
|
|
set.clear();
|
|
|
|
assert(set.size == 0);
|
|
|
|
}
|
2018-01-15 00:08:06 +01:00
|
|
|
|
2019-06-05 23:15:39 +02:00
|
|
|
testNumeric<i8>();
|
|
|
|
testNumeric<u8>();
|
|
|
|
testNumeric<i16>();
|
|
|
|
testNumeric<u16>();
|
|
|
|
testNumeric<i32>();
|
|
|
|
testNumeric<u32>();
|
|
|
|
testNumeric<i64>();
|
|
|
|
testNumeric<u64>();
|
|
|
|
testNumeric<f32>();
|
|
|
|
testNumeric<f64>();
|