summaryrefslogtreecommitdiffstats
path: root/devtools/client/canvasdebugger/test/browser_profiling-webgl.js
blob: 83009317fa6452f92e67d7dda76993cd1614ea98 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

/**
 * Tests if functions inside a single animation frame are recorded and stored
 * for a canvas context profiling.
 */

function* ifTestingSupported() {
  let currentTime = window.performance.now();
  info("Start to estimate WebGL drawArrays function.");
  var { target, front } = yield initCanvasDebuggerBackend(WEBGL_DRAW_ARRAYS);

  let navigated = once(target, "navigate");

  yield front.setup({ reload: true });
  ok(true, "The front was setup up successfully.");

  yield navigated;
  ok(true, "Target automatically navigated when the front was set up.");

  let snapshotActor = yield front.recordAnimationFrame();
  ok(snapshotActor,
    "A snapshot actor was sent after recording.");

  let animationOverview = yield snapshotActor.getOverview();
  ok(animationOverview,
    "An animation overview could be retrieved after recording.");

  let functionCalls = animationOverview.calls;
  ok(functionCalls,
    "An array of function call actors was sent after recording.");

  testFunctionCallTimestamp(functionCalls, currentTime);

  info("Check triangle and vertex counts in drawArrays()");
  is(animationOverview.primitive.tris, 5, "The count of triangles is correct.");
  is(animationOverview.primitive.vertices, 26, "The count of vertices is correct.");
  is(animationOverview.primitive.points, 4, "The count of points is correct.");
  is(animationOverview.primitive.lines, 8, "The count of lines is correct.");

  yield removeTab(target.tab);

  info("Start to estimate WebGL drawElements function.");
  var { target, front } = yield initCanvasDebuggerBackend(WEBGL_DRAW_ELEMENTS);

  navigated = once(target, "navigate");

  yield front.setup({ reload: true });
  ok(true, "The front was setup up successfully.");

  yield navigated;
  ok(true, "Target automatically navigated when the front was set up.");

  snapshotActor = yield front.recordAnimationFrame();
  ok(snapshotActor,
    "A snapshot actor was sent after recording.");
  
  animationOverview = yield snapshotActor.getOverview();
  ok(animationOverview,
    "An animation overview could be retrieved after recording.");
  
  functionCalls = animationOverview.calls;
  ok(functionCalls,
    "An array of function call actors was sent after recording.");
  
  testFunctionCallTimestamp(functionCalls, currentTime);
  
  info("Check triangle and vertex counts in drawElements()");
  is(animationOverview.primitive.tris, 5, "The count of triangles is correct.");
  is(animationOverview.primitive.vertices, 26, "The count of vertices is correct.");
  is(animationOverview.primitive.points, 4, "The count of points is correct.");
  is(animationOverview.primitive.lines, 8, "The count of lines is correct.");
  
  yield removeTab(target.tab);
  finish();
}

function testFunctionCallTimestamp(functionCalls, currentTime) {

  info("Check the timestamps of function calls");

  for ( let i = 0; i < functionCalls.length-1; i += 2 ) {
    ok( functionCalls[i].timestamp > 0, "The timestamp of the called function is larger than 0." );
    ok( functionCalls[i].timestamp < currentTime, "The timestamp has been minus the frame start time." );
    ok( functionCalls[i+1].timestamp > functionCalls[i].timestamp, "The timestamp of the called function is correct." );
  }

  yield removeTab(target.tab);
  finish();
}