diff options
-rw-r--r-- | chrome/browser/chromeos/cros/mock_update_library.h | 5 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/update_library.cc | 30 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/update_library.h | 10 | ||||
-rw-r--r-- | chrome/browser/ui/webui/options/about_page_handler.cc | 34 | ||||
-rw-r--r-- | chrome/browser/ui/webui/options/about_page_handler.h | 3 |
5 files changed, 57 insertions, 25 deletions
diff --git a/chrome/browser/chromeos/cros/mock_update_library.h b/chrome/browser/chromeos/cros/mock_update_library.h index 35af433..8abace9 100644 --- a/chrome/browser/chromeos/cros/mock_update_library.h +++ b/chrome/browser/chromeos/cros/mock_update_library.h @@ -18,10 +18,11 @@ class MockUpdateLibrary : public UpdateLibrary { virtual ~MockUpdateLibrary() {} MOCK_METHOD1(AddObserver, void(Observer*)); // NOLINT MOCK_METHOD1(RemoveObserver, void(Observer*)); // NOLINT + MOCK_METHOD1(HasObserver, bool(Observer*)); MOCK_METHOD2(RequestUpdateCheck, void(chromeos::UpdateCallback, void*)); MOCK_METHOD0(RebootAfterUpdate, bool(void)); - MOCK_METHOD1(SetReleaseTrack, bool(const std::string&)); - MOCK_METHOD0(GetReleaseTrack, std::string()); + MOCK_METHOD1(SetReleaseTrack, void(const std::string&)); + MOCK_METHOD2(GetReleaseTrack, void(chromeos::UpdateTrackCallback, void*)); MOCK_CONST_METHOD0(status, const Status&(void)); private: diff --git a/chrome/browser/chromeos/cros/update_library.cc b/chrome/browser/chromeos/cros/update_library.cc index 44c7d76..d4d48caf 100644 --- a/chrome/browser/chromeos/cros/update_library.cc +++ b/chrome/browser/chromeos/cros/update_library.cc @@ -36,6 +36,10 @@ class UpdateLibraryImpl : public UpdateLibrary { observers_.RemoveObserver(observer); } + bool HasObserver(Observer* observer) { + return observers_.HasObserver(observer); + } + void RequestUpdateCheck(chromeos::UpdateCallback callback, void* user_data) { if (CrosLibrary::Get()->EnsureLoaded()) chromeos::RequestUpdateCheck(callback, user_data); @@ -48,18 +52,15 @@ class UpdateLibraryImpl : public UpdateLibrary { return RebootIfUpdated(); } - bool SetReleaseTrack(const std::string& track) { - if (!CrosLibrary::Get()->EnsureLoaded()) - return false; - - return chromeos::SetTrack(track); + void SetReleaseTrack(const std::string& track) { + if (CrosLibrary::Get()->EnsureLoaded()) + chromeos::SetUpdateTrack(track); } - std::string GetReleaseTrack() { - if (!CrosLibrary::Get()->EnsureLoaded()) - return ""; - - return chromeos::GetTrack(); + void GetReleaseTrack(chromeos::UpdateTrackCallback callback, + void* user_data) { + if (CrosLibrary::Get()->EnsureLoaded()) + chromeos::RequestUpdateTrack(callback, user_data); } const UpdateLibrary::Status& status() const { @@ -117,13 +118,18 @@ class UpdateLibraryStubImpl : public UpdateLibrary { ~UpdateLibraryStubImpl() {} void AddObserver(Observer* observer) {} void RemoveObserver(Observer* observer) {} + bool HasObserver(Observer* observer) { return false; } void RequestUpdateCheck(chromeos::UpdateCallback callback, void* user_data) { if (callback) callback(user_data, UPDATE_RESULT_FAILED, "stub update"); } bool RebootAfterUpdate() { return false; } - bool SetReleaseTrack(const std::string& track) { return false; } - std::string GetReleaseTrack() { return "beta-channel"; } + void SetReleaseTrack(const std::string& track) { } + void GetReleaseTrack(chromeos::UpdateTrackCallback callback, + void* user_data) { + if (callback) + callback(user_data, "beta-channel"); + } const UpdateLibrary::Status& status() const { return status_; } diff --git a/chrome/browser/chromeos/cros/update_library.h b/chrome/browser/chromeos/cros/update_library.h index 8fe31cf..cf90722 100644 --- a/chrome/browser/chromeos/cros/update_library.h +++ b/chrome/browser/chromeos/cros/update_library.h @@ -61,6 +61,7 @@ class UpdateLibrary { virtual ~UpdateLibrary() {} virtual void AddObserver(Observer* observer) = 0; virtual void RemoveObserver(Observer* observer) = 0; + virtual bool HasObserver(Observer* observer) = 0; // Requests an update check and calls |callback| when completed. virtual void RequestUpdateCheck(chromeos::UpdateCallback callback, @@ -71,11 +72,12 @@ class UpdateLibrary { // Sets the release track (channel). |track| should look like // "beta-channel" and "dev-channel". Returns true on success. - virtual bool SetReleaseTrack(const std::string& track) = 0; + virtual void SetReleaseTrack(const std::string& track) = 0; - // Returns the release track (channel). On error, returns an empty - // string. - virtual std::string GetReleaseTrack() = 0; + // Calls |callback| with the release track (channel). On error, calls + // |callback| with NULL. + virtual void GetReleaseTrack(chromeos::UpdateTrackCallback callback, + void* user_data) = 0; virtual const Status& status() const = 0; diff --git a/chrome/browser/ui/webui/options/about_page_handler.cc b/chrome/browser/ui/webui/options/about_page_handler.cc index c6c8fca..3326706 100644 --- a/chrome/browser/ui/webui/options/about_page_handler.cc +++ b/chrome/browser/ui/webui/options/about_page_handler.cc @@ -72,6 +72,8 @@ class AboutPageHandler::UpdateObserver explicit UpdateObserver(AboutPageHandler* handler) : page_handler_(handler) {} virtual ~UpdateObserver() {} + AboutPageHandler* page_handler() const { return page_handler_; } + private: virtual void UpdateStatusChanged(chromeos::UpdateLibrary* object) { page_handler_->UpdateStatus(object->status()); @@ -277,12 +279,6 @@ void AboutPageHandler::PageReady(const ListValue* args) { chromeos::UpdateLibrary* update_library = chromeos::CrosLibrary::Get()->GetUpdateLibrary(); - // Update the channel information. - std::string channel = update_library->GetReleaseTrack(); - scoped_ptr<Value> channel_string(Value::CreateStringValue(channel)); - web_ui_->CallJavascriptFunction("AboutPage.updateSelectedOptionCallback", - *channel_string); - update_observer_.reset(new UpdateObserver(this)); update_library->AddObserver(update_observer_.get()); @@ -294,6 +290,11 @@ void AboutPageHandler::PageReady(const ListValue* args) { // already complete, update_observer_ won't receive a notification. // This is why we manually update the WebUI page above. CheckNow(NULL); + + // Request the channel information. Use the observer to track the about + // page handler and ensure it does not get deleted before the callback. + update_library->GetReleaseTrack(UpdateSelectedChannel, + update_observer_.get()); #endif } @@ -417,4 +418,23 @@ void AboutPageHandler::OnOSVersion(chromeos::VersionLoader::Handle handle, *version_string); } } -#endif + +// Callback from UpdateEngine with channel information. +// static +void AboutPageHandler::UpdateSelectedChannel(void* user_data, + const char* channel) { + if (!user_data || !channel) { + LOG(WARNING) << "UpdateSelectedChannel returned NULL."; + return; + } + UpdateObserver* observer = static_cast<UpdateObserver*>(user_data); + if (chromeos::CrosLibrary::Get()->GetUpdateLibrary()->HasObserver(observer)) { + // If UpdateLibrary still has the observer, then the page handler is valid. + AboutPageHandler* handler = observer->page_handler(); + scoped_ptr<Value> channel_string(Value::CreateStringValue(channel)); + handler->web_ui_->CallJavascriptFunction( + "AboutPage.updateSelectedOptionCallback", *channel_string); + } +} + +#endif // defined(OS_CHROMEOS) diff --git a/chrome/browser/ui/webui/options/about_page_handler.h b/chrome/browser/ui/webui/options/about_page_handler.h index 7199fd1..45400d3 100644 --- a/chrome/browser/ui/webui/options/about_page_handler.h +++ b/chrome/browser/ui/webui/options/about_page_handler.h @@ -44,6 +44,9 @@ class AboutPageHandler : public OptionsPageUIHandler { std::string version); void UpdateStatus(const chromeos::UpdateLibrary::Status& status); + // UpdateEngine Callback handler. + static void UpdateSelectedChannel(void* user_data, const char* channel); + // Handles asynchronously loading the version. chromeos::VersionLoader loader_; |