| // 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 |