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

Unified Diff: athena/resource_manager/resource_manager_unittest.cc

Issue 513523002: Adding Baseframework of the ResourceManager (all hooks and observers) are being put in place with a… (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Aaaand another rebase Created 6 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 side-by-side diff with in-line comments
Download patch
Index: athena/resource_manager/resource_manager_unittest.cc
diff --git a/athena/resource_manager/resource_manager_unittest.cc b/athena/resource_manager/resource_manager_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..e6e72b3958a55d3e0f8088eebeeb4ce1ed521368
--- /dev/null
+++ b/athena/resource_manager/resource_manager_unittest.cc
@@ -0,0 +1,207 @@
+/// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "athena/activity/public/activity.h"
+#include "athena/activity/public/activity_manager.h"
+#include "athena/activity/public/activity_view_model.h"
+#include "athena/resource_manager/memory_pressure_notifier.h"
+#include "athena/resource_manager/public/resource_manager.h"
+#include "athena/test/athena_test_base.h"
+#include "base/strings/utf_string_conversions.h"
+#include "ui/gfx/image/image_skia.h"
+#include "ui/views/view.h"
+#include "ui/views/widget/widget.h"
+
+namespace athena {
+namespace test {
+
+namespace {
+
+// A dummy test app activity which works without content / ShellAppWindow.
+class TestActivity : public Activity,
+ public ActivityViewModel {
+ public:
+ TestActivity(std::string title) : title_(base::UTF8ToUTF16(title)),
+ view_(new views::View()),
+ current_state_(ACTIVITY_UNLOADED),
+ media_state_(ACTIVITY_MEDIA_STATE_NONE),
+ is_visible_(false) {};
+ virtual ~TestActivity() {}
+
+ void set_media_state(ActivityMediaState media_state) {
+ media_state_ = media_state;
+ }
+ void set_visible(bool visible) { is_visible_ = visible; }
+
+ // Activity overrides:
+ virtual ActivityViewModel* GetActivityViewModel() OVERRIDE { return this; }
+ virtual void SetCurrentState(ActivityState state) OVERRIDE {
+ current_state_ = state;
+ }
+ virtual ActivityState GetCurrentState() OVERRIDE { return current_state_; }
+ virtual bool IsVisible() OVERRIDE { return is_visible_; }
+ virtual ActivityMediaState GetMediaState() OVERRIDE { return media_state_; }
+ virtual aura::Window* GetWindow() OVERRIDE {
+ return view_->GetWidget()->GetNativeWindow();
+ }
+
+ // ActivityViewModel overrides:
+ virtual void Init() OVERRIDE {}
+ virtual SkColor GetRepresentativeColor() const OVERRIDE { return 0; }
+ virtual base::string16 GetTitle() const OVERRIDE { return title_; }
+ virtual bool UsesFrame() const OVERRIDE { return true; }
+ virtual views::View* GetContentsView() OVERRIDE { return view_; }
+ virtual void CreateOverviewModeImage() OVERRIDE {}
+ virtual gfx::ImageSkia GetOverviewModeImage() OVERRIDE { return image_; }
+
+ private:
+ // The presentation values.
+ const base::string16 title_;
+ gfx::ImageSkia image_;
+
+ // The associated view.
+ views::View* view_;
+
+ // The current state.
+ ActivityState current_state_;
+
+ // The current media state.
+ ActivityMediaState media_state_;
+
+ // Returns if it is visible or not.
+ bool is_visible_;
+
+ DISALLOW_COPY_AND_ASSIGN(TestActivity);
+};
+
+} // namespace
+
+// Our testing base.
+class ResourceManagerTest : public AthenaTestBase {
+ public:
+ ResourceManagerTest() {}
+ virtual ~ResourceManagerTest() {}
+
+ virtual void TearDown() OVERRIDE {
+ while (!activity_list_.empty())
+ CloseActivity(activity_list_[0]);
+ AthenaTestBase::TearDown();
+ }
+
+ TestActivity* CreateActivity(const std::string& title) {
+ TestActivity* activity = new TestActivity(title);
+ ActivityManager::Get()->AddActivity(activity);
+ activity->SetCurrentState(Activity::ACTIVITY_INVISIBLE);
+ activity_list_.push_back(activity);
+ return activity;
+ }
+
+ void CloseActivity(Activity* activity) {
+ delete activity;
+ RunAllPendingInMessageLoop();
+ std::vector<TestActivity*>::iterator it = std::find(activity_list_.begin(),
+ activity_list_.end(),
+ activity);
+ DCHECK(it != activity_list_.end());
+ activity_list_.erase(it);
+ }
+
+ private:
+ std::vector<TestActivity*> activity_list_;
+
+ DISALLOW_COPY_AND_ASSIGN(ResourceManagerTest);
+};
+
+// Only creates and destroys it to see that the system gets properly shut down.
+TEST_F(ResourceManagerTest, SimpleTest) {
+}
+
+// Test that we release an activity when the memory pressure goes critical.
+TEST_F(ResourceManagerTest, OnCriticalWillUnloadOneActivity) {
+ // create a few dummy activities.
+ TestActivity* app_visible = CreateActivity("visible");
+ TestActivity* app_unloadable1 = CreateActivity("unloadable1");
+ TestActivity* app_unloadable2 = CreateActivity("unloadable2");
+ app_visible->set_visible(true);
+ app_unloadable1->set_visible(false);
+ app_unloadable2->set_visible(false);
+
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_visible->GetCurrentState());
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_unloadable1->GetCurrentState());
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_unloadable2->GetCurrentState());
+
+ // Call the resource manager and say we are in a critical memory condition.
+ ResourceManager::Get()->SetMemoryPressureAndStopMonitoring(
+ MemoryPressureObserver::MEMORY_PRESSURE_CRITICAL);
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_visible->GetCurrentState());
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_unloadable1->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_unloadable2->GetCurrentState());
+
+ // Calling it a second time will release the second app.
+ ResourceManager::Get()->SetMemoryPressureAndStopMonitoring(
+ MemoryPressureObserver::MEMORY_PRESSURE_CRITICAL);
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_visible->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_unloadable1->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_unloadable2->GetCurrentState());
+
+ // Calling it once more will change nothing.
+ ResourceManager::Get()->SetMemoryPressureAndStopMonitoring(
+ MemoryPressureObserver::MEMORY_PRESSURE_CRITICAL);
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_visible->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_unloadable1->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_unloadable2->GetCurrentState());
+}
+
+// Test that media playing activities only get unloaded if there is no other
+// way.
+TEST_F(ResourceManagerTest, OnCriticalMediaHandling) {
+ // create a few dummy activities.
+ TestActivity* app_visible = CreateActivity("visible");
+ TestActivity* app_media_locked1 = CreateActivity("medialocked1");
+ TestActivity* app_unloadable = CreateActivity("unloadable2");
+ TestActivity* app_media_locked2 = CreateActivity("medialocked2");
+ app_visible->set_visible(true);
+ app_unloadable->set_visible(false);
+ app_media_locked1->set_visible(false);
+ app_media_locked2->set_visible(false);
+
+ app_media_locked1->set_media_state(
+ Activity::ACTIVITY_MEDIA_STATE_AUDIO_PLAYING);
+ app_media_locked2->set_media_state(Activity::ACTIVITY_MEDIA_STATE_RECORDING);
+
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_visible->GetCurrentState());
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_media_locked1->GetCurrentState());
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_unloadable->GetCurrentState());
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_media_locked2->GetCurrentState());
+
+ // Calling it with a critical situation first, it will release the non media
+ // locked app.
+ ResourceManager::Get()->SetMemoryPressureAndStopMonitoring(
+ MemoryPressureObserver::MEMORY_PRESSURE_CRITICAL);
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_visible->GetCurrentState());
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_media_locked1->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_unloadable->GetCurrentState());
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_media_locked2->GetCurrentState());
+
+ // Calling it the second time, the oldest media playing activity will get
+ // unloaded.
+ ResourceManager::Get()->SetMemoryPressureAndStopMonitoring(
+ MemoryPressureObserver::MEMORY_PRESSURE_CRITICAL);
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_visible->GetCurrentState());
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_media_locked1->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_unloadable->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_media_locked2->GetCurrentState());
+
+ // Calling it the third time, the oldest media playing activity will get
+ // unloaded.
+ ResourceManager::Get()->SetMemoryPressureAndStopMonitoring(
+ MemoryPressureObserver::MEMORY_PRESSURE_CRITICAL);
+ DCHECK_NE(Activity::ACTIVITY_UNLOADED, app_visible->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_media_locked1->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_unloadable->GetCurrentState());
+ DCHECK_EQ(Activity::ACTIVITY_UNLOADED, app_media_locked2->GetCurrentState());
+}
+
+} // namespace test
+} // namespace athena

Powered by Google App Engine
This is Rietveld 408576698