| Index: base/task_scheduler/task_unittest.cc
|
| diff --git a/base/task_scheduler/task_unittest.cc b/base/task_scheduler/task_unittest.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..e6a2c518a0a5e4e5c409a261949a9bd104cb9cd6
|
| --- /dev/null
|
| +++ b/base/task_scheduler/task_unittest.cc
|
| @@ -0,0 +1,67 @@
|
| +// Copyright 2016 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/task_scheduler/task.h"
|
| +
|
| +#include "base/bind.h"
|
| +#include "base/location.h"
|
| +#include "base/task_scheduler/task_traits.h"
|
| +#include "base/time/time.h"
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +
|
| +namespace base {
|
| +namespace internal {
|
| +
|
| +// Verify that the shutdown behavior of a BLOCK_SHUTDOWN delayed task is
|
| +// adjusted to SKIP_ON_SHUTDOWN. The shutown behavior of other delayed tasks
|
| +// should not change.
|
| +TEST(TaskSchedulerTaskTest, ShutdownBehaviorChangeWithDelay) {
|
| + Task continue_on_shutdown(FROM_HERE, Bind(&DoNothing),
|
| + TaskTraits().WithShutdownBehavior(
|
| + TaskShutdownBehavior::CONTINUE_ON_SHUTDOWN),
|
| + TimeDelta::FromSeconds(1));
|
| + EXPECT_EQ(TaskShutdownBehavior::CONTINUE_ON_SHUTDOWN,
|
| + continue_on_shutdown.traits.shutdown_behavior());
|
| +
|
| + Task skip_on_shutdown(
|
| + FROM_HERE, Bind(&DoNothing),
|
| + TaskTraits().WithShutdownBehavior(TaskShutdownBehavior::SKIP_ON_SHUTDOWN),
|
| + TimeDelta::FromSeconds(1));
|
| + EXPECT_EQ(TaskShutdownBehavior::SKIP_ON_SHUTDOWN,
|
| + skip_on_shutdown.traits.shutdown_behavior());
|
| +
|
| + Task block_shutdown(
|
| + FROM_HERE, Bind(&DoNothing),
|
| + TaskTraits().WithShutdownBehavior(TaskShutdownBehavior::BLOCK_SHUTDOWN),
|
| + TimeDelta::FromSeconds(1));
|
| + EXPECT_EQ(TaskShutdownBehavior::SKIP_ON_SHUTDOWN,
|
| + block_shutdown.traits.shutdown_behavior());
|
| +}
|
| +
|
| +// Verify that the shutdown behavior of undelayed tasks is not adjusted.
|
| +TEST(TaskSchedulerTaskTest, NoShutdownBehaviorChangeNoDelay) {
|
| + Task continue_on_shutdown(FROM_HERE, Bind(&DoNothing),
|
| + TaskTraits().WithShutdownBehavior(
|
| + TaskShutdownBehavior::CONTINUE_ON_SHUTDOWN),
|
| + TimeDelta());
|
| + EXPECT_EQ(TaskShutdownBehavior::CONTINUE_ON_SHUTDOWN,
|
| + continue_on_shutdown.traits.shutdown_behavior());
|
| +
|
| + Task skip_on_shutdown(
|
| + FROM_HERE, Bind(&DoNothing),
|
| + TaskTraits().WithShutdownBehavior(TaskShutdownBehavior::SKIP_ON_SHUTDOWN),
|
| + TimeDelta());
|
| + EXPECT_EQ(TaskShutdownBehavior::SKIP_ON_SHUTDOWN,
|
| + skip_on_shutdown.traits.shutdown_behavior());
|
| +
|
| + Task block_shutdown(
|
| + FROM_HERE, Bind(&DoNothing),
|
| + TaskTraits().WithShutdownBehavior(TaskShutdownBehavior::BLOCK_SHUTDOWN),
|
| + TimeDelta());
|
| + EXPECT_EQ(TaskShutdownBehavior::BLOCK_SHUTDOWN,
|
| + block_shutdown.traits.shutdown_behavior());
|
| +}
|
| +
|
| +} // namespace internal
|
| +} // namespace base
|
|
|