| // Copyright (c) 2019, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| import 'package:analyzer/src/error/codes.dart'; |
| import 'package:test_reflective_loader/test_reflective_loader.dart'; |
| |
| import '../dart/resolution/context_collection_resolution.dart'; |
| |
| main() { |
| defineReflectiveSuite(() { |
| defineReflectiveTests(ExtendsNonClassTest); |
| }); |
| } |
| |
| @reflectiveTest |
| class ExtendsNonClassTest extends PubPackageResolutionTest { |
| test_class_dynamic() async { |
| await assertErrorsInCode(r''' |
| class A extends dynamic {} |
| ''', [ |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 16, 7), |
| ]); |
| |
| var node = findNode.singleExtendsClause; |
| assertResolvedNodeText(node, r''' |
| ExtendsClause |
| extendsKeyword: extends |
| superclass: NamedType |
| name: dynamic |
| element: dynamic@-1 |
| type: dynamic |
| '''); |
| } |
| |
| test_class_enum() async { |
| await assertErrorsInCode(r''' |
| enum E { ONE } |
| class A extends E {} |
| ''', [ |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 31, 1), |
| ]); |
| |
| var node = findNode.singleExtendsClause; |
| assertResolvedNodeText(node, r''' |
| ExtendsClause |
| extendsKeyword: extends |
| superclass: NamedType |
| name: E |
| element: <testLibraryFragment>::@enum::E |
| type: E |
| '''); |
| } |
| |
| test_class_extensionType() async { |
| await assertErrorsInCode(r''' |
| extension type A(int it) {} |
| class B extends A {} |
| ''', [ |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 44, 1), |
| ]); |
| |
| var node = findNode.singleExtendsClause; |
| assertResolvedNodeText(node, r''' |
| ExtendsClause |
| extendsKeyword: extends |
| superclass: NamedType |
| name: A |
| element: <testLibraryFragment>::@extensionType::A |
| type: A |
| '''); |
| } |
| |
| test_class_mixin() async { |
| await assertErrorsInCode(r''' |
| mixin M {} |
| class A extends M {} |
| ''', [ |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 27, 1), |
| ]); |
| |
| var node = findNode.singleExtendsClause; |
| assertResolvedNodeText(node, r''' |
| ExtendsClause |
| extendsKeyword: extends |
| superclass: NamedType |
| name: M |
| element: <testLibraryFragment>::@mixin::M |
| type: M |
| '''); |
| } |
| |
| test_class_variable() async { |
| await assertErrorsInCode(r''' |
| int v = 0; |
| class A extends v {} |
| ''', [ |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 27, 1), |
| ]); |
| |
| var node = findNode.singleExtendsClause; |
| assertResolvedNodeText(node, r''' |
| ExtendsClause |
| extendsKeyword: extends |
| superclass: NamedType |
| name: v |
| element: <testLibraryFragment>::@getter::v |
| type: InvalidType |
| '''); |
| } |
| |
| test_class_variable_generic() async { |
| await assertErrorsInCode(r''' |
| int v = 0; |
| class A extends v<int> {} |
| ''', [ |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 27, 1), |
| ]); |
| |
| var node = findNode.singleExtendsClause; |
| assertResolvedNodeText(node, r''' |
| ExtendsClause |
| extendsKeyword: extends |
| superclass: NamedType |
| name: v |
| typeArguments: TypeArgumentList |
| leftBracket: < |
| arguments |
| NamedType |
| name: int |
| element: dart:core::<fragment>::@class::int |
| type: int |
| rightBracket: > |
| element: <testLibraryFragment>::@getter::v |
| type: InvalidType |
| '''); |
| } |
| |
| test_Never() async { |
| await assertErrorsInCode(''' |
| class A extends Never {} |
| ''', [ |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 16, 5), |
| ]); |
| |
| var node = findNode.singleExtendsClause; |
| assertResolvedNodeText(node, r''' |
| ExtendsClause |
| extendsKeyword: extends |
| superclass: NamedType |
| name: Never |
| element: Never@-1 |
| type: Never |
| '''); |
| } |
| |
| test_undefined() async { |
| await assertErrorsInCode(r''' |
| class C extends A {} |
| ''', [ |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 16, 1), |
| ]); |
| |
| var node = findNode.singleExtendsClause; |
| assertResolvedNodeText(node, r''' |
| ExtendsClause |
| extendsKeyword: extends |
| superclass: NamedType |
| name: A |
| element: <null> |
| type: InvalidType |
| '''); |
| } |
| |
| test_undefined_ignore_import_prefix() async { |
| await assertErrorsInCode(r''' |
| import 'a.dart' as p; |
| |
| class C extends p.A {} |
| ''', [ |
| error(CompileTimeErrorCode.URI_DOES_NOT_EXIST, 7, 8), |
| ]); |
| |
| var node = findNode.singleExtendsClause; |
| assertResolvedNodeText(node, r''' |
| ExtendsClause |
| extendsKeyword: extends |
| superclass: NamedType |
| importPrefix: ImportPrefixReference |
| name: p |
| period: . |
| element: <testLibraryFragment>::@prefix::p |
| name: A |
| element: <null> |
| type: InvalidType |
| '''); |
| } |
| |
| test_undefined_ignore_import_show_it() async { |
| await assertErrorsInCode(r''' |
| import 'a.dart' show A; |
| |
| class C extends A {} |
| ''', [ |
| error(CompileTimeErrorCode.URI_DOES_NOT_EXIST, 7, 8), |
| ]); |
| } |
| |
| test_undefined_ignore_import_show_other() async { |
| await assertErrorsInCode(r''' |
| import 'a.dart' show B; |
| |
| class C extends A {} |
| ''', [ |
| error(CompileTimeErrorCode.URI_DOES_NOT_EXIST, 7, 8), |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 41, 1), |
| ]); |
| } |
| |
| test_undefined_ignore_part_exists_uriGenerated_nameIgnorable() async { |
| newFile('$testPackageLibPath/a.g.dart', r''' |
| part of 'test.dart'; |
| '''); |
| |
| await assertErrorsInCode(r''' |
| part 'a.g.dart'; |
| |
| class C extends _$A {} |
| ''', [ |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 34, 3), |
| ]); |
| } |
| |
| test_undefined_ignore_part_notExist_uriGenerated_nameIgnorable() async { |
| await assertErrorsInCode(r''' |
| part 'a.g.dart'; |
| |
| class C extends _$A {} |
| ''', [ |
| error(CompileTimeErrorCode.URI_HAS_NOT_BEEN_GENERATED, 5, 10), |
| ]); |
| } |
| |
| test_undefined_ignore_part_notExist_uriGenerated_nameNotIgnorable() async { |
| await assertErrorsInCode(r''' |
| part 'a.g.dart'; |
| |
| class C extends A {} |
| ''', [ |
| error(CompileTimeErrorCode.URI_HAS_NOT_BEEN_GENERATED, 5, 10), |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 34, 1), |
| ]); |
| } |
| |
| test_undefined_ignore_part_notExist_uriNotGenerated_nameIgnorable() async { |
| await assertErrorsInCode(r''' |
| part 'a.dart'; |
| |
| class C extends _$A {} |
| ''', [ |
| error(CompileTimeErrorCode.URI_DOES_NOT_EXIST, 5, 8), |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 32, 3), |
| ]); |
| } |
| |
| test_undefined_ignore_part_notExist_uriNotGenerated_nameNotIgnorable() async { |
| await assertErrorsInCode(r''' |
| part 'a.dart'; |
| |
| class C extends A {} |
| ''', [ |
| error(CompileTimeErrorCode.URI_DOES_NOT_EXIST, 5, 8), |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 32, 1), |
| ]); |
| } |
| |
| test_undefined_import_exists_prefixed() async { |
| await assertErrorsInCode(r''' |
| import 'dart:math' as p; |
| |
| class C extends p.A {} |
| ''', [ |
| error(CompileTimeErrorCode.EXTENDS_NON_CLASS, 42, 3), |
| ]); |
| |
| var node = findNode.singleExtendsClause; |
| assertResolvedNodeText(node, r''' |
| ExtendsClause |
| extendsKeyword: extends |
| superclass: NamedType |
| importPrefix: ImportPrefixReference |
| name: p |
| period: . |
| element: <testLibraryFragment>::@prefix::p |
| name: A |
| element: <null> |
| type: InvalidType |
| '''); |
| } |
| } |