| // Copyright (c) 2012 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 "base/test/test_pending_task.h" | 
 |  | 
 | #include "base/bind.h" | 
 | #include "base/trace_event/trace_event.h" | 
 | #include "testing/gmock/include/gmock/gmock.h" | 
 | #include "testing/gtest/include/gtest/gtest-spi.h" | 
 | #include "testing/gtest/include/gtest/gtest.h" | 
 |  | 
 | namespace base { | 
 |  | 
 | TEST(TestPendingTaskTest, TraceSupport) { | 
 |   base::TestPendingTask task; | 
 |  | 
 |   // Check that TestPendingTask can be sent to the trace subsystem. | 
 |   TRACE_EVENT1("test", "TestPendingTask::TraceSupport", "task", task.AsValue()); | 
 |  | 
 |   // Just a basic check that the trace output has *something* in it. | 
 |   std::unique_ptr<base::trace_event::ConvertableToTraceFormat> task_value( | 
 |       task.AsValue()); | 
 |   EXPECT_THAT(task_value->ToString(), ::testing::HasSubstr("post_time")); | 
 | } | 
 |  | 
 | TEST(TestPendingTaskTest, ToString) { | 
 |   base::TestPendingTask task; | 
 |  | 
 |   // Just a basic check that ToString has *something* in it. | 
 |   EXPECT_THAT(task.ToString(), ::testing::StartsWith("TestPendingTask(")); | 
 | } | 
 |  | 
 | TEST(TestPendingTaskTest, GTestPrettyPrint) { | 
 |   base::TestPendingTask task; | 
 |  | 
 |   // Check that gtest is calling the TestPendingTask's PrintTo method. | 
 |   EXPECT_THAT(::testing::PrintToString(task), | 
 |               ::testing::StartsWith("TestPendingTask(")); | 
 |  | 
 |   // Check that pretty printing works with the gtest iostreams operator. | 
 |   EXPECT_NONFATAL_FAILURE(EXPECT_TRUE(false) << task, "TestPendingTask("); | 
 | } | 
 |  | 
 | TEST(TestPendingTaskTest, ShouldRunBefore) { | 
 |   base::TestPendingTask task_first; | 
 |   task_first.delay = base::TimeDelta::FromMilliseconds(1); | 
 |   base::TestPendingTask task_after; | 
 |   task_after.delay = base::TimeDelta::FromMilliseconds(2); | 
 |  | 
 |   EXPECT_FALSE(task_after.ShouldRunBefore(task_first)) | 
 |       << task_after << ".ShouldRunBefore(" << task_first << ")\n"; | 
 |   EXPECT_TRUE(task_first.ShouldRunBefore(task_after)) | 
 |       << task_first << ".ShouldRunBefore(" << task_after << ")\n"; | 
 | } | 
 |  | 
 | }  // namespace base |