blob: cc836d8fcc55464a83428e235992988275cb5e7b [file] [log] [blame]
// Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
/// @assertion @assertion LinkedHashMap<K, V> abstract class
/// implements HashMap<K, V>
/// Values are iterated in their corresponding key's order.
/// @description Checks that [LinkedHashMap] preserves insertion order for
/// values.
/// @author iarkh@unipro.ru
import "../../../Utils/expect.dart";
import "dart:collection";
checkOrder(LinkedHashMap map, List list, dynamic key, dynamic value) {
map[key] = value;
list.add(value);
int i = 0;
for(var k in map.values) {
Expect.equals(list[i++], k);
}
}
main() {
LinkedHashMap map = new LinkedHashMap();
List list = new List.empty(growable: true);
checkOrder(map, list, 0, 1);
checkOrder(map, list, 2, 2);
checkOrder(map, list, "test", 3);
checkOrder(map, list, "test1", 256);
checkOrder(map, list, -23, -11);
checkOrder(map, list, 4, 39);
checkOrder(map, list, 1, "testme");
checkOrder(map, list, 15, null);
checkOrder(map, list, new Object(), new Object());
}