summaryrefslogtreecommitdiffstats
path: root/devtools/client/framework/test/metrics/browser_metrics_pool.js
blob: 1b2231fef96b04c549e2029264003d8b6e8d4c12 (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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/* Any copyright is dedicated to the Public Domain.
 * http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

const {
  DevToolsServer,
} = require("resource://devtools/server/devtools-server.js");
const { Pool } = require("resource://devtools/shared/protocol.js");

// Test parameters
const ROOT_POOLS = 100;
const POOL_DEPTH = 10;
const POOLS_BY_LEVEL = 100;
// Number of Pools that will be added once the environment is set up.
const ADDITIONAL_POOLS = 5000;

add_task(async function () {
  DevToolsServer.init();
  DevToolsServer.registerAllActors();
  const conn = DevToolsServer.connectPipe()._serverConnection;

  info("Add multiple Pools to the connection");
  const pools = setupTestEnvironment(conn);

  let sumResult = 0;

  info("Test how long it takes to manage new Pools");
  let start = performance.now();
  let parentPool = pools[pools.length - 1];
  const newPools = [];
  for (let i = 0; i < ADDITIONAL_POOLS; i++) {
    const pool = new Pool(conn, `${parentPool.label}-${i}`);
    newPools.push(pool);
    parentPool.manage(pool);
  }
  const manageResult = performance.now() - start;
  sumResult += manageResult;

  info("Test how long it takes to manage Pools that were already managed");
  start = performance.now();
  parentPool = pools[pools.length - 2];
  for (const pool of newPools) {
    parentPool.manage(pool);
  }
  const manageAlreadyManagedResult = performance.now() - start;
  sumResult += manageAlreadyManagedResult;

  info("Test how long it takes to unmanage Pools");
  start = performance.now();
  for (const pool of newPools) {
    parentPool.unmanage(pool);
  }
  const unmanageResult = performance.now() - start;
  sumResult += unmanageResult;

  info("Test how long it takes to destroy all the Pools");
  start = performance.now();
  conn.onTransportClosed();
  const destroyResult = performance.now() - start;
  sumResult += destroyResult;

  const PERFHERDER_DATA = {
    framework: {
      name: "devtools",
    },
    suites: [
      {
        name: "server.pool",
        value: sumResult,
        subtests: [
          {
            name: "server.pool.manage",
            value: manageResult,
          },
          {
            name: "server.pool.manage-already-managed",
            value: manageAlreadyManagedResult,
          },
          {
            name: "server.pool.unmanage",
            value: unmanageResult,
          },
          {
            name: "server.pool.destroy",
            value: destroyResult,
          },
        ],
      },
    ],
  };
  info("PERFHERDER_DATA: " + JSON.stringify(PERFHERDER_DATA));
});

// Some Pool operations might be impacted by the number of existing pools in a connection,
// so it's important to have a sizeable number of Pools in order to assert Pool performances.
function setupTestEnvironment(conn) {
  const pools = [];
  for (let i = 0; i < ROOT_POOLS; i++) {
    const rootPool = new Pool(conn, "root-pool-" + i);
    pools.push(rootPool);
    let parent = rootPool;
    for (let j = 0; j < POOL_DEPTH; j++) {
      const intermediatePool = new Pool(conn, `pool-${i}-${j}`);
      pools.push(intermediatePool);
      parent.manage(intermediatePool);

      for (let k = 0; k < POOLS_BY_LEVEL; k++) {
        const pool = new Pool(conn, `pool-${i}-${j}-${k}`);
        pools.push(pool);
        intermediatePool.manage(pool);
      }

      parent = intermediatePool;
    }
  }
  return pools;
}