blob: 686290a1ef0da0f3a850eb4701c8307d7cb134a9 [file] [log] [blame]
// Copyright (c) 2017, 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 'dart:async';
import 'package:analyzer/src/generated/engine.dart';
import 'package:analyzer/src/generated/source.dart';
import 'package:test/test.dart';
import 'package:test_reflective_loader/test_reflective_loader.dart';
import 'resolver_test_case.dart';
main() {
defineReflectiveSuite(() {
defineReflectiveTests(InvalidCodeTest);
});
}
/**
* Tests for various end-to-end cases when invalid code caused exceptions
* in one or another Analyzer subsystem. We are not interested not in specific
* errors generated, but we want to make sure that there is at least one,
* and analysis finishes without exceptions.
*/
@reflectiveTest
class InvalidCodeTest extends ResolverTestCase {
@override
AnalysisOptions get defaultAnalysisOptions =>
new AnalysisOptionsImpl()..strongMode = true;
/**
* This code results in a method with the empty name, and the default
* constructor, which also has the empty name. The `Map` in `f` initializer
* references the empty name.
*/
test_constructorAndMethodNameCollision() async {
await _assertCanBeAnalyzed('''
class C {
var f = { : };
@ ();
}
''');
}
test_genericFunction_asTypeArgument_ofUnresolvedClass() async {
await _assertCanBeAnalyzed(r'''
C<int Function()> c;
''');
}
Future<Null> _assertCanBeAnalyzed(String text) async {
Source source = addSource(text);
var analysisResult = await computeAnalysisResult(source);
expect(analysisResult.errors, isNotEmpty);
}
}