OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. |
| 4 |
| 5 /// Tests equality utilities. |
| 6 |
| 7 import "dart:collection"; |
| 8 import "package:collection_helpers/all.dart"; |
| 9 import "package:unittest/unittest.dart"; |
| 10 |
| 11 main() { |
| 12 test("IterableEquality - List", () { |
| 13 var l1 = [1, 2, 3, 4, 5]; |
| 14 var l2 = [1.0, 2.0, 3.0, 4.0, 5.0]; |
| 15 expect(const IterableEquality().equals(l1, l2), |
| 16 isTrue); |
| 17 expect(const IterableEquality(const IdentityEquality()).equals(l1, l2), |
| 18 isFalse); |
| 19 }); |
| 20 |
| 21 test("IterableEquality - LinkedSet", () { |
| 22 var l1 = new LinkedHashSet.from([1, 2, 3, 4, 5]); |
| 23 var l2 = new LinkedHashSet.from([1.0, 2.0, 3.0, 4.0, 5.0]); |
| 24 expect(const IterableEquality().equals(l1, l2), |
| 25 isTrue); |
| 26 expect(const IterableEquality(const IdentityEquality()).equals(l1, l2), |
| 27 isFalse); |
| 28 }); |
| 29 |
| 30 test("ListEquality", () { |
| 31 var l1 = [1, 2, 3, 4, 5]; |
| 32 var l2 = [1.0, 2.0, 3.0, 4.0, 5.0]; |
| 33 expect(const ListEquality().equals(l1, l2), |
| 34 isTrue); |
| 35 expect(const ListEquality(const IdentityEquality()).equals(l1, l2), |
| 36 isFalse); |
| 37 }); |
| 38 |
| 39 test("ListInequality length", () { |
| 40 var l1 = [1, 2, 3, 4, 5]; |
| 41 var l2 = [1.0, 2.0, 3.0, 4.0, 5.0, 6.0]; |
| 42 expect(const ListEquality().equals(l1, l2), |
| 43 isFalse); |
| 44 expect(const ListEquality(const IdentityEquality()).equals(l1, l2), |
| 45 isFalse); |
| 46 }); |
| 47 |
| 48 test("ListInequality value", () { |
| 49 var l1 = [1, 2, 3, 4, 5]; |
| 50 var l2 = [1.0, 2.0, 3.0, 4.0, 6.0]; |
| 51 expect(const ListEquality().equals(l1, l2), |
| 52 isFalse); |
| 53 expect(const ListEquality(const IdentityEquality()).equals(l1, l2), |
| 54 isFalse); |
| 55 }); |
| 56 |
| 57 test("UnorderedIterableEquality", () { |
| 58 var l1 = [1, 2, 3, 4, 5]; |
| 59 var l2 = [1.0, 3.0, 5.0, 4.0, 2.0]; |
| 60 expect(const UnorderedIterableEquality().equals(l1, l2), |
| 61 isTrue); |
| 62 expect(const UnorderedIterableEquality(const IdentityEquality()) |
| 63 .equals(l1, l2), |
| 64 isFalse); |
| 65 }); |
| 66 |
| 67 test("UnorderedIterableInequality length", () { |
| 68 var l1 = [1, 2, 3, 4, 5]; |
| 69 var l2 = [1.0, 3.0, 5.0, 4.0, 2.0, 1.0]; |
| 70 expect(const UnorderedIterableEquality().equals(l1, l2), |
| 71 isFalse); |
| 72 expect(const UnorderedIterableEquality(const IdentityEquality()) |
| 73 .equals(l1, l2), |
| 74 isFalse); |
| 75 }); |
| 76 |
| 77 test("UnorderedIterableInequality values", () { |
| 78 var l1 = [1, 2, 3, 4, 5]; |
| 79 var l2 = [1.0, 3.0, 5.0, 4.0, 6.0]; |
| 80 expect(const UnorderedIterableEquality().equals(l1, l2), |
| 81 isFalse); |
| 82 expect(const UnorderedIterableEquality(const IdentityEquality()) |
| 83 .equals(l1, l2), |
| 84 isFalse); |
| 85 }); |
| 86 |
| 87 test("SetEquality", () { |
| 88 var l1 = new HashSet.from([1, 2, 3, 4, 5]); |
| 89 var l2 = new LinkedHashSet.from([1.0, 3.0, 5.0, 4.0, 2.0]); |
| 90 expect(const SetEquality().equals(l1, l2), |
| 91 isTrue); |
| 92 expect(const SetEquality(const IdentityEquality()).equals(l1, l2), |
| 93 isFalse); |
| 94 }); |
| 95 |
| 96 test("SetInequality length", () { |
| 97 var l1 = new HashSet.from([1, 2, 3, 4, 5]); |
| 98 var l2 = new LinkedHashSet.from([1.0, 3.0, 5.0, 4.0, 2.0, 6.0]); |
| 99 expect(const SetEquality().equals(l1, l2), |
| 100 isFalse); |
| 101 expect(const SetEquality(const IdentityEquality()).equals(l1, l2), |
| 102 isFalse); |
| 103 }); |
| 104 |
| 105 test("SetInequality value", () { |
| 106 var l1 = new HashSet.from([1, 2, 3, 4, 5]); |
| 107 var l2 = new LinkedHashSet.from([1.0, 3.0, 5.0, 4.0, 6.0]); |
| 108 expect(const SetEquality().equals(l1, l2), |
| 109 isFalse); |
| 110 expect(const SetEquality(const IdentityEquality()).equals(l1, l2), |
| 111 isFalse); |
| 112 }); |
| 113 |
| 114 var map1a = {"x": [1, 2, 3], "y": [true, false, null]}; |
| 115 var map1b = {"x": [4.0, 5.0, 6.0], "y": [false, true, null]}; |
| 116 var map2a = {"x": [3.0, 2.0, 1.0], "y": [false, true, null]}; |
| 117 var map2b = {"x": [6, 5, 4], "y": [null, false, true]}; |
| 118 var l1 = [map1a, map1b]; |
| 119 var l2 = [map2a, map2b]; |
| 120 var s1 = new Set.from(l1); |
| 121 var s2 = new Set.from([map2b, map2a]); |
| 122 |
| 123 test("RecursiveEquality", () { |
| 124 const unordered = const UnorderedIterableEquality(); |
| 125 expect(unordered.equals(map1a["x"], map2a["x"]), |
| 126 isTrue); |
| 127 expect(unordered.equals(map1a["y"], map2a["y"]), |
| 128 isTrue); |
| 129 expect(unordered.equals(map1b["x"], map2b["x"]), |
| 130 isTrue); |
| 131 expect(unordered.equals(map1b["y"], map2b["y"]), |
| 132 isTrue); |
| 133 const mapval = const MapEquality(values: unordered); |
| 134 expect( |
| 135 mapval.equals(map1a, map2a), |
| 136 isTrue); |
| 137 expect(mapval.equals(map1b, map2b), |
| 138 isTrue); |
| 139 const listmapval = const ListEquality(mapval); |
| 140 expect(listmapval.equals(l1, l2), |
| 141 isTrue); |
| 142 const setmapval = const SetEquality(mapval); |
| 143 expect(setmapval.equals(s1, s2), |
| 144 isTrue); |
| 145 }); |
| 146 |
| 147 test("DeepEquality", () { |
| 148 var colleq = const DeepCollectionEquality.unordered(); |
| 149 expect(colleq.equals(map1a["x"], map2a["x"]), |
| 150 isTrue); |
| 151 expect(colleq.equals(map1a["y"], map2a["y"]), |
| 152 isTrue); |
| 153 expect(colleq.equals(map1b["x"], map2b["x"]), |
| 154 isTrue); |
| 155 expect(colleq.equals(map1b["y"], map2b["y"]), |
| 156 isTrue); |
| 157 expect(colleq.equals(map1a, map2a), |
| 158 isTrue); |
| 159 expect(colleq.equals(map1b, map2b), |
| 160 isTrue); |
| 161 expect(colleq.equals(l1, l2), |
| 162 isTrue); |
| 163 expect(colleq.equals(s1, s2), |
| 164 isTrue); |
| 165 }); |
| 166 } |
| 167 |
OLD | NEW |