| // 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(SuperInInvalidContextTest); |
| }); |
| } |
| |
| @reflectiveTest |
| class SuperInInvalidContextTest extends PubPackageResolutionTest { |
| test_binaryExpression() async { |
| await assertErrorsInCode(''' |
| var v = super + 0; |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 8, 5), |
| ]); |
| } |
| |
| test_class_field_instance() async { |
| await assertErrorsInCode(''' |
| class A { |
| int get foo => 0; |
| } |
| |
| class B extends A { |
| var f = super.foo; |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 63, 5), |
| ]); |
| } |
| |
| test_class_field_instance_late() async { |
| await assertNoErrorsInCode(''' |
| class A { |
| int foo() => 0; |
| } |
| |
| class B extends A { |
| late var f = super.foo(); |
| } |
| '''); |
| } |
| |
| test_class_field_static() async { |
| await assertErrorsInCode(''' |
| class A { |
| int get foo => 0; |
| } |
| |
| class B extends A { |
| static var f = super.foo; |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 70, 5), |
| ]); |
| } |
| |
| test_class_field_static_late() async { |
| await assertErrorsInCode(''' |
| class A { |
| int get foo => 0; |
| } |
| |
| class B extends A { |
| static late var f = super.foo; |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 75, 5), |
| ]); |
| } |
| |
| test_constructorInitializer_field() async { |
| await assertErrorsInCode(r''' |
| class A { |
| m() {} |
| } |
| class B extends A { |
| var f; |
| B() : f = super.m(); |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 62, 5), |
| ]); |
| } |
| |
| test_constructorInitializer_super() async { |
| await assertErrorsInCode(r''' |
| class S { |
| final int f; |
| S(this.f); |
| } |
| |
| class C extends S { |
| C() : super(super.f); |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 75, 5), |
| ]); |
| } |
| |
| test_constructorInitializer_this() async { |
| await assertErrorsInCode(r''' |
| class S { |
| final int f; |
| S(this.f); |
| } |
| |
| class C extends S { |
| C() : this.other(super.f); |
| C.other(int a) : super(a); |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 80, 5), |
| ]); |
| } |
| |
| test_factoryConstructor() async { |
| await assertErrorsInCode(r''' |
| class A { |
| m() {} |
| } |
| class B extends A { |
| factory B() { |
| super.m(); |
| return B._(); |
| } |
| B._(); |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 61, 5), |
| ]); |
| } |
| |
| test_instanceVariableInitializer() async { |
| await assertErrorsInCode(r''' |
| class A { |
| var a; |
| } |
| class B extends A { |
| var b = super.a; |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 50, 5), |
| ]); |
| } |
| |
| test_methodInvocation_extension_field_static() async { |
| await assertErrorsInCode(''' |
| extension E on int { |
| static final v = super.foo(); |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 40, 5), |
| ]); |
| } |
| |
| test_methodInvocation_extension_method_static() async { |
| await assertErrorsInCode(''' |
| extension E on int { |
| static void foo() { |
| super.foo(); |
| } |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 47, 5), |
| ]); |
| } |
| |
| test_mixin_field_instance() async { |
| await assertErrorsInCode(''' |
| class A { |
| int get foo => 0; |
| } |
| |
| mixin M on A { |
| var f = super.foo; |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 58, 5), |
| ]); |
| } |
| |
| test_mixin_field_instance_late() async { |
| await assertNoErrorsInCode(''' |
| class A { |
| int get foo => 0; |
| } |
| |
| mixin M on A { |
| late var f = super.foo; |
| } |
| '''); |
| } |
| |
| test_mixin_field_static() async { |
| await assertErrorsInCode(''' |
| class A { |
| int get foo => 0; |
| } |
| |
| mixin M on A { |
| static var f = super.foo; |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 65, 5), |
| ]); |
| } |
| |
| test_mixin_field_static_late() async { |
| await assertErrorsInCode(''' |
| class A { |
| int get foo => 0; |
| } |
| |
| mixin M on A { |
| static late var f = super.foo; |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 70, 5), |
| ]); |
| } |
| |
| test_propertyAccess_extension_field_static() async { |
| await assertErrorsInCode(''' |
| class A { |
| int get foo => 0; |
| } |
| |
| extension E on int { |
| static var f = super.foo; |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 71, 5), |
| ]); |
| } |
| |
| test_propertyAccess_extension_field_static_late() async { |
| await assertErrorsInCode(''' |
| class A { |
| int get foo => 0; |
| } |
| |
| extension E on int { |
| static late var f = super.foo; |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 76, 5), |
| ]); |
| } |
| |
| test_staticMethod() async { |
| await assertErrorsInCode(r''' |
| class A { |
| static m() {} |
| } |
| class B extends A { |
| static n() { return super.m(); } |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 70, 5), |
| ]); |
| |
| var node = findNode.methodInvocation('super.m()'); |
| assertResolvedNodeText(node, r''' |
| MethodInvocation |
| target: SuperExpression |
| superKeyword: super |
| staticType: B |
| operator: . |
| methodName: SimpleIdentifier |
| token: m |
| staticElement: <null> |
| staticType: InvalidType |
| argumentList: ArgumentList |
| leftParenthesis: ( |
| rightParenthesis: ) |
| staticInvokeType: InvalidType |
| staticType: InvalidType |
| '''); |
| } |
| |
| test_staticVariableInitializer() async { |
| await assertErrorsInCode(r''' |
| class A { |
| static int a = 0; |
| } |
| class B extends A { |
| static int b = super.a; |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 69, 5), |
| ]); |
| |
| var node = findNode.singlePropertyAccess; |
| assertResolvedNodeText(node, r''' |
| PropertyAccess |
| target: SuperExpression |
| superKeyword: super |
| staticType: B |
| operator: . |
| propertyName: SimpleIdentifier |
| token: a |
| staticElement: <null> |
| staticType: InvalidType |
| staticType: InvalidType |
| '''); |
| } |
| |
| test_topLevelFunction() async { |
| await assertErrorsInCode(r''' |
| f() { |
| super.f(); |
| } |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 8, 5), |
| ]); |
| } |
| |
| test_topLevelVariableInitializer() async { |
| await assertErrorsInCode(''' |
| var v = super.y; |
| ''', [ |
| error(CompileTimeErrorCode.SUPER_IN_INVALID_CONTEXT, 8, 5), |
| ]); |
| } |
| |
| test_valid() async { |
| await assertErrorsInCode(r''' |
| class A { |
| m() {} |
| } |
| class B extends A { |
| B() { |
| var v = super.m(); |
| } |
| n() { |
| var v = super.m(); |
| } |
| } |
| ''', [ |
| error(WarningCode.UNUSED_LOCAL_VARIABLE, 57, 1), |
| error(WarningCode.UNUSED_LOCAL_VARIABLE, 92, 1), |
| ]); |
| } |
| } |