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

Side by Side Diff: blimp/client/core/contents/blimp_contents_observer_unittest.cc

Issue 2255533002: Add TabControlFeature to BlimpClientContextImpl (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Pass TabControlFeature* to BlimpContentsImpl's constructor, remove blimp contents factory Created 4 years, 4 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
1 // Copyright 2016 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "blimp/client/public/contents/blimp_contents_observer.h" 5 #include "blimp/client/public/contents/blimp_contents_observer.h"
6 6
7 #include "base/memory/ptr_util.h" 7 #include "base/memory/ptr_util.h"
8 #include "blimp/client/core/contents/blimp_contents_impl.h" 8 #include "blimp/client/core/contents/blimp_contents_impl.h"
9 #include "testing/gmock/include/gmock/gmock.h" 9 #include "testing/gmock/include/gmock/gmock.h"
10 #include "testing/gtest/include/gtest/gtest.h" 10 #include "testing/gtest/include/gtest/gtest.h"
(...skipping 12 matching lines...) Expand all
23 explicit BlimpContentsObserverTest(BlimpContents* blimp_contents) 23 explicit BlimpContentsObserverTest(BlimpContents* blimp_contents)
24 : BlimpContentsObserver(blimp_contents) {} 24 : BlimpContentsObserver(blimp_contents) {}
25 25
26 MOCK_METHOD0(OnContentsDestroyed, void()); 26 MOCK_METHOD0(OnContentsDestroyed, void());
27 27
28 private: 28 private:
29 DISALLOW_COPY_AND_ASSIGN(BlimpContentsObserverTest); 29 DISALLOW_COPY_AND_ASSIGN(BlimpContentsObserverTest);
30 }; 30 };
31 31
32 TEST(BlimpContentsObserverUnittests, ObserverDies) { 32 TEST(BlimpContentsObserverUnittests, ObserverDies) {
33 BlimpContentsImpl contents(kDummyTabId); 33 BlimpContentsImpl contents(kDummyTabId, nullptr);
34 34
35 std::unique_ptr<BlimpContentsObserver> observer = 35 std::unique_ptr<BlimpContentsObserver> observer =
36 base::MakeUnique<BlimpContentsObserverTest>(&contents); 36 base::MakeUnique<BlimpContentsObserverTest>(&contents);
37 BlimpContentsObserver* observer_ptr = observer.get(); 37 BlimpContentsObserver* observer_ptr = observer.get();
38 EXPECT_TRUE(contents.HasObserver(observer_ptr)); 38 EXPECT_TRUE(contents.HasObserver(observer_ptr));
39 observer.reset(); 39 observer.reset();
40 40
41 EXPECT_FALSE(contents.HasObserver(observer_ptr)); 41 EXPECT_FALSE(contents.HasObserver(observer_ptr));
42 } 42 }
43 43
44 TEST(BlimpContentsObserverUnittests, ContentsDies) { 44 TEST(BlimpContentsObserverUnittests, ContentsDies) {
45 std::unique_ptr<BlimpContentsObserverTest> observer; 45 std::unique_ptr<BlimpContentsObserverTest> observer;
46 46
47 std::unique_ptr<BlimpContentsImpl> contents = 47 std::unique_ptr<BlimpContentsImpl> contents =
48 base::MakeUnique<BlimpContentsImpl>(kDummyTabId); 48 base::MakeUnique<BlimpContentsImpl>(kDummyTabId, nullptr);
49 observer.reset(new BlimpContentsObserverTest(contents.get())); 49 observer.reset(new BlimpContentsObserverTest(contents.get()));
50 EXPECT_CALL(*observer, OnContentsDestroyed()).Times(1); 50 EXPECT_CALL(*observer, OnContentsDestroyed()).Times(1);
51 EXPECT_EQ(observer->blimp_contents(), contents.get()); 51 EXPECT_EQ(observer->blimp_contents(), contents.get());
52 contents.reset(); 52 contents.reset();
53 53
54 EXPECT_EQ(observer->blimp_contents(), nullptr); 54 EXPECT_EQ(observer->blimp_contents(), nullptr);
55 } 55 }
56 56
57 } // namespace 57 } // namespace
58 58
59 } // namespace client 59 } // namespace client
60 } // namespace blimp 60 } // namespace blimp
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698