// 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) { 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);