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

Unified Diff: webkit/quota/quota_temporary_storage_evictor_unittest.cc

Issue 8342004: base::Bind: Final cleanups in webkit/quota. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 9 years, 2 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
« no previous file with comments | « webkit/quota/quota_task.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webkit/quota/quota_temporary_storage_evictor_unittest.cc
diff --git a/webkit/quota/quota_temporary_storage_evictor_unittest.cc b/webkit/quota/quota_temporary_storage_evictor_unittest.cc
index fa4f0b261985213683b2ed25e483c0c6026cf8e3..226be6b9f48cfa0024f6dc6a8b9297296da31920 100644
--- a/webkit/quota/quota_temporary_storage_evictor_unittest.cc
+++ b/webkit/quota/quota_temporary_storage_evictor_unittest.cc
@@ -7,7 +7,9 @@
#include <utility>
#include "base/bind.h"
+#include "base/callback.h"
#include "base/memory/scoped_ptr.h"
+#include "base/memory/weak_ptr.h"
#include "base/message_loop.h"
#include "base/message_loop_proxy.h"
#include "base/task.h"
@@ -52,8 +54,8 @@ class MockQuotaEvictionHandler : public quota::QuotaEvictionHandler {
callback.Run(quota::kQuotaErrorInvalidAccess, QuotaAndUsage());
return;
}
- if (task_for_get_usage_and_quota_.get())
- task_for_get_usage_and_quota_->Run();
+ if (!task_for_get_usage_and_quota_.is_null())
+ task_for_get_usage_and_quota_.Run();
QuotaAndUsage quota_and_usage = {
GetUsage(), unlimited_usage_, quota_, available_space_ };
callback.Run(quota::kQuotaStatusOk, quota_and_usage);
@@ -86,8 +88,8 @@ class MockQuotaEvictionHandler : public quota::QuotaEvictionHandler {
void set_available_space(int64 available_space) {
available_space_ = available_space;
}
- void set_task_for_get_usage_and_quota(CancelableTask* task) {
- task_for_get_usage_and_quota_.reset(task);
+ void set_task_for_get_usage_and_quota(const base::Closure& task) {
+ task_for_get_usage_and_quota_= task;
}
void set_error_on_evict_origin_data(bool error_on_evict_origin_data) {
error_on_evict_origin_data_ = error_on_evict_origin_data;
@@ -135,7 +137,7 @@ class MockQuotaEvictionHandler : public quota::QuotaEvictionHandler {
bool error_on_get_usage_and_quota_;
QuotaTemporaryStorageEvictorTest *test_;
- scoped_ptr<CancelableTask> task_for_get_usage_and_quota_;
+ base::Closure task_for_get_usage_and_quota_;
};
} // anonymous namespace
@@ -144,7 +146,7 @@ class QuotaTemporaryStorageEvictorTest : public testing::Test {
public:
QuotaTemporaryStorageEvictorTest()
: num_get_usage_and_quota_for_eviction_(0),
- runnable_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)) {}
+ ALLOW_THIS_IN_INITIALIZER_LIST(weak_factory_(this)) {}
void SetUp() {
quota_eviction_handler_.reset(new MockQuotaEvictionHandler(this));
@@ -226,8 +228,7 @@ class QuotaTemporaryStorageEvictorTest : public testing::Test {
int num_get_usage_and_quota_for_eviction_;
- ScopedRunnableMethodFactory<QuotaTemporaryStorageEvictorTest>
- runnable_factory_;
+ base::WeakPtrFactory<QuotaTemporaryStorageEvictorTest> weak_factory_;
DISALLOW_COPY_AND_ASSIGN(QuotaTemporaryStorageEvictorTest);
};
@@ -286,12 +287,11 @@ TEST_F(QuotaTemporaryStorageEvictorTest, RepeatedEvictionTest) {
quota_eviction_handler()->set_quota(1000);
quota_eviction_handler()->set_available_space(1000000000);
quota_eviction_handler()->set_task_for_get_usage_and_quota(
- runnable_factory_.NewRunnableMethod(
- &QuotaTemporaryStorageEvictorTest::TaskForRepeatedEvictionTest,
- std::make_pair(GURL("http://www.e.com"), e_size),
- GURL(),
- initial_total_size - d_size,
- initial_total_size - d_size + e_size - c_size));
+ base::Bind(&QuotaTemporaryStorageEvictorTest::TaskForRepeatedEvictionTest,
+ weak_factory_.GetWeakPtr(),
+ std::make_pair(GURL("http://www.e.com"), e_size), GURL(),
+ initial_total_size - d_size,
+ initial_total_size - d_size + e_size - c_size));
EXPECT_EQ(initial_total_size, quota_eviction_handler()->GetUsage());
temporary_storage_evictor()->Start();
MessageLoop::current()->RunAllPending();
@@ -320,12 +320,9 @@ TEST_F(QuotaTemporaryStorageEvictorTest, RepeatedEvictionSkippedTest) {
quota_eviction_handler()->set_quota(1000);
quota_eviction_handler()->set_available_space(1000000000);
quota_eviction_handler()->set_task_for_get_usage_and_quota(
- runnable_factory_.NewRunnableMethod(
- &QuotaTemporaryStorageEvictorTest::TaskForRepeatedEvictionTest,
- std::make_pair(GURL(), 0),
- GURL(),
- initial_total_size - d_size,
- initial_total_size - d_size));
+ base::Bind(&QuotaTemporaryStorageEvictorTest::TaskForRepeatedEvictionTest,
+ weak_factory_.GetWeakPtr(), std::make_pair(GURL(), 0), GURL(),
+ initial_total_size - d_size, initial_total_size - d_size));
EXPECT_EQ(initial_total_size, quota_eviction_handler()->GetUsage());
set_repeated_eviction(true);
temporary_storage_evictor()->Start();
@@ -356,12 +353,12 @@ TEST_F(QuotaTemporaryStorageEvictorTest, RepeatedEvictionWithAccessOriginTest) {
quota_eviction_handler()->set_quota(1000);
quota_eviction_handler()->set_available_space(1000000000);
quota_eviction_handler()->set_task_for_get_usage_and_quota(
- runnable_factory_.NewRunnableMethod(
- &QuotaTemporaryStorageEvictorTest::TaskForRepeatedEvictionTest,
- std::make_pair(GURL("http://www.e.com"), e_size),
- GURL("http://www.c.com"),
- initial_total_size - d_size,
- initial_total_size - d_size + e_size - b_size));
+ base::Bind(&QuotaTemporaryStorageEvictorTest::TaskForRepeatedEvictionTest,
+ weak_factory_.GetWeakPtr(),
+ std::make_pair(GURL("http://www.e.com"), e_size),
+ GURL("http://www.c.com"),
+ initial_total_size - d_size,
+ initial_total_size - d_size + e_size - b_size));
EXPECT_EQ(initial_total_size, quota_eviction_handler()->GetUsage());
temporary_storage_evictor()->Start();
MessageLoop::current()->RunAllPending();
« no previous file with comments | « webkit/quota/quota_task.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698