blob: 8f390a5adf85f201851ce056092e0cac2af5a357 [file] [log] [blame]
// 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';
void 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 => LintNames.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'''
part 'test.dart';
void f(int p) {}
''');
await assertDiagnostics(
r'''
part of 'a.dart';
augment void f(int q) {}
''',
[lint(41, 1)],
);
}
test_augmentedMethod() async {
newFile('$testPackageLibPath/a.dart', r'''
part 'test.dart';
class A {
void m(int p) {}
}
''');
await assertDiagnostics(
r'''
part of 'a.dart';
augment class A {
augment void m(int q) {}
augment void m(int q) {}
}
''',
[
lint(58, 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) {}
}
''');
await assertNoDiagnosticsInFile(lib.path);
}
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_wildcardInBase() async {
await assertNoDiagnostics(r'''
class A {
void m(int _, int b, int c) {}
}
class B extends A {
void m(a, b, c) {}
}
''');
}
test_wildcardInBaseAndSub() async {
await assertNoDiagnostics(r'''
class A {
void m(int _, int b, int c) {}
}
class B extends A {
void m(a, b, _) {}
}
''');
}
test_zeroParameters() async {
await assertNoDiagnostics(r'''
class A {
void m() {}
}
class B extends A {
void m() {}
}
''');
}
}