aboutsummaryrefslogtreecommitdiff
path: root/contexts/data/lib/closure-library/closure/goog/debug/logbuffer_test.html
blob: d01b7bed69e20b336e9bd443ac93bd790a2fd32d (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
<!DOCTYPE html>
<html>
<!--
Copyright 2010 The Closure Library Authors. All Rights Reserved.

Use of this source code is governed by the Apache License, Version 2.0.
See the COPYING file for details.
-->
<head>
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Closure Unit Tests - goog.debug.LogBuffer</title>
<script src="../base.js"></script>
<script>
  goog.require('goog.debug.LogRecord');
  goog.require('goog.debug.LogBuffer');
  goog.require('goog.debug.Logger');
  goog.require('goog.testing.jsunit');
</script>
</head>
<body>
<script>

var DUMMY_LEVELS = [
    goog.debug.Logger.Level.INFO,
    goog.debug.Logger.Level.WARNING,
    goog.debug.Logger.Level.SEVERE];
var DUMMY_MESSAGES = ['a', 'b', 'c'];
var DUMMY_NAMES = ['X', 'Y', 'Z'];

var buffer;
var dummyIndex = 0;

function setUp() {
  goog.debug.LogBuffer.CAPACITY = 4;
  goog.debug.LogBuffer.instance_ = null;
  buffer = goog.debug.LogBuffer.getInstance();
}

function verifyRecord(expectedIndex, record) {
  var index = expectedIndex % DUMMY_MESSAGES.length;
  var message = DUMMY_MESSAGES[index];
  var level = DUMMY_LEVELS[index];
  var name = DUMMY_NAMES[index];
  assertEquals('Wrong level for record ' + expectedIndex, level,
      record.getLevel());
  assertEquals('Wrong message for record ' + expectedIndex, message,
      record.getMessage());
  assertEquals('Wrong name for record ' + expectedIndex, name,
      record.getLoggerName());
}

function addAndVerifyRecord() {
  var index = dummyIndex % DUMMY_MESSAGES.length;
  var level = DUMMY_LEVELS[index];
  var message = DUMMY_MESSAGES[index];
  var name = DUMMY_NAMES[index];
  var record = buffer.addRecord(level, message, name);
  verifyRecord(dummyIndex, record);
  dummyIndex++;
}

function addSomeRecords(howMany) {
  for (var i = 0; i < howMany; i++) {
    addAndVerifyRecord();
  }
}

function testAddRecord() {
  addSomeRecords(goog.debug.LogBuffer.CAPACITY * 3);
}

function testIsFull() {
  assertFalse('Should not be full.', buffer.isFull_);
  addSomeRecords(goog.debug.LogBuffer.CAPACITY * 1.5);
  assertTrue('Should be full.', buffer.isFull_);
  buffer.clear();
  assertFalse('Should not be full after clear().', buffer.isFull_);
  addSomeRecords(goog.debug.LogBuffer.CAPACITY - 1);
  assertFalse('Should not be full but almost full.', buffer.isFull_);
}

function testForEachRecord() {
  // Test with it half full.
  var howMany1 = goog.debug.LogBuffer.CAPACITY / 2;
  addSomeRecords(howMany1);
  var counter1 = 0;
  buffer.forEachRecord(function(record) {
    verifyRecord(counter1++, record);
  });
  assertEquals('Wrong number of records when half full.', howMany1, counter1);

  // Test with it full.
  var howMany2 = goog.debug.LogBuffer.CAPACITY;
  addSomeRecords(howMany2);
  var index = counter1;
  buffer.forEachRecord(function(record) {
    verifyRecord(index++, record);
  });
  assertEquals('Wrong number of records when full.', howMany1 + howMany2,
      index);
}

</script>
</body>
</html>