use super::*;
use std::string::String;
#[test]
fn it_works() {
let mut map = IndexMap::new();
assert_eq!(map.is_empty(), true);
map.insert(1, ());
map.insert(1, ());
assert_eq!(map.len(), 1);
assert!(map.get(&1).is_some());
assert_eq!(map.is_empty(), false);
}
#[test]
fn new() {
let map = IndexMap::<String, String>::new();
println!("{:?}", map);
assert_eq!(map.capacity(), 0);
assert_eq!(map.len(), 0);
assert_eq!(map.is_empty(), true);
}
#[test]
fn insert() {
let insert = [0, 4, 2, 12, 8, 7, 11, 5];
let not_present = [1, 3, 6, 9, 10];
let mut map = IndexMap::with_capacity(insert.len());
for (i, &elt) in insert.iter().enumerate() {
assert_eq!(map.len(), i);
map.insert(elt, elt);
assert_eq!(map.len(), i + 1);
assert_eq!(map.get(&elt), Some(&elt));
assert_eq!(map[&elt], elt);
}
println!("{:?}", map);
for &elt in ¬_present {
assert!(map.get(&elt).is_none());
}
}
#[test]
fn insert_full() {
let insert = vec![9, 2, 7, 1, 4, 6, 13];
let present = vec![1, 6, 2];
let mut map = IndexMap::with_capacity(insert.len());
for (i, &elt) in insert.iter().enumerate() {
assert_eq!(map.len(), i);
let (index, existing) = map.insert_full(elt, elt);
assert_eq!(existing, None);
assert_eq!(Some(index), map.get_full(&elt).map(|x| x.0));
assert_eq!(map.len(), i + 1);
}
let len = map.len();
for &elt in &present {
let (index, existing) = map.insert_full(elt, elt);
assert_eq!(existing, Some(elt));
assert_eq!(Some(index), map.get_full(&elt).map(|x| x.0));
assert_eq!(map.len(), len);
}
}
#[test]
fn insert_2() {
let mut map = IndexMap::with_capacity(16);
let mut keys = vec![];
keys.extend(0..16);
keys.extend(if cfg!(miri) { 32..64 } else { 128..267 });
for &i in &keys {
let old_map = map.clone();
map.insert(i, ());
for key in old_map.keys() {
if map.get(key).is_none() {
println!("old_map: {:?}", old_map);
println!("map: {:?}", map);
panic!("did not find {} in map", key);
}
}
}
for &i in &keys {
assert!(map.get(&i).is_some(), "did not find {}", i);
}
}
#[test]
fn insert_order() {
let insert = [0, 4, 2, 12, 8, 7, 11, 5, 3, 17, 19, 22, 23];
let mut map = IndexMap::new();
for &elt in &insert {
map.insert(elt, ());
}
assert_eq!(map.keys().count(), map.len());
assert_eq!(map.keys().count(), insert.len());
for (a, b) in insert.iter().zip(map.keys()) {
assert_eq!(a, b);
}
for (i, k) in (0..insert.len()).zip(map.keys()) {
assert_eq!(map.get_index(i).unwrap().0, k);
}
}
#[test]
fn shift_insert() {
let insert = [0, 4, 2, 12, 8, 7, 11, 5, 3, 17, 19, 22, 23];
let mut map = IndexMap::new();
for &elt in &insert {
map.shift_insert(0, elt, ());
}
assert_eq!(map.keys().count(), map.len());
assert_eq!(map.keys().count(), insert.len());
for (a, b) in insert.iter().rev().zip(map.keys()) {
assert_eq!(a, b);
}
for (i, k) in (0..insert.len()).zip(map.keys()) {
assert_eq!(map.get_index(i).unwrap().0, k);
}
map.shift_insert(0, insert[0], ());
assert_eq!(map.keys().count(), insert.len());
assert_eq!(insert[0], map.keys()[0]);
for (a, b) in insert[1..].iter().rev().zip(map.keys().skip(1)) {
assert_eq!(a, b);
}
}
#[test]
fn insert_sorted_bad() {
let mut map = IndexMap::new();
map.insert(10, ());
for i in 0..10 {
map.insert(i, ());
}
assert_eq!(map.first(), Some((&10, &())));
map.insert_sorted(10, ());
assert_eq!(map.last(), Some((&10, &())));
assert!(map.keys().copied().eq(0..=10));
map.move_index(5, 0);
map.move_index(6, 10);
assert_eq!(map.first(), Some((&5, &())));
assert_eq!(map.last(), Some((&6, &())));
map.insert_sorted(5, ()); map.insert_sorted(6, ()); assert!(map.keys().copied().eq(0..=10));
}
#[test]
fn grow() {
let insert = [0, 4, 2, 12, 8, 7, 11];
let not_present = [1, 3, 6, 9, 10];
let mut map = IndexMap::with_capacity(insert.len());
for (i, &elt) in insert.iter().enumerate() {
assert_eq!(map.len(), i);
map.insert(elt, elt);
assert_eq!(map.len(), i + 1);
assert_eq!(map.get(&elt), Some(&elt));
assert_eq!(map[&elt], elt);
}
println!("{:?}", map);
for &elt in &insert {
map.insert(elt * 10, elt);
}
for &elt in &insert {
map.insert(elt * 100, elt);
}
for (i, &elt) in insert.iter().cycle().enumerate().take(100) {
map.insert(elt * 100 + i as i32, elt);
}
println!("{:?}", map);
for &elt in ¬_present {
assert!(map.get(&elt).is_none());
}
}
#[test]
fn reserve() {
let mut map = IndexMap::<usize, usize>::new();
assert_eq!(map.capacity(), 0);
map.reserve(100);
let capacity = map.capacity();
assert!(capacity >= 100);
for i in 0..capacity {
assert_eq!(map.len(), i);
map.insert(i, i * i);
assert_eq!(map.len(), i + 1);
assert_eq!(map.capacity(), capacity);
assert_eq!(map.get(&i), Some(&(i * i)));
}
map.insert(capacity, std::usize::MAX);
assert_eq!(map.len(), capacity + 1);
assert!(map.capacity() > capacity);
assert_eq!(map.get(&capacity), Some(&std::usize::MAX));
}
#[test]
fn try_reserve() {
let mut map = IndexMap::<usize, usize>::new();
assert_eq!(map.capacity(), 0);
assert_eq!(map.try_reserve(100), Ok(()));
assert!(map.capacity() >= 100);
assert!(map.try_reserve(usize::MAX).is_err());
}
#[test]
fn shrink_to_fit() {
let mut map = IndexMap::<usize, usize>::new();
assert_eq!(map.capacity(), 0);
for i in 0..100 {
assert_eq!(map.len(), i);
map.insert(i, i * i);
assert_eq!(map.len(), i + 1);
assert!(map.capacity() >= i + 1);
assert_eq!(map.get(&i), Some(&(i * i)));
map.shrink_to_fit();
assert_eq!(map.len(), i + 1);
assert_eq!(map.capacity(), i + 1);
assert_eq!(map.get(&i), Some(&(i * i)));
}
}
#[test]
fn remove() {
let insert = [0, 4, 2, 12, 8, 7, 11, 5, 3, 17, 19, 22, 23];
let mut map = IndexMap::new();
for &elt in &insert {
map.insert(elt, elt);
}
assert_eq!(map.keys().count(), map.len());
assert_eq!(map.keys().count(), insert.len());
for (a, b) in insert.iter().zip(map.keys()) {
assert_eq!(a, b);
}
let remove_fail = [99, 77];
let remove = [4, 12, 8, 7];
for &key in &remove_fail {
assert!(map.swap_remove_full(&key).is_none());
}
println!("{:?}", map);
for &key in &remove {
let index = map.get_full(&key).unwrap().0;
assert_eq!(map.swap_remove_full(&key), Some((index, key, key)));
}
println!("{:?}", map);
for key in &insert {
assert_eq!(map.get(key).is_some(), !remove.contains(key));
}
assert_eq!(map.len(), insert.len() - remove.len());
assert_eq!(map.keys().count(), insert.len() - remove.len());
}
#[test]
fn remove_to_empty() {
let mut map = indexmap! { 0 => 0, 4 => 4, 5 => 5 };
map.swap_remove(&5).unwrap();
map.swap_remove(&4).unwrap();
map.swap_remove(&0).unwrap();
assert!(map.is_empty());
}
#[test]
fn swap_remove_index() {
let insert = [0, 4, 2, 12, 8, 7, 11, 5, 3, 17, 19, 22, 23];
let mut map = IndexMap::new();
for &elt in &insert {
map.insert(elt, elt * 2);
}
let mut vector = insert.to_vec();
let remove_sequence = &[3, 3, 10, 4, 5, 4, 3, 0, 1];
for &rm in remove_sequence {
let out_vec = vector.swap_remove(rm);
let (out_map, _) = map.swap_remove_index(rm).unwrap();
assert_eq!(out_vec, out_map);
}
assert_eq!(vector.len(), map.len());
for (a, b) in vector.iter().zip(map.keys()) {
assert_eq!(a, b);
}
}
#[test]
fn partial_eq_and_eq() {
let mut map_a = IndexMap::new();
map_a.insert(1, "1");
map_a.insert(2, "2");
let mut map_b = map_a.clone();
assert_eq!(map_a, map_b);
map_b.swap_remove(&1);
assert_ne!(map_a, map_b);
let map_c: IndexMap<_, String> = map_b.into_iter().map(|(k, v)| (k, v.into())).collect();
assert_ne!(map_a, map_c);
assert_ne!(map_c, map_a);
}
#[test]
fn extend() {
let mut map = IndexMap::new();
map.extend(vec![(&1, &2), (&3, &4)]);
map.extend(vec![(5, 6)]);
assert_eq!(
map.into_iter().collect::<Vec<_>>(),
vec![(1, 2), (3, 4), (5, 6)]
);
}
#[test]
fn entry() {
let mut map = IndexMap::new();
map.insert(1, "1");
map.insert(2, "2");
{
let e = map.entry(3);
assert_eq!(e.index(), 2);
let e = e.or_insert("3");
assert_eq!(e, &"3");
}
let e = map.entry(2);
assert_eq!(e.index(), 1);
assert_eq!(e.key(), &2);
match e {
Entry::Occupied(ref e) => assert_eq!(e.get(), &"2"),
Entry::Vacant(_) => panic!(),
}
assert_eq!(e.or_insert("4"), &"2");
}
#[test]
fn entry_and_modify() {
let mut map = IndexMap::new();
map.insert(1, "1");
map.entry(1).and_modify(|x| *x = "2");
assert_eq!(Some(&"2"), map.get(&1));
map.entry(2).and_modify(|x| *x = "doesn't exist");
assert_eq!(None, map.get(&2));
}
#[test]
fn entry_or_default() {
let mut map = IndexMap::new();
#[derive(Debug, PartialEq)]
enum TestEnum {
DefaultValue,
NonDefaultValue,
}
impl Default for TestEnum {
fn default() -> Self {
TestEnum::DefaultValue
}
}
map.insert(1, TestEnum::NonDefaultValue);
assert_eq!(&mut TestEnum::NonDefaultValue, map.entry(1).or_default());
assert_eq!(&mut TestEnum::DefaultValue, map.entry(2).or_default());
}
#[test]
fn occupied_entry_key() {
let (k1, k2) = (&mut 1, &mut 1);
let k1_ptr = k1 as *const i32;
let k2_ptr = k2 as *const i32;
assert_ne!(k1_ptr, k2_ptr);
let mut map = IndexMap::new();
map.insert(k1, "value");
match map.entry(k2) {
Entry::Occupied(ref e) => {
let ptr = *e.key() as *const i32;
assert_eq!(ptr, k1_ptr);
assert_ne!(ptr, k2_ptr);
}
Entry::Vacant(_) => panic!(),
}
}
#[test]
fn get_index_entry() {
let mut map = IndexMap::new();
assert!(map.get_index_entry(0).is_none());
assert!(map.first_entry().is_none());
assert!(map.last_entry().is_none());
map.insert(0, "0");
map.insert(1, "1");
map.insert(2, "2");
map.insert(3, "3");
assert!(map.get_index_entry(4).is_none());
{
let e = map.get_index_entry(1).unwrap();
assert_eq!(*e.key(), 1);
assert_eq!(*e.get(), "1");
assert_eq!(e.swap_remove(), "1");
}
{
let mut e = map.get_index_entry(1).unwrap();
assert_eq!(*e.key(), 3);
assert_eq!(*e.get(), "3");
assert_eq!(e.insert("4"), "3");
}
assert_eq!(*map.get(&3).unwrap(), "4");
{
let e = map.first_entry().unwrap();
assert_eq!(*e.key(), 0);
assert_eq!(*e.get(), "0");
}
{
let e = map.last_entry().unwrap();
assert_eq!(*e.key(), 2);
assert_eq!(*e.get(), "2");
}
}
#[test]
fn from_entries() {
let mut map = IndexMap::from([(1, "1"), (2, "2"), (3, "3")]);
{
let e = match map.entry(1) {
Entry::Occupied(e) => IndexedEntry::from(e),
Entry::Vacant(_) => panic!(),
};
assert_eq!(e.index(), 0);
assert_eq!(*e.key(), 1);
assert_eq!(*e.get(), "1");
}
{
let e = match map.get_index_entry(1) {
Some(e) => OccupiedEntry::from(e),
None => panic!(),
};
assert_eq!(e.index(), 1);
assert_eq!(*e.key(), 2);
assert_eq!(*e.get(), "2");
}
}
#[test]
fn keys() {
let vec = vec![(1, 'a'), (2, 'b'), (3, 'c')];
let map: IndexMap<_, _> = vec.into_iter().collect();
let keys: Vec<_> = map.keys().copied().collect();
assert_eq!(keys.len(), 3);
assert!(keys.contains(&1));
assert!(keys.contains(&2));
assert!(keys.contains(&3));
}
#[test]
fn into_keys() {
let vec = vec![(1, 'a'), (2, 'b'), (3, 'c')];
let map: IndexMap<_, _> = vec.into_iter().collect();
let keys: Vec<i32> = map.into_keys().collect();
assert_eq!(keys.len(), 3);
assert!(keys.contains(&1));
assert!(keys.contains(&2));
assert!(keys.contains(&3));
}
#[test]
fn values() {
let vec = vec![(1, 'a'), (2, 'b'), (3, 'c')];
let map: IndexMap<_, _> = vec.into_iter().collect();
let values: Vec<_> = map.values().copied().collect();
assert_eq!(values.len(), 3);
assert!(values.contains(&'a'));
assert!(values.contains(&'b'));
assert!(values.contains(&'c'));
}
#[test]
fn values_mut() {
let vec = vec![(1, 1), (2, 2), (3, 3)];
let mut map: IndexMap<_, _> = vec.into_iter().collect();
for value in map.values_mut() {
*value *= 2
}
let values: Vec<_> = map.values().copied().collect();
assert_eq!(values.len(), 3);
assert!(values.contains(&2));
assert!(values.contains(&4));
assert!(values.contains(&6));
}
#[test]
fn into_values() {
let vec = vec![(1, 'a'), (2, 'b'), (3, 'c')];
let map: IndexMap<_, _> = vec.into_iter().collect();
let values: Vec<char> = map.into_values().collect();
assert_eq!(values.len(), 3);
assert!(values.contains(&'a'));
assert!(values.contains(&'b'));
assert!(values.contains(&'c'));
}
#[test]
fn drain_range() {
for range in [
0..0, 10..90, 80..90, 20..30, ] {
let mut vec = Vec::from_iter(0..100);
let mut map: IndexMap<i32, ()> = (0..100).map(|i| (i, ())).collect();
drop(vec.drain(range.clone()));
drop(map.drain(range));
assert!(vec.iter().eq(map.keys()));
for (i, x) in vec.iter().enumerate() {
assert_eq!(map.get_index_of(x), Some(i));
}
}
}
#[test]
#[cfg(feature = "std")]
fn from_array() {
let map = IndexMap::from([(1, 2), (3, 4)]);
let mut expected = IndexMap::new();
expected.insert(1, 2);
expected.insert(3, 4);
assert_eq!(map, expected)
}
#[test]
fn iter_default() {
struct K;
struct V;
fn assert_default<T>()
where
T: Default + Iterator,
{
assert!(T::default().next().is_none());
}
assert_default::<Iter<'static, K, V>>();
assert_default::<IterMut<'static, K, V>>();
assert_default::<IterMut2<'static, K, V>>();
assert_default::<IntoIter<K, V>>();
assert_default::<Keys<'static, K, V>>();
assert_default::<IntoKeys<K, V>>();
assert_default::<Values<'static, K, V>>();
assert_default::<ValuesMut<'static, K, V>>();
assert_default::<IntoValues<K, V>>();
}
#[test]
fn get_index_mut2() {
let mut map: IndexMap<i32, i32> = IndexMap::new();
map.insert(1, 2);
map.insert(3, 4);
map.insert(5, 6);
{
let (key, value) = map.get_index_mut2(0).unwrap();
assert_eq!(*key, 1);
assert_eq!(*value, 2);
*value = 7;
}
assert_eq!(map[0], 7);
{
let (key, _) = map.get_index_mut2(0).unwrap();
*key = 8;
}
assert_eq!(map.get_index(0).unwrap().0, &8);
}
#[test]
fn shift_shift_remove_index() {
let mut map: IndexMap<i32, i32> = IndexMap::new();
map.insert(1, 2);
map.insert(3, 4);
map.insert(5, 6);
map.insert(7, 8);
map.insert(9, 10);
let result = map.shift_remove_index(1);
assert_eq!(result, Some((3, 4)));
assert_eq!(map.len(), 4);
assert_eq!(map.as_slice(), &[(1, 2), (5, 6), (7, 8), (9, 10)]);
let result = map.shift_remove_index(1);
assert_eq!(result, Some((5, 6)));
assert_eq!(map.len(), 3);
assert_eq!(map.as_slice(), &[(1, 2), (7, 8), (9, 10)]);
let result = map.shift_remove_index(2);
assert_eq!(result, Some((9, 10)));
assert_eq!(map.len(), 2);
assert_eq!(map.as_slice(), &[(1, 2), (7, 8)]);
let result = map.shift_remove_index(2);
assert_eq!(result, None);
assert_eq!(map.len(), 2);
assert_eq!(map.as_slice(), &[(1, 2), (7, 8)]);
}
#[test]
fn shift_remove_entry() {
let mut map: IndexMap<i32, i32> = IndexMap::new();
map.insert(1, 2);
map.insert(3, 4);
map.insert(5, 6);
map.insert(7, 8);
map.insert(9, 10);
let result = map.shift_remove_entry(&3);
assert_eq!(result, Some((3, 4)));
assert_eq!(map.len(), 4);
assert_eq!(map.as_slice(), &[(1, 2), (5, 6), (7, 8), (9, 10)]);
let result = map.shift_remove_entry(&9);
assert_eq!(result, Some((9, 10)));
assert_eq!(map.len(), 3);
assert_eq!(map.as_slice(), &[(1, 2), (5, 6), (7, 8)]);
let result = map.shift_remove_entry(&9);
assert_eq!(result, None);
assert_eq!(map.len(), 3);
assert_eq!(map.as_slice(), &[(1, 2), (5, 6), (7, 8)]);
}
#[test]
fn shift_remove_full() {
let mut map: IndexMap<i32, i32> = IndexMap::new();
map.insert(1, 2);
map.insert(3, 4);
map.insert(5, 6);
map.insert(7, 8);
map.insert(9, 10);
let result = map.shift_remove_full(&3);
assert_eq!(result, Some((1, 3, 4)));
assert_eq!(map.len(), 4);
assert_eq!(map.as_slice(), &[(1, 2), (5, 6), (7, 8), (9, 10)]);
let result = map.shift_remove_full(&9);
assert_eq!(result, Some((3, 9, 10)));
assert_eq!(map.len(), 3);
assert_eq!(map.as_slice(), &[(1, 2), (5, 6), (7, 8)]);
let result = map.shift_remove_full(&9);
assert_eq!(result, None);
assert_eq!(map.len(), 3);
assert_eq!(map.as_slice(), &[(1, 2), (5, 6), (7, 8)]);
}
#[test]
fn sorted_unstable_by() {
let mut map: IndexMap<i32, i32> = IndexMap::new();
map.extend(vec![(1, 10), (2, 20), (3, 30), (4, 40), (5, 50)]);
let sorted = map.sorted_unstable_by(|_a, b, _c, d| d.cmp(&b));
assert_eq!(
sorted.as_slice(),
&[(5, 50), (4, 40), (3, 30), (2, 20), (1, 10)]
);
}
#[test]
fn into_boxed_slice() {
let mut map: IndexMap<i32, i32> = IndexMap::new();
for i in 0..5 {
map.insert(i, i * 10);
}
let boxed_slice: Box<Slice<i32, i32>> = map.into_boxed_slice();
assert_eq!(boxed_slice.len(), 5);
assert_eq!(
boxed_slice.as_ref(),
&[(0, 0), (1, 10), (2, 20), (3, 30), (4, 40)]
);
}
#[test]
fn last_mut() {
let mut map: IndexMap<&str, i32> = IndexMap::new();
let last_entry = map.last_mut();
assert_eq!(last_entry, None);
map.insert("key1", 1);
map.insert("key2", 2);
map.insert("key3", 3);
let last_entry = map.last_mut();
assert_eq!(last_entry, Some((&"key3", &mut 3)));
*last_entry.unwrap().1 = 4;
assert_eq!(map.get("key3"), Some(&4));
}
#[test]
#[should_panic = "index out of bounds"]
fn insert_before_oob() {
let mut map: IndexMap<char, ()> = IndexMap::new();
let _ = map.insert_before(0, 'a', ());
let _ = map.insert_before(1, 'b', ());
map.insert_before(3, 'd', ());
}
#[test]
fn clear() {
let mut map: IndexMap<i32, i32> = IndexMap::new();
map.extend(vec![(1, 10), (2, 20), (3, 30), (4, 40), (5, 50)]);
map.clear();
assert_eq!(map.len(), 0);
}
#[test]
fn get_range() {
let mut index_map: IndexMap<i32, i32> = IndexMap::new();
index_map.insert(1, 10);
index_map.insert(2, 20);
index_map.insert(3, 30);
index_map.insert(4, 40);
index_map.insert(5, 50);
let result = index_map.get_range(2..2);
assert!(result.unwrap().is_empty());
let result = index_map.get_range(4..2);
assert!(result.is_none());
let result = index_map.get_range(2..4);
let slice: &Slice<i32, i32> = result.unwrap();
assert_eq!(slice.len(), 2);
assert_eq!(slice, &[(3, 30), (4, 40)]);
}
#[test]
fn get_range_mut() {
let mut index_map: IndexMap<i32, i32> = IndexMap::new();
index_map.insert(1, 10);
index_map.insert(2, 20);
index_map.insert(3, 30);
index_map.insert(4, 40);
index_map.insert(5, 50);
let result = index_map.get_range_mut(2..2);
assert!(result.unwrap().is_empty());
let result = index_map.get_range_mut(4..2);
assert!(result.is_none());
let result = index_map.get_range_mut(2..4);
let slice: &mut Slice<i32, i32> = result.unwrap();
assert_eq!(slice.len(), 2);
assert_eq!(slice, &mut [(3, 30), (4, 40)]);
for i in 0..slice.len() {
slice[i] += 1;
}
assert_eq!(slice, &mut [(3, 31), (4, 41)]);
}
#[test]
#[should_panic = "index out of bounds"]
fn shift_insert_oob() {
let mut map: IndexMap<u32, u32> = IndexMap::new();
map.shift_insert(0, 1, 10);
map.shift_insert(1, 2, 20);
map.shift_insert(2, 3, 30);
map.shift_insert(5, 4, 40);
}
#[test]
fn test_binary_search_by() {
let b: IndexMap<_, i32> = []
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by(|_, x| x.cmp(&5)), Err(0));
let b: IndexMap<_, i32> = [4]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by(|_, x| x.cmp(&3)), Err(0));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&4)), Ok(0));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&5)), Err(1));
let b: IndexMap<_, i32> = [1, 2, 4, 6, 8, 9]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by(|_, x| x.cmp(&5)), Err(3));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&6)), Ok(3));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&7)), Err(4));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&8)), Ok(4));
let b: IndexMap<_, i32> = [1, 2, 4, 5, 6, 8]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by(|_, x| x.cmp(&9)), Err(6));
let b: IndexMap<_, i32> = [1, 2, 4, 6, 7, 8, 9]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by(|_, x| x.cmp(&6)), Ok(3));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&5)), Err(3));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&8)), Ok(5));
let b: IndexMap<_, i32> = [1, 2, 4, 5, 6, 8, 9]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by(|_, x| x.cmp(&7)), Err(5));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&0)), Err(0));
let b: IndexMap<_, i32> = [1, 3, 3, 3, 7]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by(|_, x| x.cmp(&0)), Err(0));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&1)), Ok(0));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&2)), Err(1));
assert!(match b.binary_search_by(|_, x| x.cmp(&3)) {
Ok(1..=3) => true,
_ => false,
});
assert!(match b.binary_search_by(|_, x| x.cmp(&3)) {
Ok(1..=3) => true,
_ => false,
});
assert_eq!(b.binary_search_by(|_, x| x.cmp(&4)), Err(4));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&5)), Err(4));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&6)), Err(4));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&7)), Ok(4));
assert_eq!(b.binary_search_by(|_, x| x.cmp(&8)), Err(5));
}
#[test]
fn test_binary_search_by_key() {
let b: IndexMap<_, i32> = []
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by_key(&5, |_, &x| x), Err(0));
let b: IndexMap<_, i32> = [4]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by_key(&3, |_, &x| x), Err(0));
assert_eq!(b.binary_search_by_key(&4, |_, &x| x), Ok(0));
assert_eq!(b.binary_search_by_key(&5, |_, &x| x), Err(1));
let b: IndexMap<_, i32> = [1, 2, 4, 6, 8, 9]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by_key(&5, |_, &x| x), Err(3));
assert_eq!(b.binary_search_by_key(&6, |_, &x| x), Ok(3));
assert_eq!(b.binary_search_by_key(&7, |_, &x| x), Err(4));
assert_eq!(b.binary_search_by_key(&8, |_, &x| x), Ok(4));
let b: IndexMap<_, i32> = [1, 2, 4, 5, 6, 8]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by_key(&9, |_, &x| x), Err(6));
let b: IndexMap<_, i32> = [1, 2, 4, 6, 7, 8, 9]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by_key(&6, |_, &x| x), Ok(3));
assert_eq!(b.binary_search_by_key(&5, |_, &x| x), Err(3));
assert_eq!(b.binary_search_by_key(&8, |_, &x| x), Ok(5));
let b: IndexMap<_, i32> = [1, 2, 4, 5, 6, 8, 9]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by_key(&7, |_, &x| x), Err(5));
assert_eq!(b.binary_search_by_key(&0, |_, &x| x), Err(0));
let b: IndexMap<_, i32> = [1, 3, 3, 3, 7]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.binary_search_by_key(&0, |_, &x| x), Err(0));
assert_eq!(b.binary_search_by_key(&1, |_, &x| x), Ok(0));
assert_eq!(b.binary_search_by_key(&2, |_, &x| x), Err(1));
assert!(match b.binary_search_by_key(&3, |_, &x| x) {
Ok(1..=3) => true,
_ => false,
});
assert!(match b.binary_search_by_key(&3, |_, &x| x) {
Ok(1..=3) => true,
_ => false,
});
assert_eq!(b.binary_search_by_key(&4, |_, &x| x), Err(4));
assert_eq!(b.binary_search_by_key(&5, |_, &x| x), Err(4));
assert_eq!(b.binary_search_by_key(&6, |_, &x| x), Err(4));
assert_eq!(b.binary_search_by_key(&7, |_, &x| x), Ok(4));
assert_eq!(b.binary_search_by_key(&8, |_, &x| x), Err(5));
}
#[test]
fn test_partition_point() {
let b: IndexMap<_, i32> = []
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.partition_point(|_, &x| x < 5), 0);
let b: IndexMap<_, i32> = [4]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.partition_point(|_, &x| x < 3), 0);
assert_eq!(b.partition_point(|_, &x| x < 4), 0);
assert_eq!(b.partition_point(|_, &x| x < 5), 1);
let b: IndexMap<_, i32> = [1, 2, 4, 6, 8, 9]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.partition_point(|_, &x| x < 5), 3);
assert_eq!(b.partition_point(|_, &x| x < 6), 3);
assert_eq!(b.partition_point(|_, &x| x < 7), 4);
assert_eq!(b.partition_point(|_, &x| x < 8), 4);
let b: IndexMap<_, i32> = [1, 2, 4, 5, 6, 8]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.partition_point(|_, &x| x < 9), 6);
let b: IndexMap<_, i32> = [1, 2, 4, 6, 7, 8, 9]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.partition_point(|_, &x| x < 6), 3);
assert_eq!(b.partition_point(|_, &x| x < 5), 3);
assert_eq!(b.partition_point(|_, &x| x < 8), 5);
let b: IndexMap<_, i32> = [1, 2, 4, 5, 6, 8, 9]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.partition_point(|_, &x| x < 7), 5);
assert_eq!(b.partition_point(|_, &x| x < 0), 0);
let b: IndexMap<_, i32> = [1, 3, 3, 3, 7]
.into_iter()
.enumerate()
.map(|(i, x)| (i + 100, x))
.collect();
assert_eq!(b.partition_point(|_, &x| x < 0), 0);
assert_eq!(b.partition_point(|_, &x| x < 1), 0);
assert_eq!(b.partition_point(|_, &x| x < 2), 1);
assert_eq!(b.partition_point(|_, &x| x < 3), 1);
assert_eq!(b.partition_point(|_, &x| x < 4), 4);
assert_eq!(b.partition_point(|_, &x| x < 5), 4);
assert_eq!(b.partition_point(|_, &x| x < 6), 4);
assert_eq!(b.partition_point(|_, &x| x < 7), 4);
assert_eq!(b.partition_point(|_, &x| x < 8), 5);
}
macro_rules! move_index_oob {
($test:ident, $from:expr, $to:expr) => {
#[test]
#[should_panic(expected = "index out of bounds")]
fn $test() {
let mut map: IndexMap<i32, ()> = (0..10).map(|k| (k, ())).collect();
map.move_index($from, $to);
}
};
}
move_index_oob!(test_move_index_out_of_bounds_0_10, 0, 10);
move_index_oob!(test_move_index_out_of_bounds_0_max, 0, usize::MAX);
move_index_oob!(test_move_index_out_of_bounds_10_0, 10, 0);
move_index_oob!(test_move_index_out_of_bounds_max_0, usize::MAX, 0);
#[test]
fn disjoint_mut_empty_map() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
assert_eq!(
map.get_disjoint_mut([&0, &1, &2, &3]),
[None, None, None, None]
);
}
#[test]
fn disjoint_mut_empty_param() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
map.insert(1, 10);
assert_eq!(map.get_disjoint_mut([] as [&u32; 0]), []);
}
#[test]
fn disjoint_mut_single_fail() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
map.insert(1, 10);
assert_eq!(map.get_disjoint_mut([&0]), [None]);
}
#[test]
fn disjoint_mut_single_success() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
map.insert(1, 10);
assert_eq!(map.get_disjoint_mut([&1]), [Some(&mut 10)]);
}
#[test]
fn disjoint_mut_multi_success() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
map.insert(1, 100);
map.insert(2, 200);
map.insert(3, 300);
map.insert(4, 400);
assert_eq!(
map.get_disjoint_mut([&1, &2]),
[Some(&mut 100), Some(&mut 200)]
);
assert_eq!(
map.get_disjoint_mut([&1, &3]),
[Some(&mut 100), Some(&mut 300)]
);
assert_eq!(
map.get_disjoint_mut([&3, &1, &4, &2]),
[
Some(&mut 300),
Some(&mut 100),
Some(&mut 400),
Some(&mut 200)
]
);
}
#[test]
fn disjoint_mut_multi_success_unsized_key() {
let mut map: IndexMap<&'static str, u32> = IndexMap::default();
map.insert("1", 100);
map.insert("2", 200);
map.insert("3", 300);
map.insert("4", 400);
assert_eq!(
map.get_disjoint_mut(["1", "2"]),
[Some(&mut 100), Some(&mut 200)]
);
assert_eq!(
map.get_disjoint_mut(["1", "3"]),
[Some(&mut 100), Some(&mut 300)]
);
assert_eq!(
map.get_disjoint_mut(["3", "1", "4", "2"]),
[
Some(&mut 300),
Some(&mut 100),
Some(&mut 400),
Some(&mut 200)
]
);
}
#[test]
fn disjoint_mut_multi_success_borrow_key() {
let mut map: IndexMap<String, u32> = IndexMap::default();
map.insert("1".into(), 100);
map.insert("2".into(), 200);
map.insert("3".into(), 300);
map.insert("4".into(), 400);
assert_eq!(
map.get_disjoint_mut(["1", "2"]),
[Some(&mut 100), Some(&mut 200)]
);
assert_eq!(
map.get_disjoint_mut(["1", "3"]),
[Some(&mut 100), Some(&mut 300)]
);
assert_eq!(
map.get_disjoint_mut(["3", "1", "4", "2"]),
[
Some(&mut 300),
Some(&mut 100),
Some(&mut 400),
Some(&mut 200)
]
);
}
#[test]
fn disjoint_mut_multi_fail_missing() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
map.insert(1, 100);
map.insert(2, 200);
map.insert(3, 300);
map.insert(4, 400);
assert_eq!(map.get_disjoint_mut([&1, &5]), [Some(&mut 100), None]);
assert_eq!(map.get_disjoint_mut([&5, &6]), [None, None]);
assert_eq!(
map.get_disjoint_mut([&1, &5, &4]),
[Some(&mut 100), None, Some(&mut 400)]
);
}
#[test]
#[should_panic]
fn disjoint_mut_multi_fail_duplicate_panic() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
map.insert(1, 100);
map.get_disjoint_mut([&1, &2, &1]);
}
#[test]
fn disjoint_indices_mut_fail_oob() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
map.insert(1, 10);
map.insert(321, 20);
assert_eq!(
map.get_disjoint_indices_mut([1, 3]),
Err(crate::GetDisjointMutError::IndexOutOfBounds)
);
}
#[test]
fn disjoint_indices_mut_empty() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
map.insert(1, 10);
map.insert(321, 20);
assert_eq!(map.get_disjoint_indices_mut([]), Ok([]));
}
#[test]
fn disjoint_indices_mut_success() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
map.insert(1, 10);
map.insert(321, 20);
assert_eq!(map.get_disjoint_indices_mut([0]), Ok([(&1, &mut 10)]));
assert_eq!(map.get_disjoint_indices_mut([1]), Ok([(&321, &mut 20)]));
assert_eq!(
map.get_disjoint_indices_mut([0, 1]),
Ok([(&1, &mut 10), (&321, &mut 20)])
);
}
#[test]
fn disjoint_indices_mut_fail_duplicate() {
let mut map: IndexMap<u32, u32> = IndexMap::default();
map.insert(1, 10);
map.insert(321, 20);
assert_eq!(
map.get_disjoint_indices_mut([1, 0, 1]),
Err(crate::GetDisjointMutError::OverlappingIndices)
);
}
#[test]
fn insert_sorted_by_key() {
let mut values = [(-1, 8), (3, 18), (-27, 2), (-2, 5)];
let mut map: IndexMap<i32, i32> = IndexMap::new();
for (key, value) in values {
let (_, old) = map.insert_sorted_by_key(key, value, |k, _| k.abs());
assert_eq!(old, None);
}
values.sort_by_key(|(key, _)| key.abs());
assert_eq!(values, *map.as_slice());
for (key, value) in &mut values {
let (_, old) = map.insert_sorted_by_key(*key, -*value, |k, _| k.abs());
assert_eq!(old, Some(*value));
*value = -*value;
}
assert_eq!(values, *map.as_slice());
}
#[test]
fn insert_sorted_by() {
let mut values = [(1, 1), (2, 2), (3, 3), (4, 4), (5, 5)];
let mut map: IndexMap<i32, i32> = IndexMap::new();
for (key, value) in values {
let (_, old) = map.insert_sorted_by(key, value, |key1, _, key2, _| key2.cmp(key1));
assert_eq!(old, None);
}
values.reverse();
assert_eq!(values, *map.as_slice());
for (key, value) in &mut values {
let (_, old) = map.insert_sorted_by(*key, -*value, |key1, _, key2, _| key2.cmp(key1));
assert_eq!(old, Some(*value));
*value = -*value;
}
assert_eq!(values, *map.as_slice());
}
#[test]
fn is_sorted() {
fn expect(map: &IndexMap<i32, i32>, e: [bool; 7]) {
assert_eq!(e[0], map.is_sorted());
assert_eq!(e[1], map.is_sorted_by(|k1, _, k2, _| k1 < k2));
assert_eq!(e[2], map.is_sorted_by(|k1, _, k2, _| k1 > k2));
assert_eq!(e[3], map.is_sorted_by(|_, v1, _, v2| v1 < v2));
assert_eq!(e[4], map.is_sorted_by(|_, v1, _, v2| v1 > v2));
assert_eq!(e[5], map.is_sorted_by_key(|k, _| k));
assert_eq!(e[6], map.is_sorted_by_key(|_, v| v));
}
let mut map = IndexMap::from_iter((0..10).map(|i| (i, i * i)));
expect(&map, [true, true, false, true, false, true, true]);
map[5] = -1;
expect(&map, [true, true, false, false, false, true, false]);
map[5] = 25;
map.replace_index(5, -1).unwrap();
expect(&map, [false, false, false, true, false, false, true]);
}
#[test]
fn is_sorted_trivial() {
fn expect(map: &IndexMap<i32, i32>, e: [bool; 5]) {
assert_eq!(e[0], map.is_sorted());
assert_eq!(e[1], map.is_sorted_by(|_, _, _, _| true));
assert_eq!(e[2], map.is_sorted_by(|_, _, _, _| false));
assert_eq!(e[3], map.is_sorted_by_key(|_, _| 0f64));
assert_eq!(e[4], map.is_sorted_by_key(|_, _| f64::NAN));
}
let mut map = IndexMap::new();
expect(&map, [true, true, true, true, true]);
map.insert(0, 0);
expect(&map, [true, true, true, true, true]);
map.insert(1, 1);
expect(&map, [true, true, false, true, false]);
map.reverse();
expect(&map, [false, true, false, true, false]);
}