Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(89)

Side by Side Diff: test/mjsunit/es6/debug-promises-update-status-event.js

Issue 416213004: Merge three PromiseEvent's into one. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Check new promise debug events in case of chained promises Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright 2014 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 // Flags: --expose-debug-as debug
6
7 Debug = debug.Debug;
8
9 var exception = null;
10 var promise, status, value;
11 var newPromise = 0, updatePromise = 0, counter = 0;
12
13 function listener(event, exec_state, event_data, data) {
14 if (event != Debug.DebugEvent.PromiseEvent) return;
15 if (event_data.type() == "new") {
16 newPromise = counter;
17 counter++;
18 return;
19 }
20 if (event_data.type() != "update") return;
21 try {
22 updatePromise = counter;
23 assertTrue(newPromise < updatePromise);
24 counter++;
25
26 assertTrue(event_data.promise().isPromise());
27 promise = event_data.promise().value();
28
29 status = event_data.status();
30
31 value = event_data.value().value();
32 } catch (e) {
33 print(e + e.stack);
34 exception = e;
35 }
36 }
37
38 Debug.setListener(listener);
39
40 var p1 = new Promise(function(resolve, reject) { resolve(1) });
41 assertSame(promise, p1);
42 assertEquals(status, 1);
43 assertEquals(value, 1);
44
45 var p2 = new Promise(function(resolve, reject) { reject(2) });
46 assertSame(promise, p2);
47 assertEquals(status, -1);
48 assertEquals(value, 2);
49
50 assertNull(exception);
51 Debug.setListener(null);
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698