Chromium Code Reviews| Index: test/mjsunit/es7/object-observe-debug-event.js |
| diff --git a/test/mjsunit/es7/object-observe-debug-event.js b/test/mjsunit/es7/object-observe-debug-event.js |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..c33a1315cb2f17196a0a1f0a623a93a5a3dff164 |
| --- /dev/null |
| +++ b/test/mjsunit/es7/object-observe-debug-event.js |
| @@ -0,0 +1,52 @@ |
| +// Copyright 2014 the V8 project authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +// Flags: --expose-debug-as debug |
| + |
| +Debug = debug.Debug; |
| + |
| +var base_id = -1; |
| +var exception = null; |
| +var expected = [ |
| + "enqueue #1", |
| + "willHandle #1", |
| + "didHandle #1", |
| +]; |
| + |
| +function assertLog(msg) |
| +{ |
|
Yang
2014/07/03 14:19:44
move this bracket to the previous line please.
|
| + print(msg); |
| + assertTrue(expected.length > 0); |
| + assertEquals(expected.shift(), msg); |
| + if (!expected.length) { |
| + Debug.setListener(null); |
| + } |
| +} |
| + |
| +function listener(event, exec_state, event_data, data) { |
| + if (event != Debug.DebugEvent.AsyncTaskEvent) return; |
| + try { |
| + if (base_id < 0) |
| + base_id = event_data.id(); |
| + var id = event_data.id() - base_id + 1; |
| + assertEquals("Object.observe", event_data.name()); |
| + assertLog(event_data.type() + " #" + id); |
| + } catch (e) { |
| + print(e + e.stack) |
| + exception = e; |
| + } |
| +} |
| + |
| +Debug.setListener(listener); |
| + |
| +var obj = {}; |
| +Object.observe(obj, function(changes) { |
| + print(change.type + " " + change.name + " " + change.oldValue); |
| +}); |
| + |
| +obj.foo = 1; |
| +obj.zoo = 2; |
| +obj.foo = 3; |
| + |
| +assertNull(exception); |