| Index: pkg/analyzer/test/generated/non_error_resolver_test.dart
|
| diff --git a/pkg/analyzer/test/generated/non_error_resolver_test.dart b/pkg/analyzer/test/generated/non_error_resolver_test.dart
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..58ad1c6ca8ef7b08705beecfa1943ab51e5ae8d2
|
| --- /dev/null
|
| +++ b/pkg/analyzer/test/generated/non_error_resolver_test.dart
|
| @@ -0,0 +1,4269 @@
|
| +// Copyright (c) 2014, 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.
|
| +
|
| +library engine.non_error_resolver_test;
|
| +
|
| +import 'package:analyzer/src/generated/source_io.dart';
|
| +import 'package:analyzer/src/generated/error.dart';
|
| +import 'package:analyzer/src/generated/ast.dart';
|
| +import 'package:analyzer/src/generated/parser.dart' show ParserErrorCode;
|
| +import 'package:analyzer/src/generated/element.dart';
|
| +import 'package:analyzer/src/generated/engine.dart';
|
| +import 'package:unittest/unittest.dart' as _ut;
|
| +import 'resolver_test.dart';
|
| +import 'test_support.dart';
|
| +import '../reflective_tests.dart';
|
| +
|
| +
|
| +class NonErrorResolverTest extends ResolverTestCase {
|
| + void fail_undefinedEnumConstant() {
|
| + Source source = addSource(EngineTestCase.createSource(["enum E { ONE }", "E e() {", " return E.ONE;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_ambiguousExport() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "export 'lib1.dart';",
|
| + "export 'lib2.dart';"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource(["library lib1;", "class M {}"]));
|
| + addNamedSource("/lib2.dart", EngineTestCase.createSource(["library lib2;", "class N {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_ambiguousExport_combinators_hide() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "export 'lib1.dart';",
|
| + "export 'lib2.dart' hide B;"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource(["library L1;", "class A {}", "class B {}"]));
|
| + addNamedSource("/lib2.dart", EngineTestCase.createSource(["library L2;", "class B {}", "class C {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_ambiguousExport_combinators_show() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "export 'lib1.dart';",
|
| + "export 'lib2.dart' show C;"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource(["library L1;", "class A {}", "class B {}"]));
|
| + addNamedSource("/lib2.dart", EngineTestCase.createSource(["library L2;", "class B {}", "class C {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_ambiguousExport_sameDeclaration() {
|
| + Source source = addSource(EngineTestCase.createSource(["library L;", "export 'lib.dart';", "export 'lib.dart';"]));
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource(["library lib;", "class N {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_ambiguousImport_hideCombinator() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "import 'lib1.dart';",
|
| + "import 'lib2.dart';",
|
| + "import 'lib3.dart' hide N;",
|
| + "main() {",
|
| + " new N1();",
|
| + " new N2();",
|
| + " new N3();",
|
| + "}"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource(["library lib1;", "class N {}", "class N1 {}"]));
|
| + addNamedSource("/lib2.dart", EngineTestCase.createSource(["library lib2;", "class N {}", "class N2 {}"]));
|
| + addNamedSource("/lib3.dart", EngineTestCase.createSource(["library lib3;", "class N {}", "class N3 {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_ambiguousImport_showCombinator() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "import 'lib1.dart';",
|
| + "import 'lib2.dart' show N, N2;",
|
| + "main() {",
|
| + " new N1();",
|
| + " new N2();",
|
| + "}"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource(["library lib1;", "class N {}", "class N1 {}"]));
|
| + addNamedSource("/lib2.dart", EngineTestCase.createSource(["library lib2;", "class N {}", "class N2 {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_argumentTypeNotAssignable_classWithCall_Function() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + " caller(Function callee) {",
|
| + " callee();",
|
| + " }",
|
| + "",
|
| + " class CallMeBack {",
|
| + " call() => 0;",
|
| + " }",
|
| + "",
|
| + " main() {",
|
| + " caller(new CallMeBack());",
|
| + " }"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_argumentTypeNotAssignable_fieldFormalParameterElement_member() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class ObjectSink<T> {",
|
| + " void sink(T object) {",
|
| + " new TimestampedObject<T>(object);",
|
| + " }",
|
| + "}",
|
| + "class TimestampedObject<E> {",
|
| + " E object2;",
|
| + " TimestampedObject(this.object2);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_argumentTypeNotAssignable_invocation_functionParameter_generic() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A<K> {",
|
| + " m(f(K k), K v) {",
|
| + " f(v);",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_argumentTypeNotAssignable_invocation_typedef_generic() {
|
| + Source source = addSource(EngineTestCase.createSource(["typedef A<T>(T p);", "f(A<int> a) {", " a(1);", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_argumentTypeNotAssignable_Object_Function() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "main() {",
|
| + " process(() {});",
|
| + "}",
|
| + "process(Object x) {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_argumentTypeNotAssignable_typedef_local() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "typedef A(int p1, String p2);",
|
| + "A getA() => null;",
|
| + "f() {",
|
| + " A a = getA();",
|
| + " a(1, '2');",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_argumentTypeNotAssignable_typedef_parameter() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "typedef A(int p1, String p2);",
|
| + "f(A a) {",
|
| + " a(1, '2');",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_assignmentToFinal_prefixNegate() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " final x = 0;", " -x;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_assignmentToFinalNoSetter_prefixedIdentifier() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " int get x => 0;",
|
| + " set x(v) {}",
|
| + "}",
|
| + "main() {",
|
| + " A a = new A();",
|
| + " a.x = 0;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_assignmentToFinalNoSetter_propertyAccess() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " int get x => 0;",
|
| + " set x(v) {}",
|
| + "}",
|
| + "class B {",
|
| + " static A a;",
|
| + "}",
|
| + "main() {",
|
| + " B.a.x = 0;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_assignmentToFinals_importWithPrefix() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library lib;",
|
| + "import 'lib1.dart' as foo;",
|
| + "main() {",
|
| + " foo.x = true;",
|
| + "}"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource(["library lib1;", "bool x = false;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_asyncForInWrongContext_async() {
|
| + resetWithAsync();
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(list) async {",
|
| + " await for (var e in list) {",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_asyncForInWrongContext_asyncStar() {
|
| + resetWithAsync();
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(list) async* {",
|
| + " await for (var e in list) {",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_awaitInWrongContext_async() {
|
| + resetWithAsync();
|
| + Source source = addSource(EngineTestCase.createSource(["f(x, y) async {", " return await x + await y;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_awaitInWrongContext_asyncStar() {
|
| + resetWithAsync();
|
| + Source source = addSource(EngineTestCase.createSource(["f(x, y) async* {", " yield await x + await y;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_breakWithoutLabelInSwitch() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " void m(int i) {",
|
| + " switch (i) {",
|
| + " case 0:",
|
| + " break;",
|
| + " }",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_builtInIdentifierAsType_dynamic() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " dynamic x;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_caseBlockNotTerminated() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(int p) {",
|
| + " for (int i = 0; i < 10; i++) {",
|
| + " switch (p) {",
|
| + " case 0:",
|
| + " break;",
|
| + " case 1:",
|
| + " continue;",
|
| + " case 2:",
|
| + " return;",
|
| + " case 3:",
|
| + " throw new Object();",
|
| + " case 4:",
|
| + " case 5:",
|
| + " return;",
|
| + " case 6:",
|
| + " default:",
|
| + " return;",
|
| + " }",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_caseBlockNotTerminated_lastCase() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(int p) {",
|
| + " switch (p) {",
|
| + " case 0:",
|
| + " p = p + 1;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_caseExpressionTypeImplementsEquals() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "print(p) {}",
|
| + "",
|
| + "abstract class B {",
|
| + " final id;",
|
| + " const B(this.id);",
|
| + " String toString() => 'C(\$id)';",
|
| + " /** Equality is identity equality, the id isn't used. */",
|
| + " bool operator==(Object other);",
|
| + " }",
|
| + "",
|
| + "class C extends B {",
|
| + " const C(id) : super(id);",
|
| + "}",
|
| + "",
|
| + "void doSwitch(c) {",
|
| + " switch (c) {",
|
| + " case const C(0): print('Switch: 0'); break;",
|
| + " case const C(1): print('Switch: 1'); break;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_caseExpressionTypeImplementsEquals_int() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(int i) {",
|
| + " switch(i) {",
|
| + " case(1) : return 1;",
|
| + " default: return 0;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_caseExpressionTypeImplementsEquals_Object() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class IntWrapper {",
|
| + " final int value;",
|
| + " const IntWrapper(this.value);",
|
| + "}",
|
| + "",
|
| + "f(IntWrapper intWrapper) {",
|
| + " switch(intWrapper) {",
|
| + " case(const IntWrapper(1)) : return 1;",
|
| + " default: return 0;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_caseExpressionTypeImplementsEquals_String() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(String s) {",
|
| + " switch(s) {",
|
| + " case('1') : return 1;",
|
| + " default: return 0;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_commentReference_beforeConstructor() {
|
| + String code = EngineTestCase.createSource(["abstract class A {", " /// [p]", " A(int p) {}", "}"]);
|
| + Source source = addSource(code);
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + CompilationUnit unit = analysisContext.parseCompilationUnit(source);
|
| + {
|
| + SimpleIdentifier ref = EngineTestCase.findNode(unit, code, "p]", (node) => node is SimpleIdentifier);
|
| + EngineTestCase.assertInstanceOf((obj) => obj is ParameterElement, ParameterElement, ref.staticElement);
|
| + }
|
| + }
|
| +
|
| + void test_commentReference_beforeFunction_blockBody() {
|
| + String code = EngineTestCase.createSource(["/// [p]", "foo(int p) {", "}"]);
|
| + Source source = addSource(code);
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + CompilationUnit unit = analysisContext.parseCompilationUnit(source);
|
| + SimpleIdentifier ref = EngineTestCase.findNode(unit, code, "p]", (node) => node is SimpleIdentifier);
|
| + EngineTestCase.assertInstanceOf((obj) => obj is ParameterElement, ParameterElement, ref.staticElement);
|
| + }
|
| +
|
| + void test_commentReference_beforeFunction_expressionBody() {
|
| + String code = EngineTestCase.createSource(["/// [p]", "foo(int p) => null;"]);
|
| + Source source = addSource(code);
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + CompilationUnit unit = analysisContext.parseCompilationUnit(source);
|
| + SimpleIdentifier ref = EngineTestCase.findNode(unit, code, "p]", (node) => node is SimpleIdentifier);
|
| + EngineTestCase.assertInstanceOf((obj) => obj is ParameterElement, ParameterElement, ref.staticElement);
|
| + }
|
| +
|
| + void test_commentReference_beforeMethod() {
|
| + String code = EngineTestCase.createSource([
|
| + "abstract class A {",
|
| + " /// [p1]",
|
| + " ma(int p1) {}",
|
| + " /// [p2]",
|
| + " mb(int p2);",
|
| + "}"]);
|
| + Source source = addSource(code);
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + CompilationUnit unit = analysisContext.parseCompilationUnit(source);
|
| + {
|
| + SimpleIdentifier ref = EngineTestCase.findNode(unit, code, "p1]", (node) => node is SimpleIdentifier);
|
| + EngineTestCase.assertInstanceOf((obj) => obj is ParameterElement, ParameterElement, ref.staticElement);
|
| + }
|
| + {
|
| + SimpleIdentifier ref = EngineTestCase.findNode(unit, code, "p2]", (node) => node is SimpleIdentifier);
|
| + EngineTestCase.assertInstanceOf((obj) => obj is ParameterElement, ParameterElement, ref.staticElement);
|
| + }
|
| + }
|
| +
|
| + void test_commentReference_class() {
|
| + String code = EngineTestCase.createSource(["/// [foo]", "class A {", " foo() {}", "}"]);
|
| + Source source = addSource(code);
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + CompilationUnit unit = analysisContext.parseCompilationUnit(source);
|
| + SimpleIdentifier ref = EngineTestCase.findNode(unit, code, "foo]", (node) => node is SimpleIdentifier);
|
| + EngineTestCase.assertInstanceOf((obj) => obj is MethodElement, MethodElement, ref.staticElement);
|
| + }
|
| +
|
| + void test_commentReference_setter() {
|
| + String code = EngineTestCase.createSource([
|
| + "class A {",
|
| + " /// [x] in A",
|
| + " mA() {}",
|
| + " set x(value) {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " /// [x] in B",
|
| + " mB() {}",
|
| + "}",
|
| + ""]);
|
| + Source source = addSource(code);
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + CompilationUnit unit = analysisContext.parseCompilationUnit(source);
|
| + {
|
| + SimpleIdentifier ref = EngineTestCase.findNode(unit, code, "x] in A", (node) => node is SimpleIdentifier);
|
| + EngineTestCase.assertInstanceOf((obj) => obj is PropertyAccessorElement, PropertyAccessorElement, ref.staticElement);
|
| + }
|
| + {
|
| + SimpleIdentifier ref = EngineTestCase.findNode(unit, code, "x] in B", (node) => node is SimpleIdentifier);
|
| + EngineTestCase.assertInstanceOf((obj) => obj is PropertyAccessorElement, PropertyAccessorElement, ref.staticElement);
|
| + }
|
| + }
|
| +
|
| + void test_concreteClassWithAbstractMember() {
|
| + Source source = addSource(EngineTestCase.createSource(["abstract class A {", " m();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_concreteClassWithAbstractMember_inherited() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m() {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " m();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_conflictingInstanceGetterAndSuperclassMember_instance() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " get v => 0;",
|
| + "}",
|
| + "class B extends A {",
|
| + " get v => 1;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_conflictingStaticGetterAndInstanceSetter_thisClass() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " static get x => 0;",
|
| + " static set x(int p) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_conflictingStaticSetterAndInstanceMember_thisClass_method() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " static x() {}",
|
| + " static set x(int p) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constConstructorWithNonConstSuper_explicit() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A();",
|
| + "}",
|
| + "class B extends A {",
|
| + " const B(): super();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constConstructorWithNonConstSuper_redirectingFactory() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A();",
|
| + "}",
|
| + "class B implements C {",
|
| + " const B();",
|
| + "}",
|
| + "class C extends A {",
|
| + " const factory C() = B;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constConstructorWithNonConstSuper_unresolved() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A.a();",
|
| + "}",
|
| + "class B extends A {",
|
| + " const B(): super();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertErrors(source, [CompileTimeErrorCode.UNDEFINED_CONSTRUCTOR_IN_INITIALIZER_DEFAULT]);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constConstructorWithNonFinalField_finalInstanceVar() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " final int x = 0;", " const A();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constConstructorWithNonFinalField_mixin() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " a() {}",
|
| + "}",
|
| + "class B extends Object with A {",
|
| + " const B();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertErrors(source, [CompileTimeErrorCode.CONST_CONSTRUCTOR_WITH_MIXIN]);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constConstructorWithNonFinalField_static() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " static int x;", " const A();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constConstructorWithNonFinalField_syntheticField() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A();",
|
| + " set x(value) {}",
|
| + " get x {return 0;}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constDeferredClass_new() {
|
| + resolveWithAndWithoutExperimental(<String> [
|
| + EngineTestCase.createSource(["library lib1;", "class A {", " const A.b();", "}"]),
|
| + EngineTestCase.createSource([
|
| + "library root;",
|
| + "import 'lib1.dart' deferred as a;",
|
| + "main() {",
|
| + " new a.A.b();",
|
| + "}"])], <ErrorCode> [ParserErrorCode.DEFERRED_IMPORTS_NOT_SUPPORTED], <ErrorCode> []);
|
| + }
|
| +
|
| + void test_constEval_functionTypeLiteral() {
|
| + Source source = addSource(EngineTestCase.createSource(["typedef F();", "const C = F;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constEval_propertyExtraction_fieldStatic_targetType() {
|
| + addNamedSource("/math.dart", EngineTestCase.createSource(["library math;", "const PI = 3.14;"]));
|
| + Source source = addSource(EngineTestCase.createSource(["import 'math.dart' as math;", "const C = math.PI;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constEval_propertyExtraction_methodStatic_targetType() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A();",
|
| + " static m() {}",
|
| + "}",
|
| + "const C = A.m;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constEval_symbol() {
|
| + addNamedSource("/math.dart", EngineTestCase.createSource(["library math;", "const PI = 3.14;"]));
|
| + Source source = addSource(EngineTestCase.createSource(["const C = #foo;", "foo() {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constEvalTypeBoolNumString_equal() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A();",
|
| + "}",
|
| + "class B {",
|
| + " final v;",
|
| + " const B.a1(bool p) : v = p == true;",
|
| + " const B.a2(bool p) : v = p == false;",
|
| + " const B.a3(bool p) : v = p == 0;",
|
| + " const B.a4(bool p) : v = p == 0.0;",
|
| + " const B.a5(bool p) : v = p == '';",
|
| + " const B.b1(int p) : v = p == true;",
|
| + " const B.b2(int p) : v = p == false;",
|
| + " const B.b3(int p) : v = p == 0;",
|
| + " const B.b4(int p) : v = p == 0.0;",
|
| + " const B.b5(int p) : v = p == '';",
|
| + " const B.c1(String p) : v = p == true;",
|
| + " const B.c2(String p) : v = p == false;",
|
| + " const B.c3(String p) : v = p == 0;",
|
| + " const B.c4(String p) : v = p == 0.0;",
|
| + " const B.c5(String p) : v = p == '';",
|
| + " const B.n1(num p) : v = p == null;",
|
| + " const B.n2(num p) : v = null == p;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_constEvalTypeBoolNumString_notEqual() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A();",
|
| + "}",
|
| + "class B {",
|
| + " final v;",
|
| + " const B.a1(bool p) : v = p != true;",
|
| + " const B.a2(bool p) : v = p != false;",
|
| + " const B.a3(bool p) : v = p != 0;",
|
| + " const B.a4(bool p) : v = p != 0.0;",
|
| + " const B.a5(bool p) : v = p != '';",
|
| + " const B.b1(int p) : v = p != true;",
|
| + " const B.b2(int p) : v = p != false;",
|
| + " const B.b3(int p) : v = p != 0;",
|
| + " const B.b4(int p) : v = p != 0.0;",
|
| + " const B.b5(int p) : v = p != '';",
|
| + " const B.c1(String p) : v = p != true;",
|
| + " const B.c2(String p) : v = p != false;",
|
| + " const B.c3(String p) : v = p != 0;",
|
| + " const B.c4(String p) : v = p != 0.0;",
|
| + " const B.c5(String p) : v = p != '';",
|
| + " const B.n1(num p) : v = p != null;",
|
| + " const B.n2(num p) : v = null != p;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constMapKeyExpressionTypeImplementsEquals_abstract() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class B {",
|
| + " final id;",
|
| + " const B(this.id);",
|
| + " String toString() => 'C(\$id)';",
|
| + " /** Equality is identity equality, the id isn't used. */",
|
| + " bool operator==(Object other);",
|
| + " }",
|
| + "",
|
| + "class C extends B {",
|
| + " const C(id) : super(id);",
|
| + "}",
|
| + "",
|
| + "Map getMap() {",
|
| + " return const { const C(0): 'Map: 0' };",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constNotInitialized_field() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " static const int x = 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constNotInitialized_local() {
|
| + Source source = addSource(EngineTestCase.createSource(["main() {", " const int x = 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constructorDeclaration_scope_signature() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "const app = 0;",
|
| + "class A {",
|
| + " A(@app int app) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constWithNonConstantArgument_literals() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A(a, b, c, d);",
|
| + "}",
|
| + "f() { return const A(true, 0, 1.0, '2'); }"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constWithTypeParameters_direct() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A<T> {",
|
| + " static const V = const A<int>();",
|
| + " const A();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constWithUndefinedConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A.name();",
|
| + "}",
|
| + "f() {",
|
| + " return const A.name();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_constWithUndefinedConstructorDefault() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A();",
|
| + "}",
|
| + "f() {",
|
| + " return const A();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_defaultValueInFunctionTypeAlias() {
|
| + Source source = addSource(EngineTestCase.createSource(["typedef F([x]);"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_defaultValueInFunctionTypedParameter_named() {
|
| + Source source = addSource(EngineTestCase.createSource(["f(g({p})) {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_defaultValueInFunctionTypedParameter_optional() {
|
| + Source source = addSource(EngineTestCase.createSource(["f(g([p])) {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_deprecatedMemberUse_hide() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library lib;",
|
| + "import 'lib1.dart' hide B;",
|
| + "A a = new A();"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource([
|
| + "library lib1;",
|
| + "class A {}",
|
| + "@deprecated",
|
| + "class B {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_duplicateDefinition_emptyName() {
|
| + // Note: This code has two FunctionElements '() {}' with an empty name, this tests that the
|
| + // empty string is not put into the scope (more than once).
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "Map _globalMap = {",
|
| + " 'a' : () {},",
|
| + " 'b' : () {}",
|
| + "};"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_duplicateDefinition_getter() {
|
| + Source source = addSource(EngineTestCase.createSource(["bool get a => true;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_dynamicIdentifier() {
|
| + Source source = addSource(EngineTestCase.createSource(["main() {", " var v = dynamic;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_expectedOneListTypeArgument() {
|
| + Source source = addSource(EngineTestCase.createSource(["main() {", " <int> [];", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_expectedTwoMapTypeArguments() {
|
| + Source source = addSource(EngineTestCase.createSource(["main() {", " <int, int> {};", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_exportOfNonLibrary_libraryDeclared() {
|
| + Source source = addSource(EngineTestCase.createSource(["library L;", "export 'lib1.dart';"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource(["library lib1;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_exportOfNonLibrary_libraryNotDeclared() {
|
| + Source source = addSource(EngineTestCase.createSource(["library L;", "export 'lib1.dart';"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource([""]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_extraPositionalArguments_function() {
|
| + Source source = addSource(EngineTestCase.createSource(["f(p1, p2) {}", "main() {", " f(1, 2);", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_extraPositionalArguments_Function() {
|
| + Source source = addSource(EngineTestCase.createSource(["f(Function a) {", " a(1, 2);", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_extraPositionalArguments_implicitConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A<E extends num> {",
|
| + " A(E x, E y);",
|
| + "}",
|
| + "class M {}",
|
| + "class B<E extends num> = A<E> with M;",
|
| + "void main() {",
|
| + " B<int> x = new B<int>(0,0);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_extraPositionalArguments_typedef_local() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "typedef A(p1, p2);",
|
| + "A getA() => null;",
|
| + "f() {",
|
| + " A a = getA();",
|
| + " a(1, 2);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_extraPositionalArguments_typedef_parameter() {
|
| + Source source = addSource(EngineTestCase.createSource(["typedef A(p1, p2);", "f(A a) {", " a(1, 2);", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_fieldInitializedByMultipleInitializers() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " int x;",
|
| + " int y;",
|
| + " A() : x = 0, y = 0 {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_fieldInitializedInInitializerAndDeclaration_fieldNotFinal() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " int x = 0;", " A() : x = 1 {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_fieldInitializedInInitializerAndDeclaration_finalFieldNotSet() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " final int x;", " A() : x = 1 {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_fieldInitializerOutsideConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " int x;", " A(this.x) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_fieldInitializerOutsideConstructor_defaultParameters() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " int x;", " A([this.x]) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_fieldInitializerRedirectingConstructor_super() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A() {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " int x;",
|
| + " B(this.x) : super();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_finalInitializedInDeclarationAndConstructor_initializer() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " final x;", " A() : x = 1 {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_finalInitializedInDeclarationAndConstructor_initializingFormal() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " final x;", " A(this.x) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_finalNotInitialized_atDeclaration() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " final int x = 0;", " A() {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_finalNotInitialized_fieldFormal() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " final int x = 0;", " A() {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_finalNotInitialized_functionTypedFieldFormal() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " final Function x;",
|
| + " A(int this.x(int p)) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_finalNotInitialized_hasNativeClause_hasConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A native 'something' {",
|
| + " final int x;",
|
| + " A() {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertErrors(source, [ParserErrorCode.NATIVE_CLAUSE_IN_NON_SDK_CODE]);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_finalNotInitialized_hasNativeClause_noConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A native 'something' {", " final int x;", "}"]));
|
| + resolve(source);
|
| + assertErrors(source, [ParserErrorCode.NATIVE_CLAUSE_IN_NON_SDK_CODE]);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_finalNotInitialized_initializer() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " final int x;", " A() : x = 0 {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_finalNotInitialized_redirectingConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " final int x;",
|
| + " A(this.x);",
|
| + " A.named() : this (42);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_functionDeclaration_scope_returnType() {
|
| + Source source = addSource(EngineTestCase.createSource(["int f(int) { return 0; }"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_functionDeclaration_scope_signature() {
|
| + Source source = addSource(EngineTestCase.createSource(["const app = 0;", "f(@app int app) {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_functionTypeAlias_scope_returnType() {
|
| + Source source = addSource(EngineTestCase.createSource(["typedef int f(int);"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_functionTypeAlias_scope_signature() {
|
| + Source source = addSource(EngineTestCase.createSource(["const app = 0;", "typedef int f(@app int app);"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_functionWithoutCall() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class A implements Function {",
|
| + "}",
|
| + "class B implements A {",
|
| + " void call() {}",
|
| + "}",
|
| + "class C extends A {",
|
| + " void call() {}",
|
| + "}",
|
| + "class D extends C {",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_functionWithoutCall_doesNotImplementFunction() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_functionWithoutCall_withNoSuchMethod() {
|
| + // 16078
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A implements Function {",
|
| + " noSuchMethod(inv) {",
|
| + " return 42;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_constructorName() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A.named() {}",
|
| + "}",
|
| + "class B {",
|
| + " var v;",
|
| + " B() : v = new A.named();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_importPrefix() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "import 'dart:async' as abstract;",
|
| + "class A {",
|
| + " var v = new abstract.Completer();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_prefixedIdentifier() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var f;",
|
| + "}",
|
| + "class B {",
|
| + " var v;",
|
| + " B(A a) : v = a.f;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_qualifiedMethodInvocation() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " f() {}",
|
| + "}",
|
| + "class B {",
|
| + " var v;",
|
| + " B() : v = new A().f();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_qualifiedPropertyAccess() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var f;",
|
| + "}",
|
| + "class B {",
|
| + " var v;",
|
| + " B() : v = new A().f;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_staticField_thisClass() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var v;",
|
| + " A() : v = f;",
|
| + " static var f;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_staticGetter() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var v;",
|
| + " A() : v = f;",
|
| + " static get f => 42;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_staticMethod() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var v;",
|
| + " A() : v = f();",
|
| + " static f() => 42;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_topLevelField() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var v;",
|
| + " A() : v = f;",
|
| + "}",
|
| + "var f = 42;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_topLevelFunction() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var v;",
|
| + " A() : v = f();",
|
| + "}",
|
| + "f() => 42;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_topLevelGetter() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var v;",
|
| + " A() : v = f;",
|
| + "}",
|
| + "get f => 42;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_implicitThisReferenceInInitializer_typeParameter() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A<T> {", " var v;", " A(p) : v = (p is T);", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_importDuplicatedLibraryName() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library test;",
|
| + "import 'lib.dart';",
|
| + "import 'lib.dart';"]));
|
| + addNamedSource("/lib.dart", "library lib;");
|
| + resolve(source);
|
| + assertErrors(source, [
|
| + HintCode.UNUSED_IMPORT,
|
| + HintCode.UNUSED_IMPORT,
|
| + HintCode.DUPLICATE_IMPORT]);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_importOfNonLibrary_libraryDeclared() {
|
| + Source source = addSource(EngineTestCase.createSource(["library lib;", "import 'part.dart';", "A a;"]));
|
| + addNamedSource("/part.dart", EngineTestCase.createSource(["library lib1;", "class A {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_importOfNonLibrary_libraryNotDeclared() {
|
| + Source source = addSource(EngineTestCase.createSource(["library lib;", "import 'part.dart';", "A a;"]));
|
| + addNamedSource("/part.dart", EngineTestCase.createSource(["class A {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_importPrefixes_withFirstLetterDifference() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "import 'lib1.dart' as math;",
|
| + "import 'lib2.dart' as path;",
|
| + "main() {",
|
| + " math.test1();",
|
| + " path.test2();",
|
| + "}"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource(["library lib1;", "test1() {}"]));
|
| + addNamedSource("/lib2.dart", EngineTestCase.createSource(["library lib2;", "test2() {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_inconsistentCaseExpressionTypes() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(var p) {",
|
| + " switch (p) {",
|
| + " case 1:",
|
| + " break;",
|
| + " case 2:",
|
| + " break;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_inconsistentMethodInheritance_accessors_typeParameter2() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class A<E> {",
|
| + " E get x {return null;}",
|
| + "}",
|
| + "class B<E> {",
|
| + " E get x {return null;}",
|
| + "}",
|
| + "class C<E> extends A<E> implements B<E> {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_inconsistentMethodInheritance_accessors_typeParameters_diamond() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class F<E> extends B<E> {}",
|
| + "class D<E> extends F<E> {",
|
| + " external E get g;",
|
| + "}",
|
| + "abstract class C<E> {",
|
| + " E get g;",
|
| + "}",
|
| + "abstract class B<E> implements C<E> {",
|
| + " E get g { return null; }",
|
| + "}",
|
| + "class A<E> extends B<E> implements D<E> {",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_inconsistentMethodInheritance_accessors_typeParameters1() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class A<E> {",
|
| + " E get x;",
|
| + "}",
|
| + "abstract class B<E> {",
|
| + " E get x;",
|
| + "}",
|
| + "class C<E> implements A<E>, B<E> {",
|
| + " E get x => null;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_inconsistentMethodInheritance_methods_typeParameter2() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A<E> {",
|
| + " x(E e) {}",
|
| + "}",
|
| + "class B<E> {",
|
| + " x(E e) {}",
|
| + "}",
|
| + "class C<E> extends A<E> implements B<E> {",
|
| + " x(E e) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_inconsistentMethodInheritance_methods_typeParameters1() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A<E> {",
|
| + " x(E e) {}",
|
| + "}",
|
| + "class B<E> {",
|
| + " x(E e) {}",
|
| + "}",
|
| + "class C<E> implements A<E>, B<E> {",
|
| + " x(E e) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_inconsistentMethodInheritance_overrideTrumpsInherits_getter() {
|
| + // 16134
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class B<S> {",
|
| + " S get g => null;",
|
| + "}",
|
| + "abstract class I<U> {",
|
| + " U get g => null;",
|
| + "}",
|
| + "class C extends B<double> implements I<int> {",
|
| + " num get g => null;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_inconsistentMethodInheritance_overrideTrumpsInherits_method() {
|
| + // 16134
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class B<S> {",
|
| + " m(S s) => null;",
|
| + "}",
|
| + "abstract class I<U> {",
|
| + " m(U u) => null;",
|
| + "}",
|
| + "class C extends B<double> implements I<int> {",
|
| + " m(num n) => null;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_inconsistentMethodInheritance_overrideTrumpsInherits_setter() {
|
| + // 16134
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class B<S> {",
|
| + " set t(S s) {}",
|
| + "}",
|
| + "abstract class I<U> {",
|
| + " set t(U u) {}",
|
| + "}",
|
| + "class C extends B<double> implements I<int> {",
|
| + " set t(num n) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_inconsistentMethodInheritance_simple() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class A {",
|
| + " x();",
|
| + "}",
|
| + "abstract class B {",
|
| + " x();",
|
| + "}",
|
| + "class C implements A, B {",
|
| + " x() {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_initializingFormalForNonExistentField() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " int x;", " A(this.x) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_instanceAccessToStaticMember_fromComment() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " static m() {}",
|
| + "}",
|
| + "/// [A.m]",
|
| + "main() {",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_instanceAccessToStaticMember_topLevel() {
|
| + Source source = addSource(EngineTestCase.createSource(["m() {}", "main() {", " m();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_instanceMemberAccessFromStatic_fromComment() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m() {}",
|
| + " /// [m]",
|
| + " static foo() {",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_instanceMethodNameCollidesWithSuperclassStatic_field() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "import 'lib.dart';",
|
| + "class B extends A {",
|
| + " _m() {}",
|
| + "}"]));
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource(["library L;", "class A {", " static var _m;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_instanceMethodNameCollidesWithSuperclassStatic_method() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "import 'lib.dart';",
|
| + "class B extends A {",
|
| + " _m() {}",
|
| + "}"]));
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource(["library L;", "class A {", " static _m() {}", "}"]));
|
| + resolve(source);
|
| + assertErrors(source, []);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAnnotation_constantVariable_field() {
|
| + Source source = addSource(EngineTestCase.createSource(["@A.C", "class A {", " static const C = 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAnnotation_constantVariable_field_importWithPrefix() {
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource(["library lib;", "class A {", " static const C = 0;", "}"]));
|
| + Source source = addSource(EngineTestCase.createSource(["import 'lib.dart' as p;", "@p.A.C", "main() {", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAnnotation_constantVariable_topLevel() {
|
| + Source source = addSource(EngineTestCase.createSource(["const C = 0;", "@C", "main() {", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAnnotation_constantVariable_topLevel_importWithPrefix() {
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource(["library lib;", "const C = 0;"]));
|
| + Source source = addSource(EngineTestCase.createSource(["import 'lib.dart' as p;", "@p.C", "main() {", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAnnotation_constConstructor_importWithPrefix() {
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource(["library lib;", "class A {", " const A(int p);", "}"]));
|
| + Source source = addSource(EngineTestCase.createSource(["import 'lib.dart' as p;", "@p.A(42)", "main() {", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAnnotation_constConstructor_named_importWithPrefix() {
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource([
|
| + "library lib;",
|
| + "class A {",
|
| + " const A.named(int p);",
|
| + "}"]));
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "import 'lib.dart' as p;",
|
| + "@p.A.named(42)",
|
| + "main() {",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAssignment() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " var x;", " var y;", " x = y;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAssignment_compoundAssignment() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class byte {",
|
| + " int _value;",
|
| + " byte(this._value);",
|
| + " byte operator +(int val) { return this; }",
|
| + "}",
|
| + "",
|
| + "void main() {",
|
| + " byte b = new byte(52);",
|
| + " b += 3;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAssignment_defaultValue_named() {
|
| + Source source = addSource(EngineTestCase.createSource(["f({String x: '0'}) {", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAssignment_defaultValue_optional() {
|
| + Source source = addSource(EngineTestCase.createSource(["f([String x = '0']) {", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAssignment_implicitlyImplementFunctionViaCall_1() {
|
| + // 18341
|
| + //
|
| + // This test and 'test_invalidAssignment_implicitlyImplementFunctionViaCall_2()'
|
| + // are closely related: here we see that 'I' checks as a subtype of 'IntToInt'.
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class I {",
|
| + " int call(int x) => 0;",
|
| + "}",
|
| + "class C implements I {",
|
| + " noSuchMethod(_) => null;",
|
| + "}",
|
| + "typedef int IntToInt(int x);",
|
| + "IntToInt f = new I();"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAssignment_implicitlyImplementFunctionViaCall_2() {
|
| + // 18341
|
| + //
|
| + // Here 'C' checks as a subtype of 'I', but 'C' does not
|
| + // check as a subtype of 'IntToInt'. Together with
|
| + // 'test_invalidAssignment_implicitlyImplementFunctionViaCall_1()' we see
|
| + // that subtyping is not transitive here.
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class I {",
|
| + " int call(int x) => 0;",
|
| + "}",
|
| + "class C implements I {",
|
| + " noSuchMethod(_) => null;",
|
| + "}",
|
| + "typedef int IntToInt(int x);",
|
| + "IntToInt f = new C();"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAssignment_implicitlyImplementFunctionViaCall_3() {
|
| + // 18341
|
| + //
|
| + // Like 'test_invalidAssignment_implicitlyImplementFunctionViaCall_2()',
|
| + // but uses type 'Function' instead of more precise type 'IntToInt' for 'f'.
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class I {",
|
| + " int call(int x) => 0;",
|
| + "}",
|
| + "class C implements I {",
|
| + " noSuchMethod(_) => null;",
|
| + "}",
|
| + "typedef int IntToInt(int x);",
|
| + "Function f = new C();"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAssignment_implicitlyImplementFunctionViaCall_4() {
|
| + // 18341
|
| + //
|
| + // Like 'test_invalidAssignment_implicitlyImplementFunctionViaCall_2()',
|
| + // but uses type 'VoidToInt' instead of more precise type 'IntToInt' for 'f'.
|
| + //
|
| + // Here 'C <: IntToInt <: VoidToInt', but the spec gives no transitivity rule
|
| + // for '<:'. However, many of the :/tools/test.py tests assume this transitivity
|
| + // for 'JsBuilder' objects, assigning them to '(String) -> dynamic'. The declared type of
|
| + // 'JsBuilder.call' is '(String, [dynamic]) -> Expression'.
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class I {",
|
| + " int call([int x]) => 0;",
|
| + "}",
|
| + "class C implements I {",
|
| + " noSuchMethod(_) => null;",
|
| + "}",
|
| + "typedef int VoidToInt();",
|
| + "VoidToInt f = new C();"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidAssignment_toDynamic() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " var g;", " g = () => 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidFactoryNameNotAClass() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " factory A() {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidIdentifierInAsync() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m() {",
|
| + " int async;",
|
| + " int await;",
|
| + " int yield;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidMethodOverrideNamedParamType() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m({int a}) {}",
|
| + "}",
|
| + "class B implements A {",
|
| + " m({int a, int b}) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideDifferentDefaultValues_named() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m({int p : 0}) {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " m({int p : 0}) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideDifferentDefaultValues_named_function() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "nothing() => 'nothing';",
|
| + "class A {",
|
| + " thing(String a, {orElse : nothing}) {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " thing(String a, {orElse : nothing}) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideDifferentDefaultValues_positional() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m([int p = 0]) {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " m([int p = 0]) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideDifferentDefaultValues_positional_changedOrder() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m([int a = 0, String b = '0']) {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " m([int b = 0, String a = '0']) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideDifferentDefaultValues_positional_function() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "nothing() => 'nothing';",
|
| + "class A {",
|
| + " thing(String a, [orElse = nothing]) {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " thing(String a, [orElse = nothing]) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideNamed_unorderedNamedParameter() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m({a, b}) {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " m({b, a}) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideRequired_less() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m(a, b) {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " m(a, [b]) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideRequired_same() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m(a) {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " m(a) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideReturnType_returnType_interface() {
|
| + Source source = addNamedSource("/test.dart", EngineTestCase.createSource([
|
| + "abstract class A {",
|
| + " num m();",
|
| + "}",
|
| + "class B implements A {",
|
| + " int m() { return 1; }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideReturnType_returnType_interface2() {
|
| + Source source = addNamedSource("/test.dart", EngineTestCase.createSource([
|
| + "abstract class A {",
|
| + " num m();",
|
| + "}",
|
| + "abstract class B implements A {",
|
| + "}",
|
| + "class C implements B {",
|
| + " int m() { return 1; }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideReturnType_returnType_mixin() {
|
| + Source source = addNamedSource("/test.dart", EngineTestCase.createSource([
|
| + "class A {",
|
| + " num m() { return 0; }",
|
| + "}",
|
| + "class B extends Object with A {",
|
| + " int m() { return 1; }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideReturnType_returnType_parameterizedTypes() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class A<E> {",
|
| + " List<E> m();",
|
| + "}",
|
| + "class B extends A<dynamic> {",
|
| + " List<dynamic> m() { return new List<dynamic>(); }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideReturnType_returnType_sameType() {
|
| + Source source = addNamedSource("/test.dart", EngineTestCase.createSource([
|
| + "class A {",
|
| + " int m() { return 0; }",
|
| + "}",
|
| + "class B extends A {",
|
| + " int m() { return 1; }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideReturnType_returnType_superclass() {
|
| + Source source = addNamedSource("/test.dart", EngineTestCase.createSource([
|
| + "class A {",
|
| + " num m() { return 0; }",
|
| + "}",
|
| + "class B extends A {",
|
| + " int m() { return 1; }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideReturnType_returnType_superclass2() {
|
| + Source source = addNamedSource("/test.dart", EngineTestCase.createSource([
|
| + "class A {",
|
| + " num m() { return 0; }",
|
| + "}",
|
| + "class B extends A {",
|
| + "}",
|
| + "class C extends B {",
|
| + " int m() { return 1; }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidOverrideReturnType_returnType_void() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " void m() {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " int m() { return 0; }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidReferenceToThis_constructor() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " A() {", " var v = this;", " }", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidReferenceToThis_instanceMethod() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " m() {", " var v = this;", " }", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidTypeArgumentForKey() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m() {",
|
| + " return const <int, int>{};",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidTypeArgumentInConstList() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A<E> {",
|
| + " m() {",
|
| + " return <E>[];",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invalidTypeArgumentInConstMap() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A<E> {",
|
| + " m() {",
|
| + " return <String, E>{};",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invocationOfNonFunction_dynamic() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var f;",
|
| + "}",
|
| + "class B extends A {",
|
| + " g() {",
|
| + " f();",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invocationOfNonFunction_getter() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var g;",
|
| + "}",
|
| + "f() {",
|
| + " A a;",
|
| + " a.g();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invocationOfNonFunction_localVariable() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " var g;", " g();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invocationOfNonFunction_localVariable_dynamic() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {}", "main() {", " var v = f;", " v();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invocationOfNonFunction_localVariable_dynamic2() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f() {}",
|
| + "main() {",
|
| + " var v = f;",
|
| + " v = 1;",
|
| + " v();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invocationOfNonFunction_Object() {
|
| + Source source = addSource(EngineTestCase.createSource(["main() {", " Object v = null;", " v();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_invocationOfNonFunction_proxyOnFunctionClass() {
|
| + // 16078
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "@proxy",
|
| + "class Functor implements Function {",
|
| + " noSuchMethod(inv) {",
|
| + " return 42;",
|
| + " }",
|
| + "}",
|
| + "main() {",
|
| + " Functor f = new Functor();",
|
| + " f();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertErrors(source, []);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_listElementTypeNotAssignable() {
|
| + Source source = addSource(EngineTestCase.createSource(["var v1 = <int> [42];", "var v2 = const <int> [42];"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_loadLibraryDefined() {
|
| + resolveWithAndWithoutExperimental(<String> [
|
| + EngineTestCase.createSource(["library lib1;", "foo() => 22;"]),
|
| + EngineTestCase.createSource([
|
| + "import 'lib1.dart' deferred as other;",
|
| + "main() {",
|
| + " other.loadLibrary().then((_) => other.foo());",
|
| + "}"])], <ErrorCode> [
|
| + ParserErrorCode.DEFERRED_IMPORTS_NOT_SUPPORTED,
|
| + StaticTypeWarningCode.UNDEFINED_FUNCTION], <ErrorCode> []);
|
| + }
|
| +
|
| + void test_mapKeyTypeNotAssignable() {
|
| + Source source = addSource(EngineTestCase.createSource(["var v = <String, int > {'a' : 1};"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_memberWithClassName_setter() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " set A(v) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_methodDeclaration_scope_signature() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "const app = 0;",
|
| + "class A {",
|
| + " foo(@app int app) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_misMatchedGetterAndSetterTypes_instance_sameTypes() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class C {",
|
| + " int get x => 0;",
|
| + " set x(int v) {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_misMatchedGetterAndSetterTypes_instance_unspecifiedGetter() {
|
| + Source source = addSource(EngineTestCase.createSource(["class C {", " get x => 0;", " set x(String v) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_misMatchedGetterAndSetterTypes_instance_unspecifiedSetter() {
|
| + Source source = addSource(EngineTestCase.createSource(["class C {", " int get x => 0;", " set x(v) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_misMatchedGetterAndSetterTypes_topLevel_sameTypes() {
|
| + Source source = addSource(EngineTestCase.createSource(["int get x => 0;", "set x(int v) {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_misMatchedGetterAndSetterTypes_topLevel_unspecifiedGetter() {
|
| + Source source = addSource(EngineTestCase.createSource(["get x => 0;", "set x(String v) {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_misMatchedGetterAndSetterTypes_topLevel_unspecifiedSetter() {
|
| + Source source = addSource(EngineTestCase.createSource(["int get x => 0;", "set x(v) {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_missingEnumConstantInSwitch_all() {
|
| + AnalysisOptionsImpl analysisOptions = new AnalysisOptionsImpl();
|
| + analysisOptions.enableEnum = true;
|
| + resetWithOptions(analysisOptions);
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "enum E { A, B, C }",
|
| + "",
|
| + "f(E e) {",
|
| + " switch (e) {",
|
| + " case E.A: break;",
|
| + " case E.B: break;",
|
| + " case E.C: break;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_missingEnumConstantInSwitch_default() {
|
| + AnalysisOptionsImpl analysisOptions = new AnalysisOptionsImpl();
|
| + analysisOptions.enableEnum = true;
|
| + resetWithOptions(analysisOptions);
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "enum E { A, B, C }",
|
| + "",
|
| + "f(E e) {",
|
| + " switch (e) {",
|
| + " case E.B: break;",
|
| + " default: break;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_mixedReturnTypes_differentScopes() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class C {",
|
| + " m(int x) {",
|
| + " f(int y) {",
|
| + " return;",
|
| + " }",
|
| + " f(x);",
|
| + " return 0;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_mixedReturnTypes_ignoreImplicit() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(bool p) {",
|
| + " if (p) return 42;",
|
| + " // implicit 'return;' is ignored",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_mixedReturnTypes_ignoreImplicit2() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(bool p) {",
|
| + " if (p) {",
|
| + " return 42;",
|
| + " } else {",
|
| + " return 42;",
|
| + " }",
|
| + " // implicit 'return;' is ignored",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_mixedReturnTypes_sameKind() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class C {",
|
| + " m(int x) {",
|
| + " if (x < 0) {",
|
| + " return 1;",
|
| + " }",
|
| + " return 0;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_mixinDeclaresConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m() {}",
|
| + "}",
|
| + "class B extends Object with A {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_mixinDeclaresConstructor_factory() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " factory A() {}",
|
| + "}",
|
| + "class B extends Object with A {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_mixinInheritsFromNotObject_classDeclaration_mixTypeAlias() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {}",
|
| + "class B = Object with A;",
|
| + "class C extends Object with B {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_mixinInheritsFromNotObject_typedef_mixTypeAlias() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {}",
|
| + "class B = Object with A;",
|
| + "class C = Object with B;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_multipleSuperInitializers_no() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {}", "class B extends A {", " B() {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_multipleSuperInitializers_single() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {}",
|
| + "class B extends A {",
|
| + " B() : super() {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nativeFunctionBodyInNonSDKCode_function() {
|
| + Source source = addSource(EngineTestCase.createSource(["import 'dart-ext:x';", "int m(a) native 'string';"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + // Cannot verify the AST because the import's URI cannot be resolved.
|
| + }
|
| +
|
| + void test_newWithAbstractClass_factory() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class A {",
|
| + " factory A() { return new B(); }",
|
| + "}",
|
| + "class B implements A {",
|
| + " B() {}",
|
| + "}",
|
| + "A f() {",
|
| + " return new A();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_newWithUndefinedConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A.name() {}",
|
| + "}",
|
| + "f() {",
|
| + " new A.name();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_newWithUndefinedConstructorDefault() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " A() {}", "}", "f() {", " new A();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_abstractsDontOverrideConcretes_getter() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " int get g => 0;",
|
| + "}",
|
| + "abstract class B extends A {",
|
| + " int get g;",
|
| + "}",
|
| + "class C extends B {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_abstractsDontOverrideConcretes_method() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m(p) {}",
|
| + "}",
|
| + "abstract class B extends A {",
|
| + " m(p);",
|
| + "}",
|
| + "class C extends B {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_abstractsDontOverrideConcretes_setter() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " set s(v) {}",
|
| + "}",
|
| + "abstract class B extends A {",
|
| + " set s(v);",
|
| + "}",
|
| + "class C extends B {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_classTypeAlias_interface() {
|
| + // 15979
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class M {}",
|
| + "abstract class A {}",
|
| + "abstract class I {",
|
| + " m();",
|
| + "}",
|
| + "abstract class B = A with M implements I;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_classTypeAlias_mixin() {
|
| + // 15979
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class M {",
|
| + " m();",
|
| + "}",
|
| + "abstract class A {}",
|
| + "abstract class B = A with M;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_classTypeAlias_superclass() {
|
| + // 15979
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class M {}",
|
| + "abstract class A {",
|
| + " m();",
|
| + "}",
|
| + "abstract class B = A with M;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_mixin_getter() {
|
| + // 17034
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var a;",
|
| + "}",
|
| + "abstract class M {",
|
| + " get a;",
|
| + "}",
|
| + "class B extends A with M {}",
|
| + "class C extends B {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_mixin_method() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m() {}",
|
| + "}",
|
| + "abstract class M {",
|
| + " m();",
|
| + "}",
|
| + "class B extends A with M {}",
|
| + "class C extends B {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_mixin_setter() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var a;",
|
| + "}",
|
| + "abstract class M {",
|
| + " set a(dynamic v);",
|
| + "}",
|
| + "class B extends A with M {}",
|
| + "class C extends B {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_noSuchMethod_accessor() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class A {",
|
| + " int get g;",
|
| + "}",
|
| + "class B extends A {",
|
| + " noSuchMethod(v) => '';",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonAbstractClassInheritsAbstractMemberOne_noSuchMethod_method() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class A {",
|
| + " m(p);",
|
| + "}",
|
| + "class B extends A {",
|
| + " noSuchMethod(v) => '';",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonBoolExpression_functionType() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "bool makeAssertion() => true;",
|
| + "f() {",
|
| + " assert(makeAssertion);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonBoolExpression_interfaceType() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " assert(true);", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonBoolNegationExpression() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(bool pb, pd) {",
|
| + " !true;",
|
| + " !false;",
|
| + " !pb;",
|
| + " !pd;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonBoolOperand_and_bool() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "bool f(bool left, bool right) {",
|
| + " return left && right;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonBoolOperand_and_dynamic() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "bool f(left, dynamic right) {",
|
| + " return left && right;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonBoolOperand_or_bool() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "bool f(bool left, bool right) {",
|
| + " return left || right;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonBoolOperand_or_dynamic() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "bool f(dynamic left, right) {",
|
| + " return left || right;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstantDefaultValue_function_named() {
|
| + Source source = addSource(EngineTestCase.createSource(["f({x : 2 + 3}) {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstantDefaultValue_function_positional() {
|
| + Source source = addSource(EngineTestCase.createSource(["f([x = 2 + 3]) {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstantDefaultValue_inConstructor_named() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " A({x : 2 + 3}) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstantDefaultValue_inConstructor_positional() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " A([x = 2 + 3]) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstantDefaultValue_method_named() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " m({x : 2 + 3}) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstantDefaultValue_method_positional() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " m([x = 2 + 3]) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstantValueInInitializer_namedArgument() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " final a;",
|
| + " const A({this.a});",
|
| + "}",
|
| + "class B extends A {",
|
| + " const B({b}) : super(a: b);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstCaseExpression() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f(Type t) {",
|
| + " switch (t) {",
|
| + " case bool:",
|
| + " case int:",
|
| + " return true;",
|
| + " default:",
|
| + " return false;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstMapAsExpressionStatement_const() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " const {'a' : 0, 'b' : 1};", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstMapAsExpressionStatement_notExpressionStatement() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " var m = {'a' : 0, 'b' : 1};", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstMapAsExpressionStatement_typeArguments() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " <String, int> {'a' : 0, 'b' : 1};", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstValueInInitializer_binary_bool() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " final v;",
|
| + " const A.a1(bool p) : v = p && true;",
|
| + " const A.a2(bool p) : v = true && p;",
|
| + " const A.b1(bool p) : v = p || true;",
|
| + " const A.b2(bool p) : v = true || p;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertErrors(source, [HintCode.DEAD_CODE]);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstValueInInitializer_binary_dynamic() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " final v;",
|
| + " const A.a1(p) : v = p + 5;",
|
| + " const A.a2(p) : v = 5 + p;",
|
| + " const A.b1(p) : v = p - 5;",
|
| + " const A.b2(p) : v = 5 - p;",
|
| + " const A.c1(p) : v = p * 5;",
|
| + " const A.c2(p) : v = 5 * p;",
|
| + " const A.d1(p) : v = p / 5;",
|
| + " const A.d2(p) : v = 5 / p;",
|
| + " const A.e1(p) : v = p ~/ 5;",
|
| + " const A.e2(p) : v = 5 ~/ p;",
|
| + " const A.f1(p) : v = p > 5;",
|
| + " const A.f2(p) : v = 5 > p;",
|
| + " const A.g1(p) : v = p < 5;",
|
| + " const A.g2(p) : v = 5 < p;",
|
| + " const A.h1(p) : v = p >= 5;",
|
| + " const A.h2(p) : v = 5 >= p;",
|
| + " const A.i1(p) : v = p <= 5;",
|
| + " const A.i2(p) : v = 5 <= p;",
|
| + " const A.j1(p) : v = p % 5;",
|
| + " const A.j2(p) : v = 5 % p;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + // operations on "p" are not resolved
|
| + }
|
| +
|
| + void test_nonConstValueInInitializer_binary_int() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " final v;",
|
| + " const A.a1(int p) : v = p ^ 5;",
|
| + " const A.a2(int p) : v = 5 ^ p;",
|
| + " const A.b1(int p) : v = p & 5;",
|
| + " const A.b2(int p) : v = 5 & p;",
|
| + " const A.c1(int p) : v = p | 5;",
|
| + " const A.c2(int p) : v = 5 | p;",
|
| + " const A.d1(int p) : v = p >> 5;",
|
| + " const A.d2(int p) : v = 5 >> p;",
|
| + " const A.e1(int p) : v = p << 5;",
|
| + " const A.e2(int p) : v = 5 << p;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstValueInInitializer_binary_num() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " final v;",
|
| + " const A.a1(num p) : v = p + 5;",
|
| + " const A.a2(num p) : v = 5 + p;",
|
| + " const A.b1(num p) : v = p - 5;",
|
| + " const A.b2(num p) : v = 5 - p;",
|
| + " const A.c1(num p) : v = p * 5;",
|
| + " const A.c2(num p) : v = 5 * p;",
|
| + " const A.d1(num p) : v = p / 5;",
|
| + " const A.d2(num p) : v = 5 / p;",
|
| + " const A.e1(num p) : v = p ~/ 5;",
|
| + " const A.e2(num p) : v = 5 ~/ p;",
|
| + " const A.f1(num p) : v = p > 5;",
|
| + " const A.f2(num p) : v = 5 > p;",
|
| + " const A.g1(num p) : v = p < 5;",
|
| + " const A.g2(num p) : v = 5 < p;",
|
| + " const A.h1(num p) : v = p >= 5;",
|
| + " const A.h2(num p) : v = 5 >= p;",
|
| + " const A.i1(num p) : v = p <= 5;",
|
| + " const A.i2(num p) : v = 5 <= p;",
|
| + " const A.j1(num p) : v = p % 5;",
|
| + " const A.j2(num p) : v = 5 % p;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstValueInInitializer_field() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " final int a;",
|
| + " const A() : a = 5;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstValueInInitializer_redirecting() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A.named(p);",
|
| + " const A() : this.named(42);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstValueInInitializer_super() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A(p);",
|
| + "}",
|
| + "class B extends A {",
|
| + " const B() : super(42);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonConstValueInInitializer_unary() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " final v;",
|
| + " const A.a(bool p) : v = !p;",
|
| + " const A.b(int p) : v = ~p;",
|
| + " const A.c(num p) : v = -p;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonGenerativeConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A.named() {}",
|
| + " factory A() {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " B() : super.named();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonTypeInCatchClause_isClass() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "f() {",
|
| + " try {",
|
| + " } on String catch (e) {",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonTypeInCatchClause_isFunctionTypeAlias() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "typedef F();",
|
| + "f() {",
|
| + " try {",
|
| + " } on F catch (e) {",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonTypeInCatchClause_isTypeParameter() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A<T> {",
|
| + " f() {",
|
| + " try {",
|
| + " } on T catch (e) {",
|
| + " }",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonTypeInCatchClause_noType() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " try {", " } catch (e) {", " }", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonVoidReturnForOperator_no() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " operator []=(a, b) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonVoidReturnForOperator_void() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " void operator []=(a, b) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonVoidReturnForSetter_function_no() {
|
| + Source source = addSource("set x(v) {}");
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonVoidReturnForSetter_function_void() {
|
| + Source source = addSource("void set x(v) {}");
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonVoidReturnForSetter_method_no() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " set x(v) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_nonVoidReturnForSetter_method_void() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " void set x(v) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_null_callMethod() {
|
| + Source source = addSource(EngineTestCase.createSource(["main() {", " null.m();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_null_callOperator() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "main() {",
|
| + " null + 5;",
|
| + " null == 5;",
|
| + " null[0];",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_optionalParameterInOperator_required() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " operator +(p) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_prefixCollidesWithTopLevelMembers() {
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource(["library lib;", "class A {}"]));
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "import 'lib.dart' as p;",
|
| + "typedef P();",
|
| + "p2() {}",
|
| + "var p3;",
|
| + "class p4 {}",
|
| + "p.A a;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_propagateTypeArgs_intoBounds() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "abstract class A<E> {}",
|
| + "abstract class B<F> implements A<F>{}",
|
| + "abstract class C<G, H extends A<G>> {}",
|
| + "class D<I> extends C<I, B<I>> {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_propagateTypeArgs_intoSupertype() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A<T> {",
|
| + " A(T p);",
|
| + " A.named(T p);",
|
| + "}",
|
| + "class B<S> extends A<S> {",
|
| + " B(S p) : super(p);",
|
| + " B.named(S p) : super.named(p);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_proxy_annotation_prefixed() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "@proxy",
|
| + "class A {}",
|
| + "f(A a) {",
|
| + " a.m();",
|
| + " var x = a.g;",
|
| + " a.s = 1;",
|
| + " var y = a + a;",
|
| + " a++;",
|
| + " ++a;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_proxy_annotation_prefixed2() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "@proxy",
|
| + "class A {}",
|
| + "class B {",
|
| + " f(A a) {",
|
| + " a.m();",
|
| + " var x = a.g;",
|
| + " a.s = 1;",
|
| + " var y = a + a;",
|
| + " a++;",
|
| + " ++a;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_proxy_annotation_prefixed3() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "class B {",
|
| + " f(A a) {",
|
| + " a.m();",
|
| + " var x = a.g;",
|
| + " a.s = 1;",
|
| + " var y = a + a;",
|
| + " a++;",
|
| + " ++a;",
|
| + " }",
|
| + "}",
|
| + "@proxy",
|
| + "class A {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_proxy_annotation_proxyHasPrefixedIdentifier() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "import 'dart:core' as core;",
|
| + "@core.proxy class PrefixProxy {}",
|
| + "main() {",
|
| + " new PrefixProxy().foo;",
|
| + " new PrefixProxy().foo();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_proxy_annotation_simple() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "@proxy",
|
| + "class B {",
|
| + " m() {",
|
| + " n();",
|
| + " var x = g;",
|
| + " s = 1;",
|
| + " var y = this + this;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_proxy_annotation_superclass() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "class B extends A {",
|
| + " m() {",
|
| + " n();",
|
| + " var x = g;",
|
| + " s = 1;",
|
| + " var y = this + this;",
|
| + " }",
|
| + "}",
|
| + "@proxy",
|
| + "class A {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_proxy_annotation_superclass_mixin() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "class B extends Object with A {",
|
| + " m() {",
|
| + " n();",
|
| + " var x = g;",
|
| + " s = 1;",
|
| + " var y = this + this;",
|
| + " }",
|
| + "}",
|
| + "@proxy",
|
| + "class A {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_proxy_annotation_superinterface() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "class B implements A {",
|
| + " m() {",
|
| + " n();",
|
| + " var x = g;",
|
| + " s = 1;",
|
| + " var y = this + this;",
|
| + " }",
|
| + "}",
|
| + "@proxy",
|
| + "class A {}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_proxy_annotation_superinterface_infiniteLoop() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "library L;",
|
| + "class C implements A {",
|
| + " m() {",
|
| + " n();",
|
| + " var x = g;",
|
| + " s = 1;",
|
| + " var y = this + this;",
|
| + " }",
|
| + "}",
|
| + "class B implements A{}",
|
| + "class A implements B{}"]));
|
| + resolve(source);
|
| + // Test is that a stack overflow isn't reached in resolution (previous line), no need to assert
|
| + // error set.
|
| + }
|
| +
|
| + void test_recursiveConstructorRedirect() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A.a() : this.b();",
|
| + " A.b() : this.c();",
|
| + " A.c() {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_recursiveFactoryRedirect() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " factory A() = B;",
|
| + "}",
|
| + "class B implements A {",
|
| + " factory B() = C;",
|
| + "}",
|
| + "class C implements B {",
|
| + " factory C() {}",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_redirectToInvalidFunctionType() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A implements B {",
|
| + " A(int p) {}",
|
| + "}",
|
| + "class B {",
|
| + " factory B(int p) = A;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_redirectToInvalidReturnType() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A() {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " factory B() = A;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_redirectToNonConstConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A.a();",
|
| + " const factory A.b() = A.a;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_referenceToDeclaredVariableInInitializer_constructorName() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A.x() {}",
|
| + "}",
|
| + "f() {",
|
| + " var x = new A.x();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_referenceToDeclaredVariableInInitializer_methodName() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " x() {}",
|
| + "}",
|
| + "f(A a) {",
|
| + " var x = a.x();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_referenceToDeclaredVariableInInitializer_propertyName() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var x;",
|
| + "}",
|
| + "f(A a) {",
|
| + " var x = a.x;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_rethrowOutsideCatch() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " void m() {",
|
| + " try {} catch (e) {rethrow;}",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnInGenerativeConstructor() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " A() { return; }", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnInGenerator_async() {
|
| + resetWithAsync();
|
| + Source source = addSource(EngineTestCase.createSource(["f() async {", " return 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnInGenerator_sync() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() {", " return 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnOfInvalidType_async() {
|
| + AnalysisOptionsImpl options = new AnalysisOptionsImpl.con1(analysisContext2.analysisOptions);
|
| + options.enableAsync = true;
|
| + resetWithOptions(options);
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "import 'dart:async';",
|
| + "class A {",
|
| + " Future<int> m() async {",
|
| + " return 0;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnOfInvalidType_dynamic() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class TypeError {}",
|
| + "class A {",
|
| + " static void testLogicalOp() {",
|
| + " testOr(a, b, onTypeError) {",
|
| + " try {",
|
| + " return a || b;",
|
| + " } on TypeError catch (t) {",
|
| + " return onTypeError;",
|
| + " }",
|
| + " }",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnOfInvalidType_dynamicAsTypeArgument() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class I<T> {",
|
| + " factory I() => new A<T>();",
|
| + "}",
|
| + "class A<T> implements I {",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnOfInvalidType_subtype() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {}",
|
| + "class B extends A {}",
|
| + "A f(B b) { return b; }"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnOfInvalidType_supertype() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {}",
|
| + "class B extends A {}",
|
| + "B f(A a) { return a; }"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnOfInvalidType_typeParameter_18468() {
|
| + // https://code.google.com/p/dart/issues/detail?id=18468
|
| + //
|
| + // This test verifies that the type of T is more specific than Type,
|
| + // where T is a type parameter and Type is the type Type from
|
| + // core, this particular test case comes from issue 18468.
|
| + //
|
| + // A test cannot be added to TypeParameterTypeImplTest since the types returned out of the
|
| + // TestTypeProvider don't have a mock 'dart.core' enclosing library element.
|
| + // See TypeParameterTypeImpl.isMoreSpecificThan().
|
| + Source source = addSource(EngineTestCase.createSource(["class Foo<T> {", " Type get t => T;", "}"]));
|
| + resolve(source);
|
| + assertErrors(source, []);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnOfInvalidType_void() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "void f1() {}",
|
| + "void f2() { return; }",
|
| + "void f3() { return null; }",
|
| + "void f4() { return g1(); }",
|
| + "void f5() { return g2(); }",
|
| + "g1() {}",
|
| + "void g2() {}",
|
| + ""]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnWithoutValue_noReturnType() {
|
| + Source source = addSource(EngineTestCase.createSource(["f() { return; }"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_returnWithoutValue_void() {
|
| + Source source = addSource(EngineTestCase.createSource(["void f() { return; }"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_reversedTypeArguments() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class Codec<S1, T1> {",
|
| + " Codec<T1, S1> get inverted => new _InvertedCodec<T1, S1>(this);",
|
| + "}",
|
| + "class _InvertedCodec<T2, S2> extends Codec<T2, S2> {",
|
| + " _InvertedCodec(Codec<S2, T2> codec);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_sharedDeferredPrefix() {
|
| + resolveWithAndWithoutExperimental(<String> [
|
| + EngineTestCase.createSource(["library lib1;", "f1() {}"]),
|
| + EngineTestCase.createSource(["library lib2;", "f2() {}"]),
|
| + EngineTestCase.createSource(["library lib3;", "f3() {}"]),
|
| + EngineTestCase.createSource([
|
| + "library root;",
|
| + "import 'lib1.dart' deferred as lib1;",
|
| + "import 'lib2.dart' as lib;",
|
| + "import 'lib3.dart' as lib;",
|
| + "main() { lib1.f1(); lib.f2(); lib.f3(); }"])], <ErrorCode> [ParserErrorCode.DEFERRED_IMPORTS_NOT_SUPPORTED], <ErrorCode> []);
|
| + }
|
| +
|
| + void test_staticAccessToInstanceMember_annotation() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " const A.name();",
|
| + "}",
|
| + "@A.name()",
|
| + "main() {",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_staticAccessToInstanceMember_method() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " static m() {}",
|
| + "}",
|
| + "main() {",
|
| + " A.m;",
|
| + " A.m();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_staticAccessToInstanceMember_propertyAccess_field() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " static var f;",
|
| + "}",
|
| + "main() {",
|
| + " A.f;",
|
| + " A.f = 1;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_staticAccessToInstanceMember_propertyAccess_propertyAccessor() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " static get f => 42;",
|
| + " static set f(x) {}",
|
| + "}",
|
| + "main() {",
|
| + " A.f;",
|
| + " A.f = 1;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_superInInvalidContext() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m() {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " B() {",
|
| + " var v = super.m();",
|
| + " }",
|
| + " n() {",
|
| + " var v = super.m();",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typeAliasCannotReferenceItself_returnClass_withTypeAlias() {
|
| + Source source = addSource(EngineTestCase.createSource(["typedef B A();", "class B {", " A a;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typeArgumentNotMatchingBounds_const() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {}",
|
| + "class B extends A {}",
|
| + "class G<E extends A> {",
|
| + " const G();",
|
| + "}",
|
| + "f() { return const G<B>(); }"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typeArgumentNotMatchingBounds_new() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {}",
|
| + "class B extends A {}",
|
| + "class G<E extends A> {}",
|
| + "f() { return new G<B>(); }"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typeArgumentNotMatchingBounds_typeArgumentList_0() {
|
| + Source source = addSource(EngineTestCase.createSource(["abstract class A<T extends A>{}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typeArgumentNotMatchingBounds_typeArgumentList_1() {
|
| + Source source = addSource(EngineTestCase.createSource(["abstract class A<T extends A<A>>{}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typeArgumentNotMatchingBounds_typeArgumentList_20() {
|
| + Source source = addSource(EngineTestCase.createSource(["abstract class A<T extends A<A<A<A<A<A<A<A<A<A<A<A<A<A<A<A<A<A<A<A<A>>>>>>>>>>>>>>>>>>>>>{}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_booleanAnd_useInRight() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "main(Object p) {",
|
| + " p is String && p.length != 0;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_booleanAnd_useInRight_accessedInClosureRight_noAssignment() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "callMe(f()) { f(); }",
|
| + "main(Object p) {",
|
| + " (p is String) && callMe(() { p.length; });",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_conditional_issue14655() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {}",
|
| + "class B extends A {}",
|
| + "class C extends B {",
|
| + " mc() {}",
|
| + "}",
|
| + "print(_) {}",
|
| + "main(A p) {",
|
| + " (p is C) && (print(() => p) && (p is B)) ? p.mc() : p = null;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_conditional_useInThen() {
|
| + Source source = addSource(EngineTestCase.createSource(["main(Object p) {", " p is String ? p.length : 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_conditional_useInThen_accessedInClosure_noAssignment() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "callMe(f()) { f(); }",
|
| + "main(Object p) {",
|
| + " p is String ? callMe(() { p.length; }) : 0;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_functionType_arg_ignoreIfNotMoreSpecific() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "typedef FuncB(B b);",
|
| + "typedef FuncA(A a);",
|
| + "class A {}",
|
| + "class B {}",
|
| + "main(FuncA f) {",
|
| + " if (f is FuncB) {",
|
| + " f(new A());",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_functionType_return_ignoreIfNotMoreSpecific() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {}",
|
| + "typedef FuncAtoDyn(A a);",
|
| + "typedef FuncDynToDyn(x);",
|
| + "main(FuncAtoDyn f) {",
|
| + " if (f is FuncDynToDyn) {",
|
| + " A a = f(new A());",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_functionType_return_voidToDynamic() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "typedef FuncDynToDyn(x);",
|
| + "typedef void FuncDynToVoid(x);",
|
| + "class A {}",
|
| + "main(FuncDynToVoid f) {",
|
| + " if (f is FuncDynToDyn) {",
|
| + " A a = f(null);",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_accessedInClosure_noAssignment() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "callMe(f()) { f(); }",
|
| + "main(Object p) {",
|
| + " if (p is String) {",
|
| + " callMe(() {",
|
| + " p.length;",
|
| + " });",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_extends_moreSpecific() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class V {}",
|
| + "class VP extends V {}",
|
| + "class A<T> {}",
|
| + "class B<S> extends A<S> {",
|
| + " var b;",
|
| + "}",
|
| + "",
|
| + "main(A<V> p) {",
|
| + " if (p is B<VP>) {",
|
| + " p.b;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_hasAssignment_outsideAfter() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "main(Object p) {",
|
| + " if (p is String) {",
|
| + " p.length;",
|
| + " }",
|
| + " p = 0;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_hasAssignment_outsideBefore() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "main(Object p, Object p2) {",
|
| + " p = p2;",
|
| + " if (p is String) {",
|
| + " p.length;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_implements_moreSpecific() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class V {}",
|
| + "class VP extends V {}",
|
| + "class A<T> {}",
|
| + "class B<S> implements A<S> {",
|
| + " var b;",
|
| + "}",
|
| + "",
|
| + "main(A<V> p) {",
|
| + " if (p is B<VP>) {",
|
| + " p.b;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_inClosure_assignedAfter_inSameFunction() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "main() {",
|
| + " f(Object p) {",
|
| + " if (p is String) {",
|
| + " p.length;",
|
| + " }",
|
| + " p = 0;",
|
| + " };",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_is_and_left() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "bool tt() => true;",
|
| + "main(Object p) {",
|
| + " if (p is String && tt()) {",
|
| + " p.length;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_is_and_right() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "bool tt() => true;",
|
| + "main(Object p) {",
|
| + " if (tt() && p is String) {",
|
| + " p.length;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_is_and_subThenSuper() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var a;",
|
| + "}",
|
| + "class B extends A {",
|
| + " var b;",
|
| + "}",
|
| + "main(Object p) {",
|
| + " if (p is B && p is A) {",
|
| + " p.a;",
|
| + " p.b;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_is_parenthesized() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "main(Object p) {",
|
| + " if ((p is String)) {",
|
| + " p.length;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_if_is_single() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "main(Object p) {",
|
| + " if (p is String) {",
|
| + " p.length;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typePromotion_parentheses() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "main(Object p) {",
|
| + " (p is String) ? p.length : 0;",
|
| + " (p) is String ? p.length : 0;",
|
| + " ((p)) is String ? p.length : 0;",
|
| + " ((p) is String) ? p.length : 0;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typeType_class() {
|
| + Source source = addSource(EngineTestCase.createSource(["class C {}", "f(Type t) {}", "main() {", " f(C);", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typeType_class_prefixed() {
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource(["library lib;", "class C {}"]));
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "import 'lib.dart' as p;",
|
| + "f(Type t) {}",
|
| + "main() {",
|
| + " f(p.C);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typeType_functionTypeAlias() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "typedef F();",
|
| + "f(Type t) {}",
|
| + "main() {",
|
| + " f(F);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_typeType_functionTypeAlias_prefixed() {
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource(["library lib;", "typedef F();"]));
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "import 'lib.dart' as p;",
|
| + "f(Type t) {}",
|
| + "main() {",
|
| + " f(p.F);",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedConstructorInInitializer_explicit_named() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A.named() {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " B() : super.named();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedConstructorInInitializer_explicit_unnamed() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A() {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " B() : super();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedConstructorInInitializer_hasOptionalParameters() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A([p]) {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " B();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedConstructorInInitializer_implicit() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A() {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " B();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedConstructorInInitializer_implicit_typeAlias() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class M {}",
|
| + "class A = Object with M;",
|
| + "class B extends A {",
|
| + " B();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedConstructorInInitializer_redirecting() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class Foo {",
|
| + " Foo.ctor();",
|
| + "}",
|
| + "class Bar extends Foo {",
|
| + " Bar() : this.ctor();",
|
| + " Bar.ctor() : super.ctor();",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedGetter_typeSubstitution() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A<E> {",
|
| + " E element;",
|
| + "}",
|
| + "class B extends A<List> {",
|
| + " m() {",
|
| + " element.last;",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedIdentifier_hide() {
|
| + Source source = addSource(EngineTestCase.createSource(["library L;", "export 'lib1.dart' hide a;"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource(["library lib1;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedIdentifier_show() {
|
| + Source source = addSource(EngineTestCase.createSource(["library L;", "export 'lib1.dart' show a;"]));
|
| + addNamedSource("/lib1.dart", EngineTestCase.createSource(["library lib1;"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedIdentifier_synthetic_whenExpression() {
|
| + Source source = addSource(EngineTestCase.createSource(["print(x) {}", "main() {", " print(is String);", "}"]));
|
| + resolve(source);
|
| + assertErrors(source, [ParserErrorCode.MISSING_IDENTIFIER]);
|
| + }
|
| +
|
| + void test_undefinedIdentifier_synthetic_whenMethodName() {
|
| + Source source = addSource(EngineTestCase.createSource(["print(x) {}", "main(int p) {", " p.();", "}"]));
|
| + resolve(source);
|
| + assertErrors(source, [ParserErrorCode.MISSING_IDENTIFIER]);
|
| + }
|
| +
|
| + void test_undefinedMethod_functionExpression_callMethod() {
|
| + Source source = addSource(EngineTestCase.createSource(["main() {", " (() => null).call();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + // A call to verify(source) fails as '.call()' isn't resolved.
|
| + }
|
| +
|
| + void test_undefinedMethod_functionExpression_directCall() {
|
| + Source source = addSource(EngineTestCase.createSource(["main() {", " (() => null)();", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + // A call to verify(source) fails as '(() => null)()' isn't resolved.
|
| + }
|
| +
|
| + void test_undefinedOperator_index() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " operator [](a) {}",
|
| + " operator []=(a, b) {}",
|
| + "}",
|
| + "f(A a) {",
|
| + " a[0];",
|
| + " a[0] = 1;",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedOperator_tilde() {
|
| + Source source = addSource(EngineTestCase.createSource(["const A = 3;", "const B = ~((1 << A) - 1);"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedSetter_importWithPrefix() {
|
| + addNamedSource("/lib.dart", EngineTestCase.createSource(["library lib;", "set y(int value) {}"]));
|
| + Source source = addSource(EngineTestCase.createSource(["import 'lib.dart' as x;", "main() {", " x.y = 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedSuperMethod_field() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " var m;",
|
| + "}",
|
| + "class B extends A {",
|
| + " f() {",
|
| + " super.m();",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_undefinedSuperMethod_method() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " m() {}",
|
| + "}",
|
| + "class B extends A {",
|
| + " f() {",
|
| + " super.m();",
|
| + " }",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_unqualifiedReferenceToNonLocalStaticMember_fromComment_new() {
|
| + Source source = addSource(EngineTestCase.createSource([
|
| + "class A {",
|
| + " A() {}",
|
| + " A.named() {}",
|
| + "}",
|
| + "/// [new A] or [new A.named]",
|
| + "main() {",
|
| + "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_uriDoesNotExist_dll() {
|
| + addNamedSource("/lib.dll", "");
|
| + Source source = addSource(EngineTestCase.createSource(["import 'dart-ext:lib';"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_uriDoesNotExist_dylib() {
|
| + addNamedSource("/lib.dylib", "");
|
| + Source source = addSource(EngineTestCase.createSource(["import 'dart-ext:lib';"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_uriDoesNotExist_so() {
|
| + addNamedSource("/lib.so", "");
|
| + Source source = addSource(EngineTestCase.createSource(["import 'dart-ext:lib';"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + }
|
| +
|
| + void test_wrongNumberOfParametersForOperator_index() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " operator []=(a, b) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_wrongNumberOfParametersForOperator_minus() {
|
| + _check_wrongNumberOfParametersForOperator("-", "");
|
| + _check_wrongNumberOfParametersForOperator("-", "a");
|
| + }
|
| +
|
| + void test_wrongNumberOfParametersForOperator1() {
|
| + _check_wrongNumberOfParametersForOperator1("<");
|
| + _check_wrongNumberOfParametersForOperator1(">");
|
| + _check_wrongNumberOfParametersForOperator1("<=");
|
| + _check_wrongNumberOfParametersForOperator1(">=");
|
| + _check_wrongNumberOfParametersForOperator1("+");
|
| + _check_wrongNumberOfParametersForOperator1("/");
|
| + _check_wrongNumberOfParametersForOperator1("~/");
|
| + _check_wrongNumberOfParametersForOperator1("*");
|
| + _check_wrongNumberOfParametersForOperator1("%");
|
| + _check_wrongNumberOfParametersForOperator1("|");
|
| + _check_wrongNumberOfParametersForOperator1("^");
|
| + _check_wrongNumberOfParametersForOperator1("&");
|
| + _check_wrongNumberOfParametersForOperator1("<<");
|
| + _check_wrongNumberOfParametersForOperator1(">>");
|
| + _check_wrongNumberOfParametersForOperator1("[]");
|
| + }
|
| +
|
| + void test_wrongNumberOfParametersForSetter() {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " set x(a) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_yieldEachInNonGenerator_asyncStar() {
|
| + resetWithAsync();
|
| + Source source = addSource(EngineTestCase.createSource(["f() async* {", " yield* 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_yieldEachInNonGenerator_syncStar() {
|
| + resetWithAsync();
|
| + Source source = addSource(EngineTestCase.createSource(["f() sync* {", " yield* 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_yieldInNonGenerator_asyncStar() {
|
| + resetWithAsync();
|
| + Source source = addSource(EngineTestCase.createSource(["f() async* {", " yield 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void test_yieldInNonGenerator_syncStar() {
|
| + resetWithAsync();
|
| + Source source = addSource(EngineTestCase.createSource(["f() sync* {", " yield 0;", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + }
|
| +
|
| + void _check_wrongNumberOfParametersForOperator(String name, String parameters) {
|
| + Source source = addSource(EngineTestCase.createSource(["class A {", " operator ${name}(${parameters}) {}", "}"]));
|
| + resolve(source);
|
| + assertNoErrors(source);
|
| + verify([source]);
|
| + reset();
|
| + }
|
| +
|
| + void _check_wrongNumberOfParametersForOperator1(String name) {
|
| + _check_wrongNumberOfParametersForOperator(name, "a");
|
| + }
|
| +}
|
| +
|
| +main() {
|
| + _ut.groupSep = ' | ';
|
| + runReflectiveTests(NonErrorResolverTest);
|
| +}
|
|
|