OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "ash/test/tray_cast_test_api.h" | 5 #include "ash/test/tray_cast_test_api.h" |
6 | 6 |
| 7 #include "ash/cast_config_delegate.h" |
| 8 #include "ash/shell.h" |
7 #include "ash/system/tray/system_tray.h" | 9 #include "ash/system/tray/system_tray.h" |
| 10 #include "ash/system/tray/system_tray_delegate.h" |
8 #include "ui/views/view.h" | 11 #include "ui/views/view.h" |
9 | 12 |
10 namespace ash { | 13 namespace ash { |
11 | 14 |
12 TrayCastTestAPI::TrayCastTestAPI(TrayCast* tray_cast) : tray_cast_(tray_cast) {} | 15 TrayCastTestAPI::TrayCastTestAPI(TrayCast* tray_cast) : tray_cast_(tray_cast) {} |
13 | 16 |
14 TrayCastTestAPI::~TrayCastTestAPI() {} | 17 TrayCastTestAPI::~TrayCastTestAPI() {} |
15 | 18 |
16 bool TrayCastTestAPI::IsTrayInitialized() const { | 19 bool TrayCastTestAPI::IsTrayInitialized() const { |
17 return tray_cast_->default_ != nullptr; | 20 return tray_cast_->default_ != nullptr; |
(...skipping 21 matching lines...) Expand all Loading... |
39 | 42 |
40 void TrayCastTestAPI::StopCast() { | 43 void TrayCastTestAPI::StopCast() { |
41 return tray_cast_->StopCastForTest(); | 44 return tray_cast_->StopCastForTest(); |
42 } | 45 } |
43 | 46 |
44 void TrayCastTestAPI::OnCastingSessionStartedOrStopped(bool is_casting) { | 47 void TrayCastTestAPI::OnCastingSessionStartedOrStopped(bool is_casting) { |
45 tray_cast_->OnCastingSessionStartedOrStopped(is_casting); | 48 tray_cast_->OnCastingSessionStartedOrStopped(is_casting); |
46 } | 49 } |
47 | 50 |
48 void TrayCastTestAPI::ReleaseConfigCallbacks() { | 51 void TrayCastTestAPI::ReleaseConfigCallbacks() { |
49 tray_cast_->device_update_subscription_.reset(); | 52 tray_cast_->added_observer_ = false; |
| 53 |
| 54 if (ash::Shell::GetInstance() && |
| 55 ash::Shell::GetInstance()->system_tray_delegate()) { |
| 56 ash::Shell::GetInstance() |
| 57 ->system_tray_delegate() |
| 58 ->GetCastConfigDelegate() |
| 59 ->RemoveObserver(tray_cast_); |
| 60 } |
50 } | 61 } |
51 | 62 |
52 bool TrayCastTestAPI::IsViewDrawn(TrayCast::ChildViewId id) const { | 63 bool TrayCastTestAPI::IsViewDrawn(TrayCast::ChildViewId id) const { |
53 const views::View* view = tray_cast_->GetDefaultView()->GetViewByID(id); | 64 const views::View* view = tray_cast_->GetDefaultView()->GetViewByID(id); |
54 return view != nullptr && view->IsDrawn(); | 65 return view != nullptr && view->IsDrawn(); |
55 } | 66 } |
56 | 67 |
57 } // namespace ash | 68 } // namespace ash |
OLD | NEW |