Index: tests/compiler/dart2js/serialization_test.dart |
diff --git a/tests/compiler/dart2js/serialization_test.dart b/tests/compiler/dart2js/serialization_test.dart |
index c19fb6145296975bb3bebd62d252b6ff80d29750..fd6ae587ff2ea9679a4b3ed5599c29c4f29055ed 100644 |
--- a/tests/compiler/dart2js/serialization_test.dart |
+++ b/tests/compiler/dart2js/serialization_test.dart |
@@ -20,6 +20,7 @@ import 'package:compiler/src/serialization/element_serialization.dart'; |
import 'package:compiler/src/serialization/equivalence.dart'; |
import 'package:compiler/src/serialization/json_serializer.dart'; |
import 'package:compiler/src/serialization/serialization.dart'; |
+import 'serialization_test_helper.dart'; |
main(List<String> arguments) { |
// Ensure that we can print out constant expressions. |
@@ -132,262 +133,6 @@ checkElementProperties( |
const ElementPropertyEquivalence().visit(element1, element2); |
} |
-/// Check the equivalence of the two lists of elements, [list1] and [list2]. |
-/// |
-/// Uses [object1], [object2] and [property] to provide context for failures. |
-checkElementLists(Object object1, Object object2, String property, |
- Iterable<Element> list1, Iterable<Element> list2) { |
- checkListEquivalence(object1, object2, property, |
- list1, list2, checkElementProperties); |
-} |
- |
-/// Check equivalence of the two lists, [list1] and [list2], using |
-/// [checkEquivalence] to check the pair-wise equivalence. |
-/// |
-/// Uses [object1], [object2] and [property] to provide context for failures. |
-bool checkListEquivalence( |
- Object object1, Object object2, String property, |
- Iterable list1, Iterable list2, |
- void checkEquivalence(o1, o2, property, a, b)) { |
- for (int i = 0; i < list1.length && i < list2.length; i++) { |
- checkEquivalence( |
- object1, object2, property, |
- list1.elementAt(i), list2.elementAt(i)); |
- } |
- for (int i = list1.length; i < list2.length; i++) { |
- throw |
- 'Missing equivalent for element ' |
- '#$i ${list2.elementAt(i)} in `${property}` on $object2.\n' |
- '`${property}` on $object1:\n ${list1.join('\n ')}\n' |
- '`${property}` on $object2:\n ${list2.join('\n ')}'; |
- } |
- for (int i = list2.length; i < list1.length; i++) { |
- throw |
- 'Missing equivalent for element ' |
- '#$i ${list1.elementAt(i)} in `${property}` on $object1.\n' |
- '`${property}` on $object1:\n ${list1.join('\n ')}\n' |
- '`${property}` on $object2:\n ${list2.join('\n ')}'; |
- } |
- return true; |
-} |
- |
-/// Computes the set difference between [set1] and [set2] using |
-/// [elementEquivalence] to determine element equivalence. |
-/// |
-/// Elements both in [set1] and [set2] are added to [common], elements in [set1] |
-/// but not in [set2] are added to [unfound], and the set of elements in [set2] |
-/// but not in [set1] are returned. |
-Set computeSetDifference( |
- Iterable set1, |
- Iterable set2, |
- List common, |
- List unfound, |
- [bool sameElement(a, b) = equality]) { |
- // TODO(johnniwinther): Avoid the quadratic cost here. Some ideas: |
- // - convert each set to a list and sort it first, then compare by walking |
- // both lists in parallel |
- // - map each element to a canonical object, create a map containing those |
- // mappings, use the mapped sets to compare (then operations like |
- // set.difference would work) |
- Set remaining = set2.toSet(); |
- for (var element1 in set1) { |
- bool found = false; |
- for (var element2 in remaining) { |
- if (sameElement(element1, element2)) { |
- found = true; |
- remaining.remove(element2); |
- break; |
- } |
- } |
- if (found) { |
- common.add(element1); |
- } else { |
- unfound.add(element1); |
- } |
- } |
- return remaining; |
-} |
- |
-/// Check equivalence of the two iterables, [set1] and [set1], as sets using |
-/// [elementEquivalence] to compute the pair-wise equivalence. |
-/// |
-/// Uses [object1], [object2] and [property] to provide context for failures. |
-bool checkSetEquivalence( |
- var object1, |
- var object2, |
- String property, |
- Iterable set1, |
- Iterable set2, |
- bool sameElement(a, b)) { |
- List common = []; |
- List unfound = []; |
- Set remaining = |
- computeSetDifference(set1, set2, common, unfound, sameElement); |
- if (unfound.isNotEmpty || remaining.isNotEmpty) { |
- String message = |
- "Set mismatch for `$property` on $object1 vs $object2: \n" |
- "Common:\n ${common.join('\n ')}\n" |
- "Unfound:\n ${unfound.join('\n ')}\n" |
- "Extra: \n ${remaining.join('\n ')}"; |
- throw message; |
- } |
- return true; |
-} |
- |
-/// Checks the equivalence of the identity (but not properties) of [element1] |
-/// and [element2]. |
-/// |
-/// Uses [object1], [object2] and [property] to provide context for failures. |
-bool checkElementIdentities( |
- Object object1, Object object2, String property, |
- Element element1, Element element2) { |
- if (identical(element1, element2)) return true; |
- if (element1 == null || element2 == null) { |
- return check(object1, object2, property, element1, element2); |
- } else { |
- return const ElementIdentityEquivalence(const CheckStrategy()) |
- .visit(element1, element2); |
- } |
-} |
- |
-/// Checks the pair-wise equivalence of the identity (but not properties) of the |
-/// elements in [list] and [list2]. |
-/// |
-/// Uses [object1], [object2] and [property] to provide context for failures. |
-bool checkElementListIdentities( |
- Object object1, Object object2, String property, |
- Iterable<Element> list1, Iterable<Element> list2) { |
- return checkListEquivalence( |
- object1, object2, property, |
- list1, list2, checkElementIdentities); |
-} |
- |
-/// Checks the equivalence of [type1] and [type2]. |
-/// |
-/// Uses [object1], [object2] and [property] to provide context for failures. |
-bool checkTypes( |
- Object object1, Object object2, String property, |
- DartType type1, DartType type2) { |
- if (identical(type1, type2)) return true; |
- if (type1 == null || type2 == null) { |
- return check(object1, object2, property, type1, type2); |
- } else { |
- return const TypeEquivalence(const CheckStrategy()).visit(type1, type2); |
- } |
-} |
- |
-/// Checks the pair-wise equivalence of the types in [list1] and [list2]. |
-/// |
-/// Uses [object1], [object2] and [property] to provide context for failures. |
-bool checkTypeLists( |
- Object object1, Object object2, String property, |
- List<DartType> list1, List<DartType> list2) { |
- return checkListEquivalence( |
- object1, object2, property, list1, list2, checkTypes); |
-} |
- |
-/// Checks the equivalence of [exp1] and [exp2]. |
-/// |
-/// Uses [object1], [object2] and [property] to provide context for failures. |
-bool checkConstants( |
- Object object1, Object object2, String property, |
- ConstantExpression exp1, ConstantExpression exp2) { |
- if (identical(exp1, exp2)) return true; |
- if (exp1 == null || exp2 == null) { |
- return check(object1, object2, property, exp1, exp2); |
- } else { |
- return const ConstantEquivalence(const CheckStrategy()).visit(exp1, exp2); |
- } |
-} |
- |
-/// Checks the pair-wise equivalence of the contants in [list1] and [list2]. |
-/// |
-/// Uses [object1], [object2] and [property] to provide context for failures. |
-bool checkConstantLists( |
- Object object1, Object object2, String property, |
- List<ConstantExpression> list1, |
- List<ConstantExpression> list2) { |
- return checkListEquivalence( |
- object1, object2, property, |
- list1, list2, checkConstants); |
-} |
- |
- |
-/// Strategy for checking equivalence. |
-/// |
-/// Use this strategy to fail early with contextual information in the event of |
-/// inequivalence. |
-class CheckStrategy implements TestStrategy { |
- const CheckStrategy(); |
- |
- @override |
- bool test(var object1, var object2, String property, var value1, var value2) { |
- return check(object1, object2, property, value1, value2); |
- } |
- |
- @override |
- bool testLists( |
- Object object1, Object object2, String property, |
- List list1, List list2, |
- [bool elementEquivalence(a, b) = equality]) { |
- return checkListEquivalence( |
- object1, object2, property, list1, list2, |
- (o1, o2, p, v1, v2) { |
- if (!elementEquivalence(v1, v2)) { |
- throw "$o1.$p = '${v1}' <> " |
- "$o2.$p = '${v2}'"; |
- } |
- return true; |
- }); |
- } |
- |
- @override |
- bool testSets( |
- var object1, var object2, String property, |
- Iterable set1, Iterable set2, |
- [bool elementEquivalence(a, b) = equality]) { |
- return checkSetEquivalence( |
- object1, object2,property, set1, set2, elementEquivalence); |
- } |
- |
- @override |
- bool testElements( |
- Object object1, Object object2, String property, |
- Element element1, Element element2) { |
- return checkElementIdentities( |
- object1, object2, property, element1, element2); |
- } |
- |
- @override |
- bool testTypes( |
- Object object1, Object object2, String property, |
- DartType type1, DartType type2) { |
- return checkTypes(object1, object2, property, type1, type2); |
- } |
- |
- @override |
- bool testConstants( |
- Object object1, Object object2, String property, |
- ConstantExpression exp1, ConstantExpression exp2) { |
- return checkConstants(object1, object2, property, exp1, exp2); |
- } |
- |
- @override |
- bool testTypeLists( |
- Object object1, Object object2, String property, |
- List<DartType> list1, List<DartType> list2) { |
- return checkTypeLists(object1, object2, property, list1, list2); |
- } |
- |
- @override |
- bool testConstantLists( |
- Object object1, Object object2, String property, |
- List<ConstantExpression> list1, |
- List<ConstantExpression> list2) { |
- return checkConstantLists(object1, object2, property, list1, list2); |
- } |
-} |
- |
/// Checks the equivalence of [constructor1] and [constructor2]. |
void constantConstructorEquivalence(ConstantConstructor constructor1, |
ConstantConstructor constructor2) { |
@@ -477,14 +222,13 @@ class ConstantConstructorEquivalence |
} |
} |
-/// Check that the values [property] of [object1] and [object2], [value1] and |
-/// [value2] respectively, are equal and throw otherwise. |
-bool check(var object1, var object2, String property, var value1, value2) { |
- if (value1 != value2) { |
- throw "$object1.$property = '${value1}' <> " |
- "$object2.$property = '${value2}'"; |
- } |
- return true; |
+/// Check the equivalence of the two lists of elements, [list1] and [list2]. |
+/// |
+/// Uses [object1], [object2] and [property] to provide context for failures. |
+checkElementLists(Object object1, Object object2, String property, |
+ Iterable<Element> list1, Iterable<Element> list2) { |
+ checkListEquivalence(object1, object2, property, |
+ list1, list2, checkElementProperties); |
} |
/// Visitor that checks for equivalence of [Element] properties. |