summaryrefslogtreecommitdiffstats
path: root/chrome/browser/download
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/download')
-rw-r--r--chrome/browser/download/download_request_infobar_delegate.cc5
-rw-r--r--chrome/browser/download/download_request_infobar_delegate.h8
-rw-r--r--chrome/browser/download/download_request_infobar_delegate_unittest.cc4
-rw-r--r--chrome/browser/download/download_request_limiter.cc (renamed from chrome/browser/download/download_request_manager.cc)92
-rw-r--r--chrome/browser/download/download_request_limiter.h (renamed from chrome/browser/download/download_request_manager.h)51
-rw-r--r--chrome/browser/download/download_request_limiter_unittest.cc (renamed from chrome/browser/download/download_request_manager_unittest.cc)96
6 files changed, 128 insertions, 128 deletions
diff --git a/chrome/browser/download/download_request_infobar_delegate.cc b/chrome/browser/download/download_request_infobar_delegate.cc
index 88c83fc..4a401bb 100644
--- a/chrome/browser/download/download_request_infobar_delegate.cc
+++ b/chrome/browser/download/download_request_infobar_delegate.cc
@@ -11,7 +11,7 @@
#include "grit/theme_resources.h"
DownloadRequestInfoBarDelegate::DownloadRequestInfoBarDelegate(TabContents* tab,
- DownloadRequestManager::TabDownloadState* host)
+ DownloadRequestLimiter::TabDownloadState* host)
: ConfirmInfoBarDelegate(tab),
host_(host) {
if (tab)
@@ -50,9 +50,10 @@ std::wstring DownloadRequestInfoBarDelegate::GetButtonLabel(
bool DownloadRequestInfoBarDelegate::Accept() {
if (host_) {
+ // Accept() call will nullify host_ if no further prompts are required.
host_->Accept();
}
- // Accept() call will nullify host_ if no furthur prompts are required.
+
return !host_;
}
diff --git a/chrome/browser/download/download_request_infobar_delegate.h b/chrome/browser/download/download_request_infobar_delegate.h
index 112c2e2..700c629 100644
--- a/chrome/browser/download/download_request_infobar_delegate.h
+++ b/chrome/browser/download/download_request_infobar_delegate.h
@@ -6,7 +6,7 @@
#define CHROME_BROWSER_DOWNLOAD_DOWNLOAD_REQUEST_INFOBAR_DELEGATE_H_
#include "base/basictypes.h"
-#include "chrome/browser/download/download_request_manager.h"
+#include "chrome/browser/download/download_request_limiter.h"
#include "chrome/browser/tab_contents/infobar_delegate.h"
class TabContents;
@@ -18,11 +18,11 @@ class TabContents;
class DownloadRequestInfoBarDelegate : public ConfirmInfoBarDelegate {
public:
DownloadRequestInfoBarDelegate(
- TabContents* tab, DownloadRequestManager::TabDownloadState* host);
+ TabContents* tab, DownloadRequestLimiter::TabDownloadState* host);
virtual ~DownloadRequestInfoBarDelegate();
- void set_host(DownloadRequestManager::TabDownloadState* host) {
+ void set_host(DownloadRequestLimiter::TabDownloadState* host) {
host_ = host;
}
@@ -42,7 +42,7 @@ class DownloadRequestInfoBarDelegate : public ConfirmInfoBarDelegate {
virtual bool Cancel();
private:
- DownloadRequestManager::TabDownloadState* host_;
+ DownloadRequestLimiter::TabDownloadState* host_;
DISALLOW_COPY_AND_ASSIGN(DownloadRequestInfoBarDelegate);
};
diff --git a/chrome/browser/download/download_request_infobar_delegate_unittest.cc b/chrome/browser/download/download_request_infobar_delegate_unittest.cc
index 663f8b7..1ceb247 100644
--- a/chrome/browser/download/download_request_infobar_delegate_unittest.cc
+++ b/chrome/browser/download/download_request_infobar_delegate_unittest.cc
@@ -3,10 +3,10 @@
// found in the LICENSE file.
#include "chrome/browser/download/download_request_infobar_delegate.h"
-#include "chrome/browser/download/download_request_manager.h"
+#include "chrome/browser/download/download_request_limiter.h"
#include "testing/gtest/include/gtest/gtest.h"
-class MockTabDownloadState : public DownloadRequestManager::TabDownloadState {
+class MockTabDownloadState : public DownloadRequestLimiter::TabDownloadState {
public:
MockTabDownloadState() : responded_(false), accepted_(false) {
}
diff --git a/chrome/browser/download/download_request_manager.cc b/chrome/browser/download/download_request_limiter.cc
index 6c06435..472a2c5 100644
--- a/chrome/browser/download/download_request_manager.cc
+++ b/chrome/browser/download/download_request_limiter.cc
@@ -1,9 +1,10 @@
-// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
+// Copyright (c) 2010 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 "chrome/browser/download/download_request_manager.h"
+#include "chrome/browser/download/download_request_limiter.h"
+#include "base/stl_util-inl.h"
#include "chrome/browser/chrome_thread.h"
#include "chrome/browser/download/download_request_infobar_delegate.h"
#include "chrome/browser/tab_contents/navigation_controller.h"
@@ -15,13 +16,13 @@
// TabDownloadState ------------------------------------------------------------
-DownloadRequestManager::TabDownloadState::TabDownloadState(
- DownloadRequestManager* host,
+DownloadRequestLimiter::TabDownloadState::TabDownloadState(
+ DownloadRequestLimiter* host,
NavigationController* controller,
NavigationController* originating_controller)
: host_(host),
controller_(controller),
- status_(DownloadRequestManager::ALLOW_ONE_DOWNLOAD),
+ status_(DownloadRequestLimiter::ALLOW_ONE_DOWNLOAD),
download_count_(0),
infobar_(NULL) {
Source<NavigationController> notification_source(controller);
@@ -35,7 +36,7 @@ DownloadRequestManager::TabDownloadState::TabDownloadState(
initial_page_host_ = active_entry->url().host();
}
-DownloadRequestManager::TabDownloadState::~TabDownloadState() {
+DownloadRequestLimiter::TabDownloadState::~TabDownloadState() {
// We should only be destroyed after the callbacks have been notified.
DCHECK(callbacks_.empty());
@@ -43,14 +44,14 @@ DownloadRequestManager::TabDownloadState::~TabDownloadState() {
DCHECK(!infobar_);
}
-void DownloadRequestManager::TabDownloadState::OnUserGesture() {
+void DownloadRequestLimiter::TabDownloadState::OnUserGesture() {
if (is_showing_prompt()) {
// Don't change the state if the user clicks on the page some where.
return;
}
- if (status_ != DownloadRequestManager::ALLOW_ALL_DOWNLOADS &&
- status_ != DownloadRequestManager::DOWNLOADS_NOT_ALLOWED) {
+ if (status_ != DownloadRequestLimiter::ALLOW_ALL_DOWNLOADS &&
+ status_ != DownloadRequestLimiter::DOWNLOADS_NOT_ALLOWED) {
// Revert to default status.
host_->Remove(this);
// WARNING: We've been deleted.
@@ -58,30 +59,30 @@ void DownloadRequestManager::TabDownloadState::OnUserGesture() {
}
}
-void DownloadRequestManager::TabDownloadState::PromptUserForDownload(
+void DownloadRequestLimiter::TabDownloadState::PromptUserForDownload(
TabContents* tab,
- DownloadRequestManager::Callback* callback) {
+ DownloadRequestLimiter::Callback* callback) {
callbacks_.push_back(callback);
if (is_showing_prompt())
return; // Already showing prompt.
- if (DownloadRequestManager::delegate_) {
- NotifyCallbacks(DownloadRequestManager::delegate_->ShouldAllowDownload());
+ if (DownloadRequestLimiter::delegate_) {
+ NotifyCallbacks(DownloadRequestLimiter::delegate_->ShouldAllowDownload());
} else {
infobar_ = new DownloadRequestInfoBarDelegate(tab, this);
}
}
-void DownloadRequestManager::TabDownloadState::Cancel() {
+void DownloadRequestLimiter::TabDownloadState::Cancel() {
NotifyCallbacks(false);
}
-void DownloadRequestManager::TabDownloadState::Accept() {
+void DownloadRequestLimiter::TabDownloadState::Accept() {
NotifyCallbacks(true);
}
-void DownloadRequestManager::TabDownloadState::Observe(
+void DownloadRequestLimiter::TabDownloadState::Observe(
NotificationType type,
const NotificationSource& source,
const NotificationDetails& details) {
@@ -109,8 +110,8 @@ void DownloadRequestManager::TabDownloadState::Observe(
return;
}
- if (status_ == DownloadRequestManager::ALLOW_ALL_DOWNLOADS ||
- status_ == DownloadRequestManager::DOWNLOADS_NOT_ALLOWED) {
+ if (status_ == DownloadRequestLimiter::ALLOW_ALL_DOWNLOADS ||
+ status_ == DownloadRequestLimiter::DOWNLOADS_NOT_ALLOWED) {
// User has either allowed all downloads or canceled all downloads. Only
// reset the download state if the user is navigating to a different
// host (or host is empty).
@@ -135,11 +136,11 @@ void DownloadRequestManager::TabDownloadState::Observe(
host_->Remove(this);
}
-void DownloadRequestManager::TabDownloadState::NotifyCallbacks(bool allow) {
+void DownloadRequestLimiter::TabDownloadState::NotifyCallbacks(bool allow) {
status_ = allow ?
- DownloadRequestManager::ALLOW_ALL_DOWNLOADS :
- DownloadRequestManager::DOWNLOADS_NOT_ALLOWED;
- std::vector<DownloadRequestManager::Callback*> callbacks;
+ DownloadRequestLimiter::ALLOW_ALL_DOWNLOADS :
+ DownloadRequestLimiter::DOWNLOADS_NOT_ALLOWED;
+ std::vector<DownloadRequestLimiter::Callback*> callbacks;
bool change_status = false;
// Selectively send first few notifications only if number of downloads exceed
@@ -154,7 +155,7 @@ void DownloadRequestManager::TabDownloadState::NotifyCallbacks(bool allow) {
}
callbacks.swap(callbacks_);
} else {
- std::vector<DownloadRequestManager::Callback*>::iterator start, end;
+ std::vector<DownloadRequestLimiter::Callback*>::iterator start, end;
start = callbacks_.begin();
end = callbacks_.begin() + kMaxDownloadsAtOnce;
callbacks.assign(start, end);
@@ -162,31 +163,31 @@ void DownloadRequestManager::TabDownloadState::NotifyCallbacks(bool allow) {
change_status = true;
}
- for (size_t i = 0; i < callbacks.size(); ++i) {
+ for (size_t i = 0; i < callbacks.size(); ++i)
host_->ScheduleNotification(callbacks[i], allow);
- }
+
if (change_status)
- status_ = DownloadRequestManager::PROMPT_BEFORE_DOWNLOAD;
+ status_ = DownloadRequestLimiter::PROMPT_BEFORE_DOWNLOAD;
}
-// DownloadRequestManager ------------------------------------------------------
+// DownloadRequestLimiter ------------------------------------------------------
-DownloadRequestManager::DownloadRequestManager() {
+DownloadRequestLimiter::DownloadRequestLimiter() {
}
-DownloadRequestManager::~DownloadRequestManager() {
+DownloadRequestLimiter::~DownloadRequestLimiter() {
// All the tabs should have closed before us, which sends notification and
// removes from state_map_. As such, there should be no pending callbacks.
DCHECK(state_map_.empty());
}
-DownloadRequestManager::DownloadStatus
- DownloadRequestManager::GetDownloadStatus(TabContents* tab) {
+DownloadRequestLimiter::DownloadStatus
+ DownloadRequestLimiter::GetDownloadStatus(TabContents* tab) {
TabDownloadState* state = GetDownloadState(&tab->controller(), NULL, false);
return state ? state->download_status() : ALLOW_ONE_DOWNLOAD;
}
-void DownloadRequestManager::CanDownloadOnIOThread(int render_process_host_id,
+void DownloadRequestLimiter::CanDownloadOnIOThread(int render_process_host_id,
int render_view_id,
Callback* callback) {
// This is invoked on the IO thread. Schedule the task to run on the UI
@@ -194,11 +195,11 @@ void DownloadRequestManager::CanDownloadOnIOThread(int render_process_host_id,
DCHECK(ChromeThread::CurrentlyOn(ChromeThread::IO));
ChromeThread::PostTask(
ChromeThread::UI, FROM_HERE,
- NewRunnableMethod(this, &DownloadRequestManager::CanDownload,
+ NewRunnableMethod(this, &DownloadRequestLimiter::CanDownload,
render_process_host_id, render_view_id, callback));
}
-void DownloadRequestManager::OnUserGesture(TabContents* tab) {
+void DownloadRequestLimiter::OnUserGesture(TabContents* tab) {
TabDownloadState* state = GetDownloadState(&tab->controller(), NULL, false);
if (!state)
return;
@@ -207,11 +208,11 @@ void DownloadRequestManager::OnUserGesture(TabContents* tab) {
}
// static
-void DownloadRequestManager::SetTestingDelegate(TestingDelegate* delegate) {
+void DownloadRequestLimiter::SetTestingDelegate(TestingDelegate* delegate) {
delegate_ = delegate;
}
-DownloadRequestManager::TabDownloadState* DownloadRequestManager::
+DownloadRequestLimiter::TabDownloadState* DownloadRequestLimiter::
GetDownloadState(NavigationController* controller,
NavigationController* originating_controller,
bool create) {
@@ -229,7 +230,7 @@ DownloadRequestManager::TabDownloadState* DownloadRequestManager::
return state;
}
-void DownloadRequestManager::CanDownload(int render_process_host_id,
+void DownloadRequestLimiter::CanDownload(int render_process_host_id,
int render_view_id,
Callback* callback) {
DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI));
@@ -244,7 +245,7 @@ void DownloadRequestManager::CanDownload(int render_process_host_id,
CanDownloadImpl(originating_tab, callback);
}
-void DownloadRequestManager::CanDownloadImpl(
+void DownloadRequestLimiter::CanDownloadImpl(
TabContents* originating_tab,
Callback* callback) {
// FYI: Chrome Frame overrides CanDownload in ExternalTabContainer in order
@@ -268,7 +269,7 @@ void DownloadRequestManager::CanDownloadImpl(
switch (state->download_status()) {
case ALLOW_ALL_DOWNLOADS:
if (state->download_count() && !(state->download_count() %
- DownloadRequestManager::kMaxDownloadsAtOnce))
+ DownloadRequestLimiter::kMaxDownloadsAtOnce))
state->set_download_status(PROMPT_BEFORE_DOWNLOAD);
ScheduleNotification(callback, true);
state->increment_download_count();
@@ -293,16 +294,15 @@ void DownloadRequestManager::CanDownloadImpl(
}
}
-void DownloadRequestManager::ScheduleNotification(Callback* callback,
+void DownloadRequestLimiter::ScheduleNotification(Callback* callback,
bool allow) {
ChromeThread::PostTask(
ChromeThread::IO, FROM_HERE,
NewRunnableMethod(
- this, &DownloadRequestManager::NotifyCallback, callback, allow));
+ this, &DownloadRequestLimiter::NotifyCallback, callback, allow));
}
-void DownloadRequestManager::NotifyCallback(Callback* callback, bool allow) {
- // We better be on the IO thread now.
+void DownloadRequestLimiter::NotifyCallback(Callback* callback, bool allow) {
DCHECK(ChromeThread::CurrentlyOn(ChromeThread::IO));
if (allow)
callback->ContinueDownload();
@@ -310,12 +310,12 @@ void DownloadRequestManager::NotifyCallback(Callback* callback, bool allow) {
callback->CancelDownload();
}
-void DownloadRequestManager::Remove(TabDownloadState* state) {
- DCHECK(state_map_.find(state->controller()) != state_map_.end());
+void DownloadRequestLimiter::Remove(TabDownloadState* state) {
+ DCHECK(ContainsKey(state_map_, state->controller()));
state_map_.erase(state->controller());
delete state;
}
// static
-DownloadRequestManager::TestingDelegate* DownloadRequestManager::delegate_ =
+DownloadRequestLimiter::TestingDelegate* DownloadRequestLimiter::delegate_ =
NULL;
diff --git a/chrome/browser/download/download_request_manager.h b/chrome/browser/download/download_request_limiter.h
index 97fa7f8..f5b4cfa 100644
--- a/chrome/browser/download/download_request_manager.h
+++ b/chrome/browser/download/download_request_limiter.h
@@ -1,9 +1,9 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// Copyright (c) 2010 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.
-#ifndef CHROME_BROWSER_DOWNLOAD_DOWNLOAD_REQUEST_MANAGER_H_
-#define CHROME_BROWSER_DOWNLOAD_DOWNLOAD_REQUEST_MANAGER_H_
+#ifndef CHROME_BROWSER_DOWNLOAD_DOWNLOAD_REQUEST_LIMITER_H_
+#define CHROME_BROWSER_DOWNLOAD_DOWNLOAD_REQUEST_LIMITER_H_
#include <map>
#include <string>
@@ -17,9 +17,9 @@ class DownloadRequestInfoBarDelegate;
class NavigationController;
class TabContents;
-// DownloadRequestManager is responsible for determining whether a download
+// DownloadRequestLimiter is responsible for determining whether a download
// should be allowed or not. It is designed to keep pages from downloading
-// multiple files without user interaction. DownloadRequestManager is invoked
+// multiple files without user interaction. DownloadRequestLimiter is invoked
// from ResourceDispatcherHost any time a download begins
// (CanDownloadOnIOThread). The request is processed on the UI thread, and the
// request is notified (back on the IO thread) as to whether the download should
@@ -39,9 +39,8 @@ class TabContents;
// choice stays until the user navigates to a different host. For example, if
// the user allowed the download, multiple downloads are allowed without any
// user intervention until the user navigates to a different host.
-
-class DownloadRequestManager
- : public base::RefCountedThreadSafe<DownloadRequestManager> {
+class DownloadRequestLimiter
+ : public base::RefCountedThreadSafe<DownloadRequestLimiter> {
public:
// Download status for a particular page. See class description for details.
enum DownloadStatus {
@@ -68,7 +67,7 @@ class DownloadRequestManager
// TabDownloadState maintains the download state for a particular tab.
// TabDownloadState prompts the user with an infobar as necessary.
// TabDownloadState deletes itself (by invoking
- // DownloadRequestManager::Remove) as necessary.
+ // DownloadRequestLimiter::Remove) as necessary.
class TabDownloadState : public NotificationObserver {
public:
// Creates a new TabDownloadState. |controller| is the controller the
@@ -77,16 +76,16 @@ class DownloadRequestManager
// the initial download. If |originating_controller| is null, |controller|
// is used. |originating_controller| is typically null, but differs from
// |controller| in the case of a constrained popup requesting the download.
- TabDownloadState(DownloadRequestManager* host,
+ TabDownloadState(DownloadRequestLimiter* host,
NavigationController* controller,
NavigationController* originating_controller);
virtual ~TabDownloadState();
// Status of the download.
- void set_download_status(DownloadRequestManager::DownloadStatus status) {
+ void set_download_status(DownloadRequestLimiter::DownloadStatus status) {
status_ = status;
}
- DownloadRequestManager::DownloadStatus download_status() const {
+ DownloadRequestLimiter::DownloadStatus download_status() const {
return status_;
}
@@ -99,14 +98,14 @@ class DownloadRequestManager
}
// Invoked when a user gesture occurs (mouse click, enter or space). This
- // may result in invoking Remove on DownloadRequestManager.
+ // may result in invoking Remove on DownloadRequestLimiter.
void OnUserGesture();
// Asks the user if they really want to allow the download.
// See description above CanDownloadOnIOThread for details on lifetime of
// callback.
void PromptUserForDownload(TabContents* tab,
- DownloadRequestManager::Callback* callback);
+ DownloadRequestLimiter::Callback* callback);
// Are we showing a prompt to the user?
bool is_showing_prompt() const { return (infobar_ != NULL); }
@@ -124,7 +123,7 @@ class DownloadRequestManager
TabDownloadState()
: host_(NULL),
controller_(NULL),
- status_(DownloadRequestManager::ALLOW_ONE_DOWNLOAD),
+ status_(DownloadRequestLimiter::ALLOW_ONE_DOWNLOAD),
download_count_(0),
infobar_(NULL) {
}
@@ -139,14 +138,14 @@ class DownloadRequestManager
// Updates status_ appropriately.
void NotifyCallbacks(bool allow);
- DownloadRequestManager* host_;
+ DownloadRequestLimiter* host_;
NavigationController* controller_;
// Host of the first page the download started on. This may be empty.
std::string initial_page_host_;
- DownloadRequestManager::DownloadStatus status_;
+ DownloadRequestLimiter::DownloadStatus status_;
size_t download_count_;
@@ -154,7 +153,7 @@ class DownloadRequestManager
// dialog.
// See description above CanDownloadOnIOThread for details on lifetime of
// callbacks.
- std::vector<DownloadRequestManager::Callback*> callbacks_;
+ std::vector<DownloadRequestLimiter::Callback*> callbacks_;
// Used to remove observers installed on NavigationController.
NotificationRegistrar registrar_;
@@ -165,7 +164,7 @@ class DownloadRequestManager
DISALLOW_COPY_AND_ASSIGN(TabDownloadState);
};
- DownloadRequestManager();
+ DownloadRequestLimiter();
// Returns the download status for a page. This does not change the state in
// anyway.
@@ -174,7 +173,7 @@ class DownloadRequestManager
// Updates the state of the page as necessary and notifies the callback.
// WARNING: both this call and the callback are invoked on the io thread.
//
- // DownloadRequestManager does not retain/release the Callback. It is up to
+ // DownloadRequestLimiter does not retain/release the Callback. It is up to
// the caller to ensure the callback is valid until the request is complete.
void CanDownloadOnIOThread(int render_process_host_id,
int render_view_id,
@@ -186,11 +185,11 @@ class DownloadRequestManager
void OnUserGesture(TabContents* tab);
private:
- friend class base::RefCountedThreadSafe<DownloadRequestManager>;
- friend class DownloadRequestManagerTest;
+ friend class base::RefCountedThreadSafe<DownloadRequestLimiter>;
+ friend class DownloadRequestLimiterTest;
friend class TabDownloadState;
- ~DownloadRequestManager();
+ ~DownloadRequestLimiter();
// For unit tests. If non-null this is used instead of creating a dialog.
class TestingDelegate {
@@ -207,7 +206,7 @@ class DownloadRequestManager
// See TabDownloadState's constructor description for details on the two
// controllers.
//
- // The returned TabDownloadState is owned by the DownloadRequestManager and
+ // The returned TabDownloadState is owned by the DownloadRequestLimiter and
// deleted when no longer needed (the Remove method is invoked).
TabDownloadState* GetDownloadState(
NavigationController* controller,
@@ -246,7 +245,7 @@ class DownloadRequestManager
static TestingDelegate* delegate_;
- DISALLOW_COPY_AND_ASSIGN(DownloadRequestManager);
+ DISALLOW_COPY_AND_ASSIGN(DownloadRequestLimiter);
};
-#endif // CHROME_BROWSER_DOWNLOAD_DOWNLOAD_REQUEST_MANAGER_H_
+#endif // CHROME_BROWSER_DOWNLOAD_DOWNLOAD_REQUEST_LIMITER_H_
diff --git a/chrome/browser/download/download_request_manager_unittest.cc b/chrome/browser/download/download_request_limiter_unittest.cc
index 3e5e454..d8582a9 100644
--- a/chrome/browser/download/download_request_manager_unittest.cc
+++ b/chrome/browser/download/download_request_limiter_unittest.cc
@@ -3,17 +3,17 @@
// found in the LICENSE file.
#include "chrome/browser/chrome_thread.h"
-#include "chrome/browser/download/download_request_manager.h"
+#include "chrome/browser/download/download_request_limiter.h"
#include "chrome/browser/renderer_host/test/test_render_view_host.h"
#include "chrome/browser/tab_contents/navigation_controller.h"
#include "chrome/test/testing_profile.h"
#include "testing/gtest/include/gtest/gtest.h"
-class DownloadRequestManagerTest
+class DownloadRequestLimiterTest
: public RenderViewHostTestHarness,
- public DownloadRequestManager::Callback {
+ public DownloadRequestLimiter::Callback {
public:
- DownloadRequestManagerTest() : io_thread_(ChromeThread::IO, &message_loop_) {}
+ DownloadRequestLimiterTest() : io_thread_(ChromeThread::IO, &message_loop_) {}
virtual void SetUp() {
RenderViewHostTestHarness::SetUp();
@@ -21,13 +21,13 @@ class DownloadRequestManagerTest
allow_download_ = true;
ask_allow_count_ = cancel_count_ = continue_count_ = 0;
- download_request_manager_ = new DownloadRequestManager();
- test_delegate_.reset(new DownloadRequestManagerTestDelegate(this));
- DownloadRequestManager::SetTestingDelegate(test_delegate_.get());
+ download_request_limiter_ = new DownloadRequestLimiter();
+ test_delegate_.reset(new DownloadRequestLimiterTestDelegate(this));
+ DownloadRequestLimiter::SetTestingDelegate(test_delegate_.get());
}
virtual void TearDown() {
- DownloadRequestManager::SetTestingDelegate(NULL);
+ DownloadRequestLimiter::SetTestingDelegate(NULL);
RenderViewHostTestHarness::TearDown();
}
@@ -44,7 +44,7 @@ class DownloadRequestManagerTest
}
void CanDownload() {
- download_request_manager_->CanDownloadImpl(
+ download_request_limiter_->CanDownloadImpl(
controller().tab_contents(), this);
message_loop_.RunAllPending();
}
@@ -55,11 +55,11 @@ class DownloadRequestManagerTest
}
protected:
- class DownloadRequestManagerTestDelegate
- : public DownloadRequestManager::TestingDelegate {
+ class DownloadRequestLimiterTestDelegate
+ : public DownloadRequestLimiter::TestingDelegate {
public:
- explicit DownloadRequestManagerTestDelegate(
- DownloadRequestManagerTest* test)
+ explicit DownloadRequestLimiterTestDelegate(
+ DownloadRequestLimiterTest* test)
: test_(test) { }
virtual bool ShouldAllowDownload() {
@@ -67,11 +67,11 @@ class DownloadRequestManagerTest
}
private:
- DownloadRequestManagerTest* test_;
+ DownloadRequestLimiterTest* test_;
};
- scoped_ptr<DownloadRequestManagerTestDelegate> test_delegate_;
- scoped_refptr<DownloadRequestManager> download_request_manager_;
+ scoped_ptr<DownloadRequestLimiterTestDelegate> test_delegate_;
+ scoped_refptr<DownloadRequestLimiter> download_request_limiter_;
// Number of times ContinueDownload was invoked.
int continue_count_;
@@ -89,16 +89,16 @@ class DownloadRequestManagerTest
};
// http://code.google.com/p/chromium/issues/detail?id=39753
-TEST_F(DownloadRequestManagerTest, FLAKY_Allow) {
+TEST_F(DownloadRequestLimiterTest, FLAKY_Allow) {
// All tabs should initially start at ALLOW_ONE_DOWNLOAD.
- ASSERT_EQ(DownloadRequestManager::ALLOW_ONE_DOWNLOAD,
- download_request_manager_->GetDownloadStatus(
+ ASSERT_EQ(DownloadRequestLimiter::ALLOW_ONE_DOWNLOAD,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// Ask if the tab can do a download. This moves to PROMPT_BEFORE_DOWNLOAD.
CanDownload();
- ASSERT_EQ(DownloadRequestManager::PROMPT_BEFORE_DOWNLOAD,
- download_request_manager_->GetDownloadStatus(
+ ASSERT_EQ(DownloadRequestLimiter::PROMPT_BEFORE_DOWNLOAD,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// We should have been told we can download.
ASSERT_EQ(1, continue_count_);
@@ -112,8 +112,8 @@ TEST_F(DownloadRequestManagerTest, FLAKY_Allow) {
// This should ask us if the download is allowed.
ASSERT_EQ(1, ask_allow_count_);
ask_allow_count_ = 0;
- ASSERT_EQ(DownloadRequestManager::ALLOW_ALL_DOWNLOADS,
- download_request_manager_->GetDownloadStatus(
+ ASSERT_EQ(DownloadRequestLimiter::ALLOW_ALL_DOWNLOADS,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// We should have been told we can download.
ASSERT_EQ(1, continue_count_);
@@ -124,8 +124,8 @@ TEST_F(DownloadRequestManagerTest, FLAKY_Allow) {
CanDownload();
// The state is at allow_all, which means the delegate shouldn't be asked.
ASSERT_EQ(0, ask_allow_count_);
- ASSERT_EQ(DownloadRequestManager::ALLOW_ALL_DOWNLOADS,
- download_request_manager_->GetDownloadStatus(
+ ASSERT_EQ(DownloadRequestLimiter::ALLOW_ALL_DOWNLOADS,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// We should have been told we can download.
ASSERT_EQ(1, continue_count_);
@@ -133,7 +133,7 @@ TEST_F(DownloadRequestManagerTest, FLAKY_Allow) {
continue_count_ = 0;
}
-TEST_F(DownloadRequestManagerTest, ResetOnNavigation) {
+TEST_F(DownloadRequestLimiterTest, ResetOnNavigation) {
NavigateAndCommit(GURL("http://foo.com/bar"));
// Do two downloads, allowing the second so that we end up with allow all.
@@ -141,8 +141,8 @@ TEST_F(DownloadRequestManagerTest, ResetOnNavigation) {
allow_download_ = true;
CanDownload();
ask_allow_count_ = continue_count_ = cancel_count_ = 0;
- ASSERT_EQ(DownloadRequestManager::ALLOW_ALL_DOWNLOADS,
- download_request_manager_->GetDownloadStatus(
+ ASSERT_EQ(DownloadRequestLimiter::ALLOW_ALL_DOWNLOADS,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// Navigate to a new URL with the same host, which shouldn't reset the allow
@@ -153,38 +153,38 @@ TEST_F(DownloadRequestManagerTest, ResetOnNavigation) {
ASSERT_EQ(0, cancel_count_);
ASSERT_EQ(0, ask_allow_count_);
ask_allow_count_ = continue_count_ = cancel_count_ = 0;
- ASSERT_EQ(DownloadRequestManager::ALLOW_ALL_DOWNLOADS,
- download_request_manager_->GetDownloadStatus(
+ ASSERT_EQ(DownloadRequestLimiter::ALLOW_ALL_DOWNLOADS,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// Do a user gesture, because we're at allow all, this shouldn't change the
// state.
- download_request_manager_->OnUserGesture(controller().tab_contents());
- ASSERT_EQ(DownloadRequestManager::ALLOW_ALL_DOWNLOADS,
- download_request_manager_->GetDownloadStatus(
+ download_request_limiter_->OnUserGesture(controller().tab_contents());
+ ASSERT_EQ(DownloadRequestLimiter::ALLOW_ALL_DOWNLOADS,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// Navigate to a completely different host, which should reset the state.
NavigateAndCommit(GURL("http://fooey.com"));
- ASSERT_EQ(DownloadRequestManager::ALLOW_ONE_DOWNLOAD,
- download_request_manager_->GetDownloadStatus(
+ ASSERT_EQ(DownloadRequestLimiter::ALLOW_ONE_DOWNLOAD,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
}
-TEST_F(DownloadRequestManagerTest, ResetOnUserGesture) {
+TEST_F(DownloadRequestLimiterTest, ResetOnUserGesture) {
NavigateAndCommit(GURL("http://foo.com/bar"));
// Do one download, which should change to prompt before download.
CanDownload();
ask_allow_count_ = continue_count_ = cancel_count_ = 0;
- ASSERT_EQ(DownloadRequestManager::PROMPT_BEFORE_DOWNLOAD,
- download_request_manager_->GetDownloadStatus(
+ ASSERT_EQ(DownloadRequestLimiter::PROMPT_BEFORE_DOWNLOAD,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// Do a user gesture, which should reset back to allow one.
- download_request_manager_->OnUserGesture(controller().tab_contents());
- ASSERT_EQ(DownloadRequestManager::ALLOW_ONE_DOWNLOAD,
- download_request_manager_->GetDownloadStatus(
+ download_request_limiter_->OnUserGesture(controller().tab_contents());
+ ASSERT_EQ(DownloadRequestLimiter::ALLOW_ONE_DOWNLOAD,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// Ask twice, which triggers calling the delegate. Don't allow the download
@@ -192,14 +192,14 @@ TEST_F(DownloadRequestManagerTest, ResetOnUserGesture) {
allow_download_ = false;
CanDownload();
CanDownload();
- ASSERT_EQ(DownloadRequestManager::DOWNLOADS_NOT_ALLOWED,
- download_request_manager_->GetDownloadStatus(
+ ASSERT_EQ(DownloadRequestLimiter::DOWNLOADS_NOT_ALLOWED,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// A user gesture now should NOT change the state.
- download_request_manager_->OnUserGesture(controller().tab_contents());
- ASSERT_EQ(DownloadRequestManager::DOWNLOADS_NOT_ALLOWED,
- download_request_manager_->GetDownloadStatus(
+ download_request_limiter_->OnUserGesture(controller().tab_contents());
+ ASSERT_EQ(DownloadRequestLimiter::DOWNLOADS_NOT_ALLOWED,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
// And make sure we really can't download.
ask_allow_count_ = continue_count_ = cancel_count_ = 0;
@@ -208,7 +208,7 @@ TEST_F(DownloadRequestManagerTest, ResetOnUserGesture) {
ASSERT_EQ(0, continue_count_);
ASSERT_EQ(1, cancel_count_);
// And the state shouldn't have changed.
- ASSERT_EQ(DownloadRequestManager::DOWNLOADS_NOT_ALLOWED,
- download_request_manager_->GetDownloadStatus(
+ ASSERT_EQ(DownloadRequestLimiter::DOWNLOADS_NOT_ALLOWED,
+ download_request_limiter_->GetDownloadStatus(
controller().tab_contents()));
}