| /* |
| * Copyright (c) 2016, 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 If f is marked sync*, then a fresh instance i implementing |
| * the built-in class Iterable is associated with the invocation and |
| * immediately returned. |
| * A Dart implementation will need to provide a specific implementation of |
| * Iterable that will be returned by sync* methods. A typical strategy would |
| * be to produce an instance of a subclass of class IterableBase defined in |
| * dart:core. The only method that needs to be added by the Dart |
| * implementation in that case is iterator. |
| * |
| * @description Check that body of sync generator function is not executed |
| * before Iterable instance is returned. |
| * |
| * @author a.semenov@unipro.ru |
| */ |
| |
| import '../../../Utils/expect.dart'; |
| |
| bool bodyExecuted = false; |
| |
| Iterable test() sync* { |
| bodyExecuted = true; |
| yield 1; |
| } |
| |
| main() { |
| for (var i = 0; i < 10; i++) { |
| test(); |
| Expect.isFalse(bodyExecuted); |
| } |
| } |