| // Copyright (c) 2023, 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:test_reflective_loader/test_reflective_loader.dart'; |
| |
| import '../rule_test_support.dart'; |
| |
| void main() { |
| defineReflectiveSuite(() { |
| defineReflectiveTests(UnnecessaryParenthesisTest); |
| }); |
| } |
| |
| @reflectiveTest |
| class UnnecessaryParenthesisTest extends LintRuleTest { |
| @override |
| String get lintRule => LintNames.unnecessary_parenthesis; |
| |
| test_asExpressionInside_targetOfIndexAssignmentExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(Object o) { |
| (o as List)[7] = 7; |
| } |
| '''); |
| } |
| |
| test_asExpressionInside_targetOfIndexExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(Object o) { |
| (o as List)[7]; |
| } |
| '''); |
| } |
| |
| test_asExpressionInside_targetOfMethodInvocation() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| (2 as num).toString(); |
| } |
| '''); |
| } |
| |
| test_asExpressionInside_targetOfPrefixExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(Object o) { |
| !(o as bool); |
| } |
| '''); |
| } |
| |
| test_assignmentInside_await() async { |
| await assertNoDiagnostics(r''' |
| void f(Future<void> f, Future<void>? g) async { |
| await (g ??= f); |
| } |
| '''); |
| } |
| |
| test_awaitInside_methodInvocation() async { |
| await assertNoDiagnostics(r''' |
| void f(Future<int> f) async { |
| (await f).toString(); |
| } |
| '''); |
| } |
| |
| test_awaitInside_prefixExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(Future<bool> p) async { |
| !(await p); |
| } |
| '''); |
| } |
| |
| test_binaryExpressionInside_asExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(int a, int b) { |
| (b - a) as num; |
| } |
| '''); |
| } |
| |
| test_binaryExpressionInside_assignment() async { |
| await assertNoDiagnostics(r''' |
| void f(bool x) { |
| x = (1 == 1); |
| } |
| '''); |
| } |
| |
| test_binaryExpressionInside_binaryExpression() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| (1 == 1) || "".isEmpty; |
| |
| } |
| '''); |
| } |
| |
| test_binaryExpressionInside_constructorFieldInitializer() async { |
| await assertDiagnostics( |
| r''' |
| class C { |
| bool f; |
| C() : f = (true && false); |
| } |
| ''', |
| [lint(32, 15)], |
| ); |
| } |
| |
| test_binaryExpressionInside_isExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(num a, num b) { |
| (b - a) is int; |
| } |
| '''); |
| } |
| |
| test_binaryExpressionInside_namedArgument() async { |
| await assertDiagnostics( |
| r''' |
| void f({required int p}) { |
| f(p: (1 + 3)); |
| } |
| ''', |
| [lint(34, 7)], |
| ); |
| } |
| |
| test_binaryExpressionInside_positionalArgument() async { |
| await assertDiagnostics( |
| r''' |
| void f(int p) { |
| f((1 + 3)); |
| } |
| ''', |
| [lint(20, 7)], |
| ); |
| } |
| |
| test_binaryExpressionInside_prefixExpression() async { |
| await assertNoDiagnostics(r''' |
| var x = ~(1 | 2); |
| '''); |
| } |
| |
| test_binaryExpressionInside_recordLiteral() async { |
| await assertDiagnostics( |
| r''' |
| Record f() { |
| return (1, (2 + 2)); |
| } |
| ''', |
| [lint(26, 7)], |
| ); |
| } |
| |
| test_binaryExpressionInside_returnExpression() async { |
| await assertDiagnostics( |
| r''' |
| bool f() { |
| return (1 > 1); |
| } |
| ''', |
| [lint(20, 7)], |
| ); |
| } |
| |
| test_binaryExpressionInside_switchStatementVariable() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| switch ((5 == 6)) { |
| case true: |
| return; |
| default: |
| return; |
| } |
| } |
| ''', |
| [lint(21, 8)], |
| ); |
| } |
| |
| test_binaryExpressionInside_variableDeclarationInitializer() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| var x = (1 == 1); |
| } |
| '''); |
| } |
| |
| test_binaryExpressionInside_whileCondition() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| while ((1 == 1)) {} |
| } |
| ''', |
| [lint(20, 8)], |
| ); |
| } |
| |
| test_binaryOperationInside_binaryOperation() async { |
| await assertNoDiagnostics(r''' |
| void f(bool a, bool b) { |
| if ((a && b) || b) {} |
| } |
| '''); |
| } |
| |
| /// https://github.com/dart-lang/linter/issues/4041 |
| test_cascadeAssignmentInside_nullAware() async { |
| await assertNoDiagnostics(r''' |
| class A { |
| var b = false; |
| void m() {} |
| set setter(int i) {} |
| } |
| |
| void f(A? a) { |
| (a?..b = true)?.m(); |
| (a?..b = true)?.setter = 1; |
| } |
| |
| void g(List<int>? list) { |
| (list?..[0] = 1)?.length; |
| } |
| '''); |
| } |
| |
| test_cascadeInside_cascadeAssignmentExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(A a, int x) { |
| a..b = (x..isEven); |
| } |
| abstract class A { |
| int b = 0; |
| } |
| '''); |
| } |
| |
| test_cascadeInside_propertyAssignmentExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(A a, int x) { |
| a.b = (x..isEven); |
| } |
| abstract class A { |
| int b = 0; |
| } |
| '''); |
| } |
| |
| test_conditionalExpressionInside_argument() async { |
| await assertDiagnostics( |
| r''' |
| void f(int p) { |
| print((1 == 1 ? 2 : 3)); |
| } |
| ''', |
| [lint(24, 16)], |
| ); |
| } |
| |
| test_conditionalExpressionInside_argumentList() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| 'a'.substring((1 == 1 ? 2 : 3), 1); |
| } |
| '''); |
| } |
| |
| test_conditionalExpressionInside_expressionBody() async { |
| await assertNoDiagnostics(r''' |
| int f() => (1 == 1 ? 2 : 3); |
| '''); |
| } |
| |
| test_conditionalExpressionInside_ifCondition() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| if ((1 == 1 ? true : false)) {} |
| } |
| ''', |
| [lint(17, 23)], |
| ); |
| } |
| |
| test_conditionalExpressionInside_listLiteral() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| [(1 == 1 ? 2 : 3)]; |
| } |
| '''); |
| } |
| |
| test_conditionalExpressionInside_stringInterpolation() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| '${(1 == 1 ? 2 : 3)}'; |
| } |
| ''', |
| [lint(16, 16)], |
| ); |
| } |
| |
| test_conditionalExpressionInside_targetOfMethodInvocation() async { |
| await assertNoDiagnostics(r''' |
| void f(bool b) { |
| (b ? [] : [])..add(''); |
| } |
| '''); |
| } |
| |
| test_conditionalExpressionInside_variableDeclarationInitiailizer() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| var x = (1 == 1 ? 2 : 3); |
| } |
| '''); |
| } |
| |
| /// https://github.com/dart-lang/linter/issues/4060 |
| test_constantPattern() async { |
| await assertNoDiagnostics(r''' |
| const a = 1; |
| const b = 2; |
| |
| void f(int i) { |
| switch (i) { |
| case const (a + b): |
| } |
| } |
| '''); |
| } |
| |
| test_constructorFieldInitializer_functionExpressionInAssignment() async { |
| await assertNoDiagnostics(r''' |
| class C { |
| final bool Function() e; |
| |
| C(bool Function()? e) : e = e ??= (() => true); |
| } |
| '''); |
| } |
| |
| test_constructorFieldInitializer_functionExpressionInNullAware() async { |
| await assertNoDiagnostics(r''' |
| class C { |
| final bool Function() e; |
| |
| C(bool Function()? e) : e = e ?? (() => true); |
| } |
| '''); |
| } |
| |
| /// https://github.com/dart-lang/linter/issues/1473 |
| test_constructorFieldInitializer_functionExpressionInNullAware2() async { |
| await assertNoDiagnostics(r''' |
| class C { |
| final bool Function() e; |
| |
| C(bool Function()? e) : e = (e ?? () => true); |
| } |
| '''); |
| } |
| |
| test_constructorTearoffInside() async { |
| await assertDiagnostics( |
| r''' |
| class C {} |
| void f() { |
| (C.new)(); |
| } |
| ''', |
| [lint(24, 7)], |
| ); |
| } |
| |
| test_constructorTearoffInside_instantiatedThenCalled() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| (List.filled)<int>(3, 0); |
| } |
| '''); |
| } |
| |
| test_constructorTearoffInstantiatedInside() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| (List<int>.filled)(3, 0); |
| } |
| ''', |
| [lint(13, 18)], |
| ); |
| } |
| |
| test_constructorTearoffInstantiatedInside_assignment() async { |
| await assertDiagnostics( |
| r''' |
| var x = (List<int>.filled); |
| ''', |
| [lint(8, 18)], |
| ); |
| } |
| |
| test_constructorTearoffReferenceInside() async { |
| await assertDiagnostics( |
| r''' |
| class C {} |
| void f() { |
| var cNew = C.new; |
| (cNew)(); |
| } |
| ''', |
| [lint(44, 6)], |
| ); |
| } |
| |
| test_equalityInside_constructorFieldInitializer() async { |
| await assertNoDiagnostics(r''' |
| class C { |
| bool f; |
| C() : f = (1 == 2); |
| } |
| '''); |
| } |
| |
| test_equalityInside_expressionBody() async { |
| await assertDiagnostics( |
| r''' |
| bool f() => (1 == 1); |
| ''', |
| [lint(12, 8)], |
| ); |
| } |
| |
| test_expressionInside_targetOfMethodInvocation() async { |
| await assertNoDiagnostics(r''' |
| void f(Object o) { |
| (o is num).toString(); |
| } |
| '''); |
| } |
| |
| /// https://github.com/dart-lang/linter/issues/1395 |
| test_functionExpressionInCascade2Inside_constructorFieldInitializer() async { |
| await assertNoDiagnostics(r''' |
| class C { |
| dynamic f; |
| |
| C() |
| : f = (C()..f = (C()..f = () => 42)); |
| } |
| '''); |
| } |
| |
| /// https://github.com/dart-lang/linter/issues/1395 |
| test_functionExpressionInCascadeInside_constructorFieldInitializer() async { |
| await assertNoDiagnostics(r''' |
| class C { |
| Object f; |
| |
| C() : f = (C()..f = () => 42); |
| } |
| '''); |
| } |
| |
| test_functionExpressionInside_assignment() async { |
| await assertDiagnostics( |
| r''' |
| var f = (() => null); |
| ''', |
| [lint(8, 12)], |
| ); |
| } |
| |
| test_functionExpressionInside_binaryExpression() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| (() => '') + 1; |
| } |
| extension on Function { |
| operator +(int x) {} |
| } |
| '''); |
| } |
| |
| test_functionExpressionInside_indexExpression() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| (() => '')[0]; |
| } |
| extension on Function { |
| int operator [](int i) => 0; |
| } |
| '''); |
| } |
| |
| test_functionExpressionInside_targetOfAssignment() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| (() => '').g = 1; |
| } |
| |
| extension on Function { |
| set g(int value) {} |
| } |
| '''); |
| } |
| |
| test_functionExpressionInside_targetOfMethodInvocation() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| (() {}).g(); |
| } |
| extension on Function { |
| void g() {} |
| } |
| '''); |
| } |
| |
| test_functionExpressionInside_targetOfPropertyAccess() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| (() => '').hashCode; |
| } |
| '''); |
| } |
| |
| test_intLiteralInside_recordLiteral() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| var x = (1, (2)); |
| } |
| ''', |
| [lint(25, 3)], |
| ); |
| } |
| |
| test_listLiteral() async { |
| await assertDiagnostics( |
| r''' |
| final items = [1, (DateTime.now())]; |
| ''', |
| [lint(18, 16)], |
| ); |
| } |
| |
| test_notEqualInside_returnExpression() async { |
| await assertNoDiagnostics(r''' |
| bool f() { |
| return (1 != 1); |
| } |
| '''); |
| } |
| |
| test_nullAwareCascadeInside_propretyAccess() async { |
| await assertNoDiagnostics(r''' |
| void f(int? a) { |
| (a?..abs()).hashCode; |
| } |
| '''); |
| } |
| |
| test_nullAwareIndexExpressionInside_conditionExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(List<int>? a, bool b) { |
| var x = b ? (a?[7]) : 7; |
| } |
| '''); |
| } |
| |
| test_nullAwareIndexExpressionInside_mapLiteralKey() async { |
| await assertNoDiagnostics(r''' |
| void f(List<int>? a) { |
| var x = {(a?[7]): 7}; |
| } |
| '''); |
| } |
| |
| test_nullAwareIndexExpressionInside_postfixExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(List<int?>? a) { |
| (a?[0])!; |
| } |
| '''); |
| } |
| |
| test_nullAwareIndexExpressionInside_propertyAccess() async { |
| await assertNoDiagnostics(r''' |
| void f(List<int>? a) { |
| (a?[0]).hashCode; |
| } |
| '''); |
| } |
| |
| test_nullAwareMethodInvocationInside_propertyAccess() async { |
| await assertNoDiagnostics(r''' |
| void f(int? a) { |
| (a?.abs()).hashCode; |
| } |
| '''); |
| } |
| |
| test_nullAwarePropertyAccessInside_postfixExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(int? a) { |
| (a?.sign)!; |
| } |
| '''); |
| } |
| |
| test_nullAwarePropertyAccessInside_propertyAccess() async { |
| await assertNoDiagnostics(r''' |
| void f(int? a) { |
| (a?.sign).hashCode; |
| } |
| '''); |
| } |
| |
| test_nullCheckInside_conditionalExpressionCondition() async { |
| await assertNoDiagnostics(r''' |
| void f(bool? b) { |
| (b ?? true) ? true : true; |
| } |
| '''); |
| } |
| |
| @FailingTest(issue: 'https://github.com/dart-lang/linter/issues/4062') |
| test_parenthesizedPattern_nonPatternOutside() async { |
| await assertDiagnostics( |
| r''' |
| void f(num n) { |
| if (1 case (int())) {} |
| } |
| ''', |
| [lint(20, 7)], |
| ); |
| } |
| |
| test_positionalArgument() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| print((1 + 2)); |
| } |
| ''', |
| [lint(19, 7)], |
| ); |
| } |
| |
| test_postfixExpressionInside_targetOfMethodInvocation() async { |
| await assertNoDiagnostics(r''' |
| void f(int i) { |
| (i++).toString(); |
| } |
| '''); |
| } |
| |
| test_postfixExpressionInside_targetOfPropertyAccess() async { |
| await assertNoDiagnostics(r''' |
| void f(int p) { |
| (p++).hashCode; |
| } |
| '''); |
| } |
| |
| test_prefixedIdentifierInside_cascadeAssignmentExpression() async { |
| await assertNoDiagnostics(r''' |
| void f(A a) { |
| a..b = (a.b); |
| } |
| abstract class A { |
| int b = 0; |
| } |
| '''); |
| } |
| |
| test_prefixedIdentifierInside_recordLiteral() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| var x = ((''.isEmpty), 2); |
| } |
| ''', |
| [lint(22, 12)], |
| ); |
| } |
| |
| test_prefixedIdentifierInside_targetOfMethodCall() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| (0.isEven).toString(); |
| } |
| ''', |
| [lint(13, 10)], |
| ); |
| } |
| |
| test_prefixedIdentifierInside_targetOfPropertyAccess() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| (0.sign).isEven; |
| } |
| ''', |
| [lint(13, 8)], |
| ); |
| } |
| |
| test_prefixExpressionInside_targetOfMethodInvocation() async { |
| await assertNoDiagnostics(r''' |
| void f(bool b) { |
| (!b).toString(); |
| } |
| '''); |
| } |
| |
| test_propertyAccessInside_prefixExpression() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| !([].isEmpty); |
| } |
| ''', |
| [lint(14, 12)], |
| ); |
| } |
| |
| test_propertyAccessInside_recordLiteral() async { |
| await assertDiagnostics( |
| r''' |
| Record f() { |
| return (1.isEven, (2.isEven)); |
| } |
| ''', |
| [lint(33, 10)], |
| ); |
| } |
| |
| test_recordInside_assignment() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| (int,) r = ((3,)); |
| } |
| ''', |
| [lint(24, 6)], |
| ); |
| } |
| |
| test_recordInside_namedParam() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| g(i: ((3,))); |
| } |
| |
| void g({required (int,) i}) {} |
| ''', |
| [lint(18, 6)], |
| ); |
| } |
| |
| test_recordInside_param() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| g(((3,))); |
| } |
| |
| void g((int,) i) {} |
| ''', |
| [lint(15, 6)], |
| ); |
| } |
| |
| test_setLiteralInside_binaryExpression() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| ({1, 2, 3}) + {4}; |
| } |
| |
| extension<T> on Set<T> { |
| Set<T> operator +(Set<T> other) => {...this, ...other}; |
| } |
| '''); |
| } |
| |
| test_setLiteralInside_propertyAccess() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| ({false, true}).length; |
| } |
| '''); |
| } |
| |
| test_setLiteralInside_propertyAccess_functionArgument() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| print(({1, 2, 3}).length); |
| } |
| ''', |
| [lint(19, 11)], |
| ); |
| } |
| |
| test_setLiteralInside_targetOfGenericTearoff() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| ({1, 2, 3}).cast<num>; |
| } |
| '''); |
| } |
| |
| test_simpleIdentifierInside_assignmentRightSide() async { |
| await assertDiagnostics( |
| r''' |
| void f(int a) { |
| a = (a); |
| } |
| ''', |
| [lint(22, 3)], |
| ); |
| } |
| |
| test_simpleIdentifierInside_conditionalExpressionCondition() async { |
| await assertDiagnostics( |
| r''' |
| void f(bool a) { |
| (a) ? 2 : 3; |
| } |
| ''', |
| [lint(19, 3)], |
| ); |
| } |
| |
| test_simpleIdentifierInside_conditionalExpressionElseExpression() async { |
| await assertDiagnostics( |
| r''' |
| void f(int a) { |
| 1 == 2 ? true : (a); // LINT |
| } |
| ''', |
| [lint(34, 3)], |
| ); |
| } |
| |
| test_simpleIdentifierInside_conditionalExpressionThenExpression() async { |
| await assertDiagnostics( |
| r''' |
| void f(int a) { |
| 1 == 2 ? (a) : false; // LINT |
| } |
| ''', |
| [lint(27, 3)], |
| ); |
| } |
| |
| test_simpleIdentifierInside_expressionStatement() async { |
| await assertDiagnostics( |
| r''' |
| void f(int a) { |
| (a); |
| } |
| ''', |
| [lint(18, 3)], |
| ); |
| } |
| |
| test_simpleIdentifierInside_functionArgument() async { |
| await assertDiagnostics( |
| r''' |
| void f(int a) { |
| print((a)); |
| } |
| ''', |
| [lint(24, 3)], |
| ); |
| } |
| |
| test_simpleIdentifierInside_methodInvocation() async { |
| await assertDiagnostics( |
| r''' |
| void f(Function fn) { |
| (fn)(3); |
| } |
| ''', |
| [lint(24, 4)], |
| ); |
| } |
| |
| test_singleElementRecordWithNoTrailingCommaInside_assignment() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| (int,) r = (3); |
| } |
| ''', |
| [ |
| error( |
| CompileTimeErrorCode.RECORD_LITERAL_ONE_POSITIONAL_NO_TRAILING_COMMA, |
| 24, |
| 3, |
| ), |
| ], |
| ); |
| } |
| |
| test_singleElementRecordWithNoTrailingCommaInside_namedArgument() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| g(i: (3)); |
| } |
| |
| void g({required (int,) i}) {} |
| ''', |
| [ |
| error( |
| CompileTimeErrorCode.RECORD_LITERAL_ONE_POSITIONAL_NO_TRAILING_COMMA, |
| 18, |
| 3, |
| ), |
| ], |
| ); |
| } |
| |
| /// https://github.com/dart-lang/linter/issues/4876 |
| test_singleElementRecordWithNoTrailingCommaInside_positionalArgument() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| g((3)); |
| } |
| |
| void g((int,) i) {} |
| ''', |
| [ |
| error( |
| CompileTimeErrorCode.RECORD_LITERAL_ONE_POSITIONAL_NO_TRAILING_COMMA, |
| 15, |
| 3, |
| ), |
| ], |
| ); |
| } |
| |
| test_spread() async { |
| await assertNoDiagnostics(r''' |
| void f(Object p) { |
| [...(p as List)]; |
| } |
| '''); |
| } |
| |
| test_spread_nullAware() async { |
| await assertNoDiagnostics(r''' |
| void f(Object? p) { |
| [...?(p as List?)]; |
| } |
| '''); |
| } |
| |
| test_startsWithConstInside_prefixExpression() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| !(const [7].contains(42)); |
| } |
| '''); |
| } |
| |
| test_startsWithConstInside_targetOfMethodCall_prefixExpression() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| !(const [7]).contains(42); |
| } |
| '''); |
| } |
| |
| test_startsWithNew2Inside_prefixExpression() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| -(new List.empty().length); |
| } |
| '''); |
| } |
| |
| test_startsWithNewInside_prefixExpression() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| !(new List.empty().contains(42)); |
| } |
| '''); |
| } |
| |
| test_stringLiteralInside() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| '' + (''); |
| } |
| ''', |
| [lint(18, 4)], |
| ); |
| } |
| |
| test_stringLiteralInside_variableDeclarationInitializer() async { |
| await assertDiagnostics( |
| r''' |
| void f() { |
| var x = (''); |
| } |
| ''', |
| [lint(21, 4)], |
| ); |
| } |
| |
| test_switchExpressionInside_argument() async { |
| await assertDiagnostics( |
| r''' |
| void f(Object? x) { |
| print((switch (x) { _ => 0 })); |
| } |
| ''', |
| [lint(28, 23)], |
| ); |
| } |
| |
| test_switchExpressionInside_expressionStatement() async { |
| await assertNoDiagnostics(r''' |
| void f(Object? x) { |
| (switch (x) { _ => 0 }); |
| } |
| '''); |
| } |
| |
| test_switchExpressionInside_methodInvocation() async { |
| await assertNoDiagnostics(r''' |
| void f(Object v) { |
| const v = 0; |
| (switch (v) { _ => Future.value() }).then((_) {}); |
| } |
| '''); |
| } |
| |
| test_switchExpressionInside_variableDeclaration() async { |
| await assertDiagnostics( |
| r''' |
| void f(Object? x) { |
| final v = (switch (x) { _ => 0 }); |
| } |
| ''', |
| [lint(32, 23)], |
| ); |
| } |
| |
| test_targetOfGetterInNullableExtension() async { |
| await assertNoDiagnostics(r''' |
| void f(C? c) { |
| (c?.s).g; |
| } |
| |
| class C { |
| String? get s => 'yay'; |
| } |
| |
| extension on String? { |
| bool get g => false; |
| } |
| '''); |
| } |
| |
| test_targetOfMethodInNullableExtension() async { |
| await assertNoDiagnostics(r''' |
| void f(C? c) { |
| (c?.s).g(); |
| } |
| |
| class C { |
| String? get s => 'yay'; |
| } |
| |
| extension on String? { |
| bool g() => false; |
| } |
| '''); |
| } |
| |
| test_typeLiteralInside() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| (List<int>).toString(); |
| } |
| '''); |
| } |
| |
| test_typeLiteralInside_propertyAccess() async { |
| await assertNoDiagnostics(r''' |
| void f() { |
| (String).hashCode; |
| } |
| '''); |
| } |
| } |