| // Copyright (c) 2022, 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'; |
| |
| main() { |
| defineReflectiveSuite(() { |
| // TODO(srawlins): Add more tests: |
| // * indirect extension (C extends B extends A), |
| // * implementation (B implements A), |
| // * mixing in |
| // * mix-in applications |
| // * renaming with `_` |
| // * renaming with `__` (like `m(_, __)`) |
| defineReflectiveTests(AvoidRenamingMethodParametersTest); |
| }); |
| } |
| |
| @reflectiveTest |
| class AvoidRenamingMethodParametersTest extends LintRuleTest { |
| @override |
| String get lintRule => 'avoid_renaming_method_parameters'; |
| |
| @FailingTest( |
| reason: 'lint is limited to methods', |
| issue: 'https://github.com/dart-lang/linter/issues/4891') |
| test_augmentedFunction() async { |
| newFile('$testPackageLibPath/a.dart', r''' |
| import augment 'test.dart'; |
| |
| void f(int p) {} |
| '''); |
| |
| await assertDiagnostics(r''' |
| augment library 'a.dart'; |
| |
| augment void f(int q) {} |
| ''', [ |
| lint(41, 1), |
| ]); |
| } |
| |
| test_augmentedMethod() async { |
| newFile('$testPackageLibPath/a.dart', r''' |
| import augment 'test.dart'; |
| |
| class A { |
| void m(int p) {} |
| } |
| '''); |
| |
| await assertDiagnostics(r''' |
| augment library 'a.dart'; |
| |
| augment class A { |
| augment void m(int q) {} |
| augment void m(int q) {} |
| } |
| ''', [ |
| lint(66, 1), // Only the first augmentation gets linted. |
| ]); |
| } |
| |
| test_enumMixingIn() async { |
| await assertDiagnostics(r''' |
| mixin class C { |
| int f(int f) => f; |
| } |
| enum A with C { |
| a,b,c; |
| @override |
| int f(int x) => x; |
| } |
| ''', [ |
| lint(88, 1), |
| ]); |
| } |
| |
| test_optionalPositional_renamed() async { |
| await assertDiagnostics(r''' |
| class A { |
| void m([int p = 0]) {} |
| } |
| class B extends A { |
| void m([int q = 0]) {} |
| } |
| ''', [ |
| lint(71, 1), |
| ]); |
| } |
| |
| test_positional_docComments() async { |
| await assertNoDiagnostics(r''' |
| class A { |
| void m(int p) {} |
| } |
| class B extends A { |
| /// New comment. |
| void m(int q) {} |
| } |
| '''); |
| } |
| |
| test_positional_privateOverride() async { |
| await assertNoDiagnostics(r''' |
| class A { |
| void m(int p) {} |
| } |
| // ignore: unused_element |
| class _B extends A { |
| void m(int q) {} |
| } |
| '''); |
| } |
| |
| test_positional_renamed() async { |
| await assertDiagnostics(r''' |
| class A { |
| void m(int p) {} |
| } |
| class B extends A { |
| void m(int q) {} |
| } |
| ''', [ |
| lint(64, 1), |
| ]); |
| } |
| |
| test_positional_renamed_nonLibSource() async { |
| newFile('$testPackageLibPath/a.dart', r''' |
| class A { |
| void m(int p) {} |
| } |
| '''); |
| var lib = newFile('$testPackageRootPath/test/a.dart', r''' |
| import '../lib/a.dart'; |
| class B extends A { |
| void m(int q) {} |
| } |
| '''); |
| var result = await resolveFile(lib.path); |
| await assertNoDiagnosticsIn(result.errors); |
| } |
| |
| test_positional_sameName() async { |
| await assertNoDiagnostics(r''' |
| class A { |
| void m(int p) {} |
| } |
| class B extends A { |
| void m(int p) {} |
| } |
| '''); |
| } |
| |
| test_wildcard_allowed() async { |
| await assertNoDiagnostics(r''' |
| class A { |
| void m(int p) {} |
| } |
| class B extends A { |
| void m(_) {} |
| } |
| '''); |
| } |
| |
| test_wildcard_featureDisabledFails() async { |
| await assertDiagnostics(r''' |
| // @dart = 3.4 |
| // (pre wildcard-variables) |
| |
| class A { |
| void m(int p) {} |
| } |
| class B extends A { |
| void m(_) {} |
| } |
| ''', [ |
| lint(104, 1), |
| ]); |
| } |
| |
| test_wildcard_mixed() async { |
| await assertNoDiagnostics(r''' |
| class A { |
| void m(int a, int b, int c) {} |
| } |
| class B extends A { |
| void m(_, b, _) {} |
| } |
| '''); |
| } |
| |
| test_wildcard_mixedFails() async { |
| await assertDiagnostics(r''' |
| class A { |
| void m(int a, int b, int c) {} |
| } |
| class B extends A { |
| void m(_, c, _) {} |
| } |
| ''', [ |
| lint(77, 1), |
| ]); |
| } |
| |
| test_wildcard_multipleWildcards() async { |
| await assertNoDiagnostics(r''' |
| class A { |
| void m(int a, int b) {} |
| } |
| class B extends A { |
| void m(_, _) {} |
| } |
| '''); |
| } |
| |
| test_wildcard_nonWildcardButUnderscoreBefore() async { |
| await assertDiagnostics(r''' |
| class A { |
| void m(int a, int b) {} |
| } |
| class B extends A { |
| void m(_, _b) {} |
| } |
| ''', [ |
| lint(70, 2), |
| ]); |
| } |
| |
| test_wildcard_nonWildcardButUnderscoresAround() async { |
| await assertDiagnostics(r''' |
| class A { |
| void m(int p) {} |
| } |
| class B extends A { |
| void m(_p_) {} |
| } |
| ''', [ |
| lint(60, 3), |
| ]); |
| } |
| |
| test_zeroParameters() async { |
| await assertNoDiagnostics(r''' |
| class A { |
| void m() {} |
| } |
| class B extends A { |
| void m() {} |
| } |
| '''); |
| } |
| } |