blob: 486e9503a14a2ebd2c70ece0857444b453c5d9b3 [file] [log] [blame]
// Copyright (c) 2019, 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:analysis_server/src/services/correction/fix.dart';
import 'package:analysis_server/src/services/linter/lint_names.dart';
import 'package:analyzer_plugin/utilities/fixes/fixes.dart';
import 'package:test_reflective_loader/test_reflective_loader.dart';
import 'bulk/bulk_fix_processor.dart';
import 'fix_processor.dart';
void main() {
defineReflectiveSuite(() {
defineReflectiveTests(AddConst_PreferConstConstructorsBulkTest);
defineReflectiveTests(AddConst_PreferConstConstructorsInImmutablesBulkTest);
defineReflectiveTests(AddConst_PreferConstConstructorsInImmutablesTest);
defineReflectiveTests(AddConst_PreferConstConstructorsTest);
});
}
@reflectiveTest
class AddConst_PreferConstConstructorsBulkTest extends BulkFixProcessorTest {
@override
String get lintCode => LintNames.prefer_const_constructors;
/// Disabled in BulkFixProcessor.
@failingTest
Future<void> test_noKeyword() async {
writeTestPackageConfig(meta: true);
await resolveTestCode(r'''
class C {
const C([C c]);
}
var c = C(C());
''');
// TODO (pq): results are incompatible w/ `unnecessary_const`
await assertHasFix(r'''
class C {
const C([C c]);
}
var c = const C(const C());
''');
}
}
@reflectiveTest
class AddConst_PreferConstConstructorsInImmutablesBulkTest
extends BulkFixProcessorTest {
@override
String get lintCode => LintNames.prefer_const_constructors_in_immutables;
Future<void> test_multipleConstructors() async {
writeTestPackageConfig(meta: true);
await resolveTestCode('''
import 'package:meta/meta.dart';
@immutable
class A {
A();
/// Comment.
A.a();
}
''');
await assertHasFix('''
import 'package:meta/meta.dart';
@immutable
class A {
const A();
/// Comment.
const A.a();
}
''');
}
}
@reflectiveTest
class AddConst_PreferConstConstructorsInImmutablesTest
extends FixProcessorLintTest {
@override
FixKind get kind => DartFixKind.ADD_CONST;
@override
String get lintCode => LintNames.prefer_const_constructors_in_immutables;
@override
void setUp() {
super.setUp();
writeTestPackageConfig(
meta: true,
);
}
Future<void> test_default() async {
await resolveTestCode('''
import 'package:meta/meta.dart';
@immutable
class A {
A();
}
''');
await assertHasFix('''
import 'package:meta/meta.dart';
@immutable
class A {
const A();
}
''');
}
Future<void> test_default_withComment() async {
await resolveTestCode('''
import 'package:meta/meta.dart';
@immutable
class A {
/// Comment.
A();
}
''');
await assertHasFix('''
import 'package:meta/meta.dart';
@immutable
class A {
/// Comment.
const A();
}
''');
}
}
@reflectiveTest
class AddConst_PreferConstConstructorsTest extends FixProcessorLintTest {
@override
FixKind get kind => DartFixKind.ADD_CONST;
@override
String get lintCode => LintNames.prefer_const_constructors;
Future<void> test_new() async {
await resolveTestCode('''
class C {
const C();
}
void f() {
var c = new C();
print(c);
}
''');
// handled by REPLACE_NEW_WITH_CONST
await assertNoFix();
}
Future<void> test_noKeyword() async {
await resolveTestCode('''
class C {
const C();
}
void f() {
var c = C();
print(c);
}
''');
await assertHasFix('''
class C {
const C();
}
void f() {
var c = const C();
print(c);
}
''');
}
}