Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2017 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 "chromeos/dbus/fake_media_analytics_client.h" | |
| 6 | |
| 7 #include "base/bind.h" | |
| 8 #include "base/logging.h" | |
| 9 #include "base/threading/thread_task_runner_handle.h" | |
| 10 | |
| 11 namespace chromeos { | |
| 12 | |
| 13 FakeMediaAnalyticsClient::FakeMediaAnalyticsClient() | |
| 14 : process_running_(false), weak_ptr_factory_(this) { | |
| 15 current_state_.set_status(mri::State::UNINITIALIZED); | |
| 16 } | |
| 17 | |
| 18 FakeMediaAnalyticsClient::~FakeMediaAnalyticsClient() {} | |
| 19 | |
| 20 void FakeMediaAnalyticsClient::FireMediaPerceptionEvent( | |
| 21 mri::MediaPerception media_perception) { | |
| 22 if (!process_running_) { | |
| 23 LOG(ERROR) << "Fake media analytics process not running."; | |
|
tbarzic
2017/05/11 16:55:55
maybe return false here, so tests can assert the e
Luke Sorenson
2017/05/11 18:16:47
Done.
| |
| 24 return; | |
| 25 } | |
| 26 base::ThreadTaskRunnerHandle::Get()->PostTask( | |
| 27 FROM_HERE, base::Bind(&FakeMediaAnalyticsClient::OnMediaPerception, | |
| 28 weak_ptr_factory_.GetWeakPtr(), media_perception)); | |
| 29 } | |
| 30 | |
| 31 void FakeMediaAnalyticsClient::SetDiagnostics(mri::Diagnostics diagnostics) { | |
| 32 diagnostics_ = diagnostics; | |
| 33 } | |
| 34 | |
| 35 void FakeMediaAnalyticsClient::Init(dbus::Bus* bus) {} | |
| 36 | |
| 37 void FakeMediaAnalyticsClient::SetMediaPerceptionSignalHandler( | |
| 38 const MediaPerceptionSignalHandler& handler) { | |
| 39 media_perception_signal_handler_ = handler; | |
| 40 } | |
| 41 | |
| 42 void FakeMediaAnalyticsClient::ClearMediaPerceptionSignalHandler() { | |
| 43 media_perception_signal_handler_.Reset(); | |
| 44 } | |
| 45 | |
| 46 void FakeMediaAnalyticsClient::GetState(const StateCallback& callback) { | |
| 47 if (!process_running_) { | |
| 48 LOG(ERROR) << "Fake media analytics process not running."; | |
|
tbarzic
2017/05/11 16:55:55
I'd consider removing these logs
Luke Sorenson
2017/05/11 18:16:47
Done.
| |
| 49 callback.Run(false, current_state_); | |
| 50 return; | |
| 51 } | |
| 52 base::ThreadTaskRunnerHandle::Get()->PostTask( | |
| 53 FROM_HERE, base::Bind(&FakeMediaAnalyticsClient::OnState, | |
| 54 weak_ptr_factory_.GetWeakPtr(), callback)); | |
| 55 } | |
| 56 | |
| 57 void FakeMediaAnalyticsClient::SetState(const mri::State& state, | |
| 58 const StateCallback& callback) { | |
| 59 if (!process_running_) { | |
| 60 LOG(ERROR) << "Fake media analytics process not running."; | |
| 61 callback.Run(false, current_state_); | |
| 62 return; | |
| 63 } | |
| 64 DCHECK(state.has_status()) << "Trying to set state without status."; | |
| 65 DCHECK(state.status() == mri::State::SUSPENDED || | |
| 66 state.status() == mri::State::RUNNING) | |
| 67 << "Trying set state to something other than RUNNING or SUSPENDED."; | |
| 68 current_state_ = state; | |
| 69 base::ThreadTaskRunnerHandle::Get()->PostTask( | |
| 70 FROM_HERE, base::Bind(&FakeMediaAnalyticsClient::OnState, | |
| 71 weak_ptr_factory_.GetWeakPtr(), callback)); | |
| 72 } | |
| 73 | |
| 74 void FakeMediaAnalyticsClient::OnState(const StateCallback& callback) { | |
| 75 callback.Run(true, current_state_); | |
| 76 } | |
| 77 | |
| 78 void FakeMediaAnalyticsClient::GetDiagnostics( | |
| 79 const DiagnosticsCallback& callback) { | |
| 80 if (!process_running_) { | |
| 81 LOG(ERROR) << "Fake media analytics process not running."; | |
| 82 callback.Run(false, mri::Diagnostics()); | |
| 83 return; | |
| 84 } | |
| 85 base::ThreadTaskRunnerHandle::Get()->PostTask( | |
| 86 FROM_HERE, base::Bind(&FakeMediaAnalyticsClient::OnGetDiagnostics, | |
| 87 weak_ptr_factory_.GetWeakPtr(), callback)); | |
| 88 } | |
| 89 | |
| 90 void FakeMediaAnalyticsClient::OnGetDiagnostics( | |
| 91 const DiagnosticsCallback& callback) { | |
| 92 callback.Run(true, diagnostics_); | |
| 93 } | |
| 94 | |
| 95 void FakeMediaAnalyticsClient::OnMediaPerception( | |
| 96 mri::MediaPerception media_perception) { | |
| 97 if (media_perception_signal_handler_.is_null()) { | |
|
tbarzic
2017/05/11 16:55:55
nit: I prefer one line ifs without {}
Luke Sorenson
2017/05/11 18:16:47
Done.
| |
| 98 return; | |
| 99 } | |
| 100 media_perception_signal_handler_.Run(media_perception); | |
| 101 } | |
| 102 | |
| 103 } // namespace chromeos | |
| OLD | NEW |