blob: 47c0b39603deb31e37a778d0391807f8ed56c226 [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';
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() {}
}
''');
}
}