| 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.
|
|
|