summaryrefslogtreecommitdiffstats
path: root/base/barrier_closure_unittest.cc
diff options
context:
space:
mode:
authorgroby@chromium.org <groby@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-08-24 15:00:33 +0000
committergroby@chromium.org <groby@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-08-24 15:00:33 +0000
commit285d06fced9e6778985c50778327d64f29300174 (patch)
tree62df99ebde4d3b082f5ade19a31249e55ac06ac9 /base/barrier_closure_unittest.cc
parent213fcfcf37c64ea18ebe2adc82a05c469a479d39 (diff)
downloadchromium_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.cc36
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