diff options
author | groby@chromium.org <groby@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-08-24 15:00:33 +0000 |
---|---|---|
committer | groby@chromium.org <groby@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-08-24 15:00:33 +0000 |
commit | 285d06fced9e6778985c50778327d64f29300174 (patch) | |
tree | 62df99ebde4d3b082f5ade19a31249e55ac06ac9 /base/barrier_closure_unittest.cc | |
parent | 213fcfcf37c64ea18ebe2adc82a05c469a479d39 (diff) | |
download | chromium_src-285d06fced9e6778985c50778327d64f29300174.zip chromium_src-285d06fced9e6778985c50778327d64f29300174.tar.gz chromium_src-285d06fced9e6778985c50778327d64f29300174.tar.bz2 |
Add a BarrierClosure.
Chromium frequently needs to execute a "final" closure once a given
number of other callbacks have run. BarrierClosure encapsulates that
logic while staying as light-weight as possible.
TBR=gbillock@chromium.org, willchan@chromium.org
BUG=none
Review URL: https://chromiumcodereview.appspot.com/22859056
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@219446 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/barrier_closure_unittest.cc')
-rw-r--r-- | base/barrier_closure_unittest.cc | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/base/barrier_closure_unittest.cc b/base/barrier_closure_unittest.cc new file mode 100644 index 0000000..ab05cb8 --- /dev/null +++ b/base/barrier_closure_unittest.cc @@ -0,0 +1,36 @@ +// 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 "base/barrier_closure.h" + +#include "base/bind.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace { + +void Increment(int* count) { (*count)++; } + +TEST(BarrierClosureTest, RunImmediatelyForZeroClosures) { + int count = 0; + base::Closure doneClosure(base::Bind(&Increment, base::Unretained(&count))); + + base::Closure barrierClosure = base::BarrierClosure(0, doneClosure); + EXPECT_EQ(1, count); +} + +TEST(BarrierClosureTest, RunAfterNumClosures) { + int count = 0; + base::Closure doneClosure(base::Bind(&Increment, base::Unretained(&count))); + + base::Closure barrierClosure = base::BarrierClosure(2, doneClosure); + EXPECT_EQ(0, count); + + barrierClosure.Run(); + EXPECT_EQ(0, count); + + barrierClosure.Run(); + EXPECT_EQ(1, count); +} + +} // namespace |