dart-sdk/tests/lib/collection/hash_map_test.dart
Robert Nystrom ccaea0ef80 Migrate lib_2/collection tests to NNBD.
Change-Id: Ia76fb4b8354127638af281ad735c3e4aee99ef0c
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/128309
Auto-Submit: Bob Nystrom <rnystrom@google.com>
Reviewed-by: Lasse R.H. Nielsen <lrn@google.com>
Commit-Queue: Bob Nystrom <rnystrom@google.com>
2019-12-17 20:25:14 +00:00

43 lines
1.5 KiB
Dart

// Copyright (c) 2011, 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.
import "dart:collection";
import "package:expect/expect.dart";
void main() {
// Test customized maps.
// Regression test for issue http://dartbug.com/18109
int hash(s) => s.toLowerCase().hashCode;
bool equals(a, b) => a.toLowerCase() == b.toLowerCase();
for (var m in [
new HashMap<String, int>(equals: equals, hashCode: hash),
new LinkedHashMap<String, int>(equals: equals, hashCode: hash),
]) {
m["Abel"] = 42;
for (var key in ["Abel", "abel", "ABEL", "Abel"]) {
Expect.isTrue(m.containsKey(key), "contains $key in ${m.runtimeType} $m");
Expect.equals(42, m[key], "get $key in ${m.runtimeType} $m");
Expect.equals(42, m.remove(key), "remove $key in ${m.runtimeType} $m");
m[key] = 42;
}
}
int abshash(n) => n.abs();
bool abseq(a, b) => a.abs() == b.abs();
for (var m in [
new HashMap<int, int>(equals: abseq, hashCode: abshash),
new LinkedHashMap<int, int>(equals: abseq, hashCode: abshash),
]) {
m[1] = 42;
for (var key in [1, -1, 1]) {
Expect.isTrue(m.containsKey(key), "contains $key in ${m.runtimeType} $m");
Expect.equals(42, m[key], "get $key in ${m.runtimeType} $m");
Expect.equals(42, m.remove(key), "remove $key in ${m.runtimeType} $m");
m[key] = 42;
}
}
}