| 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
 | if (window.jstestdriver) {
  jstd = jstestdriver;
  dump = bind(jstd.console, jstd.console.log);
}
function time(fn) {
  var count = 1,
      targetTime = 500,
      start = new Date().getTime(),
      stop = start + targetTime,
      elapsed,
      end,
      iterations,
      pad = angularFilter.number;
  // do one iteration to guess how long it will take
  fn();
  while((end=new Date().getTime()) < stop ){
    // how much time has elapsed since we started the test
    elapsed = (end-start) || 1;
    // guess how many more iterations we need before we reach
    // the time limit. We do this so that we spend most of our
    // time in tight loop
    iterations = Math.ceil(
        // how much more time we need
        (targetTime - elapsed)
        /
        2 // to prevent overrun guess low
        /
        // this is how much the cost is so far per iteration
        (elapsed / count)
      );
    count += iterations;
    while(iterations--) {
      fn();
    }
  }
  elapsed = end - start;
  return {
    count: count,
    total: elapsed,
    time: elapsed / count,
    name: fn.name,
    msg: '' + pad(elapsed / count, 3)
      + ' ms [ ' + pad(1 / elapsed * count * 1000, 0) + ' ops/sec ] '
      + '(' + elapsed + ' ms/' + count + ')'
  };
}
function perf() {
  var log = [],
      summary = [],
      i,
      baseline,
      pad = angularFilter.number;
  for (i = 0; i < arguments.length; i++) {
    var fn = arguments[i];
    var info = time(fn);
    if (baseline === undefined) baseline = info.time;
    summary.push(info.name + ': ' + pad(baseline / info.time, 2) + ' X');
    log.push('\n        ' + info.name + ': ' + info.msg);
  }
  log.unshift(summary.join(' - '));
  dump(log.join(' '));
}
 |