普通文本  |  66行  |  2.16 KB

// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "ppapi/tests/test_trace_event.h"

#include "ppapi/cpp/module.h"
#include "ppapi/tests/testing_instance.h"

REGISTER_TEST_CASE(TraceEvent);

TestTraceEvent::TestTraceEvent(TestingInstance* instance)
    : TestCase(instance),
      interface_(NULL) {
}

bool TestTraceEvent::Init() {
  interface_ = static_cast<const PPB_Trace_Event_Dev*>(
      pp::Module::Get()->GetBrowserInterface(PPB_TRACE_EVENT_DEV_INTERFACE));
  return !!interface_;
}

void TestTraceEvent::RunTests(const std::string& filter) {
  RUN_TEST(Smoke, filter);
  RUN_TEST(SmokeWithTimestamps, filter);
  RUN_TEST(Clock, filter);
}

std::string TestTraceEvent::TestSmoke() {
  // This test does not verify the log message actually reaches dev tracing, but
  // it does test that the interface exists and that it can be called without
  // crashing.
  const void* cat_enabled = interface_->GetCategoryEnabled("bar");
  interface_->AddTraceEvent('B', cat_enabled, "foo", 0, 0, NULL, NULL, NULL, 0);
  interface_->AddTraceEvent('E', cat_enabled, "foo", 0, 0, NULL, NULL, NULL, 0);
  PASS();
}

std::string TestTraceEvent::TestSmokeWithTimestamps() {
  // This test does not verify the log message actually reaches dev tracing, but
  // it does test that the interface exists and that it can be called without
  // crashing.
  const void* cat_enabled = interface_->GetCategoryEnabled("bar");
  interface_->AddTraceEventWithThreadIdAndTimestamp(
    'B', cat_enabled, "foo", 0, 0, 42, 0, NULL, NULL, NULL, 0);
  interface_->AddTraceEventWithThreadIdAndTimestamp(
    'B', cat_enabled, "foo", 0, 1, 43, 0, NULL, NULL, NULL, 0);
  interface_->AddTraceEventWithThreadIdAndTimestamp(
    'E', cat_enabled, "foo", 0, 0, 44, 0, NULL, NULL, NULL, 0);
  interface_->AddTraceEventWithThreadIdAndTimestamp(
    'E', cat_enabled, "foo", 0, 1, 45, 0, NULL, NULL, NULL, 0);
  PASS();
}

std::string TestTraceEvent::TestClock() {
  int64_t last = interface_->Now();

  for(int i=0; i<5; ++i){
    int64_t next = interface_->Now();
    ASSERT_LE(last, next);
    last = next;
  }

  PASS();
}