mirror of
https://github.com/dart-lang/sdk
synced 2024-09-16 03:47:13 +00:00
5b391babbf
* Move each section of the original file into a new test file. * Remove the use of multi-tests entirely to avoid running ~90% of these tests 5 times each. * async_star2_test/02 became cancel_while_paused_at_yield_test.dart. I will approve the existing failures of this newly named test. * All other sections marked as multi-tests actually appear to be passing on all configurations so they didn't need to be broken out. * Cleanup now unnecessary lines in the status file. Change-Id: I5d62a35ffff1248532fa9ffade1a7259f83814da Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/130890 Commit-Queue: Nicholas Shahan <nshahan@google.com> Reviewed-by: Bob Nystrom <rnystrom@google.com>
178 lines
2.9 KiB
Dart
178 lines
2.9 KiB
Dart
// Copyright (c) 2020, 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:async_helper/async_minitest.dart';
|
|
|
|
import 'utils.dart';
|
|
|
|
main() {
|
|
test('local variable', () {
|
|
f() async* {
|
|
var x = 42;
|
|
yield x;
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('constant variable', () {
|
|
f() async* {
|
|
const x = 42;
|
|
yield x;
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('function call', () {
|
|
g() => 42;
|
|
f() async* {
|
|
yield g();
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('unary operator', () {
|
|
f() async* {
|
|
var x = -42;
|
|
yield -x;
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('binary operator', () {
|
|
f() async* {
|
|
var x = 21;
|
|
yield x + x;
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('ternary operator', () {
|
|
f() async* {
|
|
var x = 21;
|
|
yield x == 21 ? x + x : x;
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('suffix post-increment', () {
|
|
f() async* {
|
|
var x = 42;
|
|
yield x++;
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('suffix pre-increment', () {
|
|
f() async* {
|
|
var x = 41;
|
|
yield ++x;
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('assignment', () {
|
|
f() async* {
|
|
var x = 37;
|
|
yield x = 42;
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('assignment op', () {
|
|
f() async* {
|
|
var x = 41;
|
|
yield x += 1;
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('await', () {
|
|
f() async* {
|
|
yield await Future.value(42);
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('index operator', () {
|
|
f() async* {
|
|
var x = [42];
|
|
yield x[0];
|
|
}
|
|
|
|
return expectList(f(), [42]);
|
|
});
|
|
|
|
test('function expression block', () {
|
|
var o = Object();
|
|
f() async* {
|
|
yield () {
|
|
return o;
|
|
};
|
|
}
|
|
|
|
return f().first.then((v) {
|
|
expect(v(), same(o));
|
|
});
|
|
});
|
|
|
|
test('function expression arrow', () {
|
|
var o = Object();
|
|
f() async* {
|
|
yield () => o;
|
|
}
|
|
|
|
return f().first.then((v) {
|
|
expect(v(), same(o));
|
|
});
|
|
});
|
|
|
|
test('function expression block async', () {
|
|
var o = Object();
|
|
f() async* {
|
|
yield () async {
|
|
return o;
|
|
};
|
|
}
|
|
|
|
return f().first.then((v) => v()).then((v) {
|
|
expect(v, same(o));
|
|
});
|
|
});
|
|
|
|
test('function expression arrow async', () {
|
|
var o = Object();
|
|
f() async* {
|
|
yield () async => o;
|
|
}
|
|
|
|
return f().first.then((v) => v()).then((v) {
|
|
expect(v, same(o));
|
|
});
|
|
});
|
|
|
|
test('function expression block async*', () {
|
|
var o = Object();
|
|
f() async* {
|
|
yield () async* {
|
|
yield o;
|
|
};
|
|
}
|
|
|
|
return f().first.then((v) => v().first).then((v) {
|
|
expect(v, same(o));
|
|
});
|
|
});
|
|
}
|