| // test data |
| var testThreshold = 20; |
| |
| var expectedTimes = new Array(); |
| |
| function match_entries(entries, index) |
| { |
| var entry = entries[index]; |
| var match = self.performance.getEntriesByName("mark")[index]; |
| assert_equals(entry.name, match.name, "entry.name"); |
| assert_equals(entry.startTime, match.startTime, "entry.startTime"); |
| assert_equals(entry.entryType, match.entryType, "entry.entryType"); |
| assert_equals(entry.duration, match.duration, "entry.duration"); |
| } |
| |
| function filter_entries_by_type(entryList, entryType) |
| { |
| var testEntries = new Array(); |
| |
| // filter entryList |
| for (var i in entryList) |
| { |
| if (entryList[i].entryType == entryType) |
| { |
| testEntries.push(entryList[i]); |
| } |
| } |
| |
| return testEntries; |
| } |
| |
| test(function () { |
| // create first mark |
| self.performance.mark("mark"); |
| |
| expectedTimes[0] = self.performance.now(); |
| |
| entries = self.performance.getEntriesByName("mark"); |
| assert_equals(entries.length, 1); |
| }, "Entry 0 is properly created"); |
| |
| test(function () { |
| // create second, duplicate mark |
| self.performance.mark("mark"); |
| |
| expectedTimes[1] = self.performance.now(); |
| |
| entries = self.performance.getEntriesByName("mark"); |
| assert_equals(entries.length, 2); |
| |
| }, "Entry 1 is properly created"); |
| |
| function test_mark(index) { |
| test(function () { |
| entries = self.performance.getEntriesByName("mark"); |
| assert_equals(entries[index].name, "mark", "Entry has the proper name"); |
| }, "Entry " + index + " has the proper name"); |
| |
| test(function () { |
| entries = self.performance.getEntriesByName("mark"); |
| assert_approx_equals(entries[index].startTime, expectedTimes[index], testThreshold); |
| }, "Entry " + index + " startTime is approximately correct (up to " + testThreshold + |
| "ms difference allowed)"); |
| |
| test(function () { |
| entries = self.performance.getEntriesByName("mark"); |
| assert_equals(entries[index].entryType, "mark"); |
| }, "Entry " + index + " has the proper entryType"); |
| |
| test(function () { |
| entries = self.performance.getEntriesByName("mark"); |
| assert_equals(entries[index].duration, 0); |
| }, "Entry " + index + " duration == 0"); |
| |
| test(function () { |
| entries = self.performance.getEntriesByName("mark", "mark"); |
| assert_equals(entries[index].name, "mark"); |
| }, "getEntriesByName(\"mark\", \"mark\")[" + index + "] returns an " + |
| "object containing a \"mark\" mark"); |
| |
| test(function () { |
| entries = self.performance.getEntriesByName("mark", "mark"); |
| match_entries(entries, index); |
| }, "The mark returned by getEntriesByName(\"mark\", \"mark\")[" + index |
| + "] matches the mark returned by " + |
| "getEntriesByName(\"mark\")[" + index + "]"); |
| |
| test(function () { |
| entries = filter_entries_by_type(self.performance.getEntries(), "mark"); |
| assert_equals(entries[index].name, "mark"); |
| }, "getEntries()[" + index + "] returns an " + |
| "object containing a \"mark\" mark"); |
| |
| test(function () { |
| entries = filter_entries_by_type(self.performance.getEntries(), "mark"); |
| match_entries(entries, index); |
| }, "The mark returned by getEntries()[" + index |
| + "] matches the mark returned by " + |
| "getEntriesByName(\"mark\")[" + index + "]"); |
| |
| test(function () { |
| entries = self.performance.getEntriesByType("mark"); |
| assert_equals(entries[index].name, "mark"); |
| }, "getEntriesByType(\"mark\")[" + index + "] returns an " + |
| "object containing a \"mark\" mark"); |
| |
| test(function () { |
| entries = self.performance.getEntriesByType("mark"); |
| match_entries(entries, index); |
| }, "The mark returned by getEntriesByType(\"mark\")[" + index |
| + "] matches the mark returned by " + |
| "getEntriesByName(\"mark\")[" + index + "]"); |
| |
| } |
| |
| for (var i = 0; i < expectedTimes.length; i++) { |
| test_mark(i); |
| } |