Skip to content

Commit

Permalink
Move avoid_positional_boolean_parameters tests (#4687)
Browse files Browse the repository at this point in the history
  • Loading branch information
srawlins authored Aug 14, 2023
1 parent a9e90d5 commit 73083b9
Show file tree
Hide file tree
Showing 3 changed files with 251 additions and 107 deletions.
3 changes: 3 additions & 0 deletions test/rules/all.dart
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ import 'avoid_final_parameters_test.dart' as avoid_final_parameters;
import 'avoid_function_literals_in_foreach_calls_test.dart'
as avoid_function_literals_in_foreach_calls;
import 'avoid_init_to_null_test.dart' as avoid_init_to_null;
import 'avoid_positional_boolean_parameters_test.dart'
as avoid_positional_boolean_parameters;
import 'avoid_private_typedef_functions_test.dart'
as avoid_private_typedef_functions;
import 'avoid_redundant_argument_values_test.dart'
Expand Down Expand Up @@ -230,6 +232,7 @@ void main() {
avoid_final_parameters.main();
avoid_function_literals_in_foreach_calls.main();
avoid_init_to_null.main();
avoid_positional_boolean_parameters.main();
avoid_private_typedef_functions.main();
avoid_redundant_argument_values.main();
avoid_relative_lib_imports.main();
Expand Down
248 changes: 248 additions & 0 deletions test/rules/avoid_positional_boolean_parameters_test.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,248 @@
// 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';

main() {
defineReflectiveSuite(() {
defineReflectiveTests(AvoidPositionalBooleanParametersTest);
});
}

@reflectiveTest
class AvoidPositionalBooleanParametersTest extends LintRuleTest {
@override
String get lintRule => 'avoid_positional_boolean_parameters';

test_anonymousFunction() async {
await assertNoDiagnostics(r'''
void f(List<bool> list) {
list.where((bool e) => e);
}
''');
}

test_constructor_fieldFormalParameter_named() async {
await assertNoDiagnostics(r'''
class C {
bool p;
C.named({this.p = false});
}
''');
}

test_constructor_fieldFormalParameter_postional() async {
await assertDiagnostics(r'''
class C {
bool p;
C.named(this.p);
}
''', [
lint(30, 6),
]);
}

test_constructor_named_withDefault() async {
await assertNoDiagnostics(r'''
class C {
C.named({bool p = false}) {
}
}
''');
}

test_constructor_positional() async {
await assertDiagnostics(r'''
class C {
C.named(bool a) {
}
}
''', [
lint(20, 6),
]);
}

test_constructorPrivate_positionalOptional() async {
await assertNoDiagnostics(r'''
class C {
// ignore: unused_element_parameter
C._named([bool p = false]);
}
''');
}

test_extensionMethod() async {
await assertDiagnostics(r'''
extension Ext on int {
void f([bool p = false]) {}
}
''', [
lint(33, 14),
]);
}

test_extensionMethod_unnamed() async {
await assertDiagnostics(r'''
extension on int {
// ignore: unused_element, unused_element_parameter
void f([bool p = false]) {}
}
''', [
lint(83, 14),
]);
}

test_instanceMethod_named() async {
await assertNoDiagnostics(r'''
class C {
void m({bool p = true}) {}
}
''');
}

test_instanceMethod_overrideExtends_positionalOptional() async {
// TODO(srawlins): Test where the parameter in the override is _not found_
// in the parent interface.
// TODO(srawlins): Test where the parameter is renamed.
await assertDiagnostics(r'''
class C {
void m([bool p = false]) {}
}
class D extends C {
@override
void m([bool p = false]) {}
}
''', [
lint(20, 14),
]);
}

test_instanceMethod_overrideImplements_positionalOptional() async {
await assertDiagnostics(r'''
class C {
void m([bool p = false]) {}
}
abstract class D implements C {
@override
void m([bool p = false]) {}
}
''', [
lint(20, 14),
]);
}

test_instanceMethod_positional() async {
await assertDiagnostics(r'''
class A {
void m(bool p) {}
}
''', [
lint(19, 6),
]);
}

test_instanceMethod_positionalOptional() async {
await assertDiagnostics(r'''
class C {
void m([bool p = false]) {}
}
''', [
lint(20, 14),
]);
}

test_instanceSetter() async {
await assertNoDiagnostics(r'''
class C {
set m(bool p) {}
}
''');
}

test_operator_indexAssignment() async {
await assertNoDiagnostics(r'''
class C {
void operator []=(int index, bool value) {}
}
''');
}

test_operator_minus() async {
await assertNoDiagnostics(r'''
class C {
void operator -(bool value) {}
}
''');
}

test_operator_plus() async {
await assertNoDiagnostics(r'''
class C {
void operator +(bool value) {
}
}
''');
}

test_staticMethod_namedWithDefault() async {
await assertNoDiagnostics(r'''
class B {
static void m({bool p = false}) {}
}
''');
}

test_staticMethod_positional() async {
await assertDiagnostics(r'''
class B {
static void m(bool p) {}
}
''', [
lint(26, 6),
]);
}

test_topLevel_namedParameter() async {
await assertNoDiagnostics(r'''
void f({bool p = false}) {}
''');
}

test_topLevel_namedParameter_defaultValue() async {
await assertNoDiagnostics(r'''
void f({bool p = false}) {}
''');
}

test_topLevel_positionalParameter() async {
await assertDiagnostics(r'''
void f(bool p) {}
''', [
lint(7, 6),
]);
}

test_topLevelPrivate() async {
await assertNoDiagnostics(r'''
// ignore: unused_element
void _f(bool p) {}
''');
}

test_typedef_named() async {
await assertNoDiagnostics(r'''
typedef T = Function({bool p});
''');
}

test_typedef_positional() async {
await assertDiagnostics(r'''
typedef T = Function(bool p);
''', [
lint(21, 6),
]);
}
}
107 changes: 0 additions & 107 deletions test_data/rules/avoid_positional_boolean_parameters.dart

This file was deleted.

0 comments on commit 73083b9

Please sign in to comment.