blob: d3325a0a35ace88f7efff9e4ab9a5802a6ae7604 [file] [log] [blame]
// Copyright (c) 2018, 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.
/**
* @assertion We say that a type T0 is a subtype of a type T1 (written T0 <: T1)
* when:
* Left FutureOr: T0 is FutureOr<S0>
* and Future<S0> <: T1
* and S0 <: T1
* @description Check that if a type T0 is FutureOr<S0> and S0 is a subtype of
* T1 but Future<S0> is not a subtype of T1 , then a type T0 is not a subtype of
* a type T1.
* @author sgrekhov@unipro.ru
*/
/**
* @description Check that if type T0 not a subtype of a type T1, then it cannot
* be used as an argument of type T1. Global function required argument is
* tested.
* @author sgrekhov@unipro.ru
*/
/*
* This test is generated from left_FutureOr_fail_A04.dart and
* arguments_binding_fail_x01.dart.
* Don't modify it. If you want to change this file, change one of the files
* above and then run generator.dart to regenerate the tests.
*/
import "dart:async";
FutureOr? t0Instance = Future.value(42);
Future? t1Instance = Future.value(42);
const t1Default = null;
namedArgumentsFunc1(Future? t1, {Future? t2 = t1Default}) {}
positionalArgumentsFunc1(Future? t1, [Future? t2 = t1Default]) {}
class ArgumentsBindingClass {
ArgumentsBindingClass(Future? t1) {}
ArgumentsBindingClass.named(Future? t1, {Future? t2 = t1Default}) {}
ArgumentsBindingClass.positional(Future? t1, [Future? t2 = t1Default]) {}
factory ArgumentsBindingClass.fNamed(Future? t1, {Future? t2 = t1Default}) {
return new ArgumentsBindingClass.named(t1, t2: t2);
}
factory ArgumentsBindingClass.fPositional(Future? t1, [Future? t2 = t1Default]) {
return new ArgumentsBindingClass.positional(t1, t2);
}
static namedArgumentsStaticMethod(Future? t1, {Future? t2 = t1Default}) {}
static positionalArgumentsStaticMethod(Future? t1, [Future? t2 = t1Default]) {}
namedArgumentsMethod(Future? t1, {Future? t2 = t1Default}) {}
positionalArgumentsMethod(Future? t1, [Future? t2 = t1Default]) {}
set testSetter(Future? val) {}
}
class ArgumentsBindingClassSuper {
ArgumentsBindingClassSuper(Future? t1) {}
}
class ArgumentsBindingDesc extends ArgumentsBindingClassSuper {
ArgumentsBindingDesc(FutureOr? t0) : super (t0) {}
// ^^
// [analyzer] unspecified
// [cfe] unspecified
}
main() {
namedArgumentsFunc1(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
namedArgumentsFunc1(t1Instance, t2: t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
positionalArgumentsFunc1(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
positionalArgumentsFunc1(t1Instance, t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass(t1Instance).namedArgumentsMethod(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass(t1Instance).namedArgumentsMethod(t1Instance, t2: t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass(t1Instance).positionalArgumentsMethod(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass(t1Instance).positionalArgumentsMethod(t1Instance, t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass(t1Instance).testSetter = t0Instance;
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
ArgumentsBindingClass.namedArgumentsStaticMethod(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
ArgumentsBindingClass.namedArgumentsStaticMethod(t1Instance, t2: t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
ArgumentsBindingClass.positionalArgumentsStaticMethod(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
ArgumentsBindingClass.positionalArgumentsStaticMethod(t1Instance, t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass.named(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass.named(t1Instance, t2: t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass.positional(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass.positional(t1Instance, t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass.fNamed(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass.fNamed(t1Instance, t2: t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass.fPositional(t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
new ArgumentsBindingClass.fPositional(t1Instance, t0Instance);
// ^^^^^^^^^^
// [analyzer] unspecified
// [cfe] unspecified
}