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

Side by Side Diff: chrome/installer/util/work_item_unittest.cc

Issue 1882923003: Add best-effort/allow rollback flags on WorkItem. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@simple_list_tests
Patch Set: self review Created 4 years, 7 months 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
OLDNEW
(Empty)
1 // Copyright 2016 The Chromium Authors. All rights reserved.
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 "chrome/installer/util/work_item.h"
6
7 #include "testing/gmock/include/gmock/gmock.h"
8 #include "testing/gtest/include/gtest/gtest.h"
9
10 namespace {
11
12 class MockWorkItem : public WorkItem {
13 public:
14 MOCK_METHOD0(DoImpl, bool());
15 MOCK_METHOD0(RollbackImpl, void());
16 };
17
18 using StrictMockWorkItem = testing::StrictMock<MockWorkItem>;
19 using testing::Return;
20
21 } // namespace
22
23 // Verify that Do() calls DoImpl() and returns its return value for a
24 // non-best-effort WorkItem.
25 TEST(WorkItemTest, Do) {
26 {
27 StrictMockWorkItem item_success;
28 item_success.set_best_effort(false);
29 EXPECT_FALSE(item_success.best_effort());
grt (UTC plus 2) 2016/05/06 18:39:13 rather than checking that the setter worked in eac
fdoray 2016/05/10 18:35:32 Done.
30 EXPECT_CALL(item_success, DoImpl()).WillOnce(Return(true));
31 EXPECT_TRUE(item_success.Do());
32 }
33
34 {
35 StrictMockWorkItem item_failure;
36 item_failure.set_best_effort(false);
37 EXPECT_FALSE(item_failure.best_effort());
38 EXPECT_CALL(item_failure, DoImpl()).WillOnce(Return(false));
39 EXPECT_FALSE(item_failure.Do());
40 }
41 }
42
43 // Verify that Do() calls DoImpl() and returns true for a best-effort WorkItem.
44 TEST(WorkItemTest, DoBestEffort) {
45 {
46 StrictMockWorkItem item_success;
47 item_success.set_best_effort(true);
48 EXPECT_TRUE(item_success.best_effort());
49 EXPECT_CALL(item_success, DoImpl()).WillOnce(Return(true));
50 EXPECT_TRUE(item_success.Do());
51 }
52
53 {
54 StrictMockWorkItem item_failure;
55 item_failure.set_best_effort(true);
56 EXPECT_TRUE(item_failure.best_effort());
57 EXPECT_CALL(item_failure, DoImpl()).WillOnce(Return(false));
58 EXPECT_TRUE(item_failure.Do());
59 testing::Mock::VerifyAndClearExpectations(&item_failure);
60 }
61 }
62
63 // Verify that Rollback() calls RollbackImpl() for a WorkItem with rollback
64 // enabled.
65 TEST(WorkItemTest, Rollback) {
66 StrictMockWorkItem item;
67 item.set_rollback_enabled(true);
68 EXPECT_TRUE(item.rollback_enabled());
69
70 {
71 testing::InSequence s;
72 EXPECT_CALL(item, DoImpl()).WillOnce(Return(true));
73 EXPECT_CALL(item, RollbackImpl());
74 }
75
76 item.Do();
77 item.Rollback();
78 }
79
80 // Verify that Rollback() doesn't call RollbackImpl() for a WorkItem with
81 // rollback disabled.
82 TEST(WorkItemTest, RollbackNotAllowed) {
83 StrictMockWorkItem item;
84 item.set_rollback_enabled(false);
85 EXPECT_FALSE(item.rollback_enabled());
86
87 EXPECT_CALL(item, DoImpl()).WillOnce(Return(true));
88
89 item.Do();
90 item.Rollback();
91 }
92
93 // Verify that the default value of the "best-effort" flag is false.
94 TEST(WorkItemTest, BestEffortDefaultValue) {
95 EXPECT_FALSE(MockWorkItem().best_effort());
96 }
97
98 // Verify that the default value of the "enable rollback" flag is true.
99 TEST(WorkItemTest, EnableRollbackDefaultValue) {
100 EXPECT_TRUE(MockWorkItem().rollback_enabled());
101 }
OLDNEW
« chrome/installer/util/work_item_list.cc ('K') | « chrome/installer/util/work_item_mocks.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698