Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(341)

Side by Side Diff: base/callback_helpers_unittest.cc

Issue 2513363003: repro for crbug.com/663886
Patch Set: Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « base/callback_helpers.cc ('k') | base/callback_internal.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 __attribute__((visibility("default"))) void Increment(int* value) {
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "base/callback_helpers.h"
6
7 #include "base/bind.h"
8 #include "base/callback.h"
9 #include "testing/gtest/include/gtest/gtest.h"
10
11 namespace {
12
13 void Increment(int* value) {
14 (*value)++; 2 (*value)++;
15 } 3 }
16 4
17 TEST(CallbackHelpersTest, TestScopedClosureRunnerExitScope) { 5 class Listener {
18 int run_count = 0; 6 public:
19 { 7 Listener() : total_(0) {}
20 base::ScopedClosureRunner runner(base::Bind(&Increment, &run_count)); 8 void IncrementTotal() { total_++; }
21 EXPECT_EQ(0, run_count); 9 int total_;
22 } 10 };
23 EXPECT_EQ(1, run_count);
24 }
25 11
26 TEST(CallbackHelpersTest, TestScopedClosureRunnerRelease) { 12 void(Listener::*secret(void (Listener::*memptr)()))() { return memptr; }
27 int run_count = 0; 13 Listener* secret(Listener* l) { return l; }
28 base::Closure c;
29 {
30 base::ScopedClosureRunner runner(base::Bind(&Increment, &run_count));
31 c = runner.Release();
32 EXPECT_EQ(0, run_count);
33 }
34 EXPECT_EQ(0, run_count);
35 c.Run();
36 EXPECT_EQ(1, run_count);
37 }
38
39 TEST(CallbackHelpersTest, TestScopedClosureRunnerReplaceClosure) {
40 int run_count_1 = 0;
41 int run_count_2 = 0;
42 {
43 base::ScopedClosureRunner runner;
44 runner.ReplaceClosure(base::Bind(&Increment, &run_count_1));
45 runner.ReplaceClosure(base::Bind(&Increment, &run_count_2));
46 EXPECT_EQ(0, run_count_1);
47 EXPECT_EQ(0, run_count_2);
48 }
49 EXPECT_EQ(0, run_count_1);
50 EXPECT_EQ(1, run_count_2);
51 }
52
53 TEST(CallbackHelpersTest, TestScopedClosureRunnerRunAndReset) {
54 int run_count_3 = 0;
55 {
56 base::ScopedClosureRunner runner(base::Bind(&Increment, &run_count_3));
57 EXPECT_EQ(0, run_count_3);
58 runner.RunAndReset();
59 EXPECT_EQ(1, run_count_3);
60 }
61 EXPECT_EQ(1, run_count_3);
62 }
63
64 TEST(CallbackHelpersTest, TestScopedClosureRunnerMoveConstructor) {
65 int run_count = 0;
66 {
67 std::unique_ptr<base::ScopedClosureRunner> runner(
68 new base::ScopedClosureRunner(base::Bind(&Increment, &run_count)));
69 base::ScopedClosureRunner runner2(std::move(*runner));
70 runner.reset();
71 EXPECT_EQ(0, run_count);
72 }
73 EXPECT_EQ(1, run_count);
74 }
75
76 TEST(CallbackHelpersTest, TestScopedClosureRunnerMoveAssignment) {
77 int run_count_1 = 0;
78 int run_count_2 = 0;
79 {
80 base::ScopedClosureRunner runner(base::Bind(&Increment, &run_count_1));
81 {
82 base::ScopedClosureRunner runner2(base::Bind(&Increment, &run_count_2));
83 runner = std::move(runner2);
84 EXPECT_EQ(0, run_count_1);
85 EXPECT_EQ(0, run_count_2);
86 }
87 EXPECT_EQ(0, run_count_1);
88 EXPECT_EQ(0, run_count_2);
89 }
90 EXPECT_EQ(0, run_count_1);
91 EXPECT_EQ(1, run_count_2);
92 }
93
94 } // namespace
OLDNEW
« no previous file with comments | « base/callback_helpers.cc ('k') | base/callback_internal.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698