summaryrefslogtreecommitdiffstats
path: root/chrome/browser
diff options
context:
space:
mode:
authormaruel@chromium.org <maruel@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-11-18 16:10:01 +0000
committermaruel@chromium.org <maruel@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-11-18 16:10:01 +0000
commite0a89d9555ffb8575be21c3a96564d59aeb44c82 (patch)
tree5b3ca8e4637b8d194db5f5d96b70457a60bd99a6 /chrome/browser
parent8c2990ccf93794012497fe2a03291392abf400e0 (diff)
downloadchromium_src-e0a89d9555ffb8575be21c3a96564d59aeb44c82.zip
chromium_src-e0a89d9555ffb8575be21c3a96564d59aeb44c82.tar.gz
chromium_src-e0a89d9555ffb8575be21c3a96564d59aeb44c82.tar.bz2
Revert 5607 because it caused a base_unittest failure.
Review URL: http://codereview.chromium.org/11234 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@5608 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser')
-rw-r--r--chrome/browser/printing/print_job.cc12
-rw-r--r--chrome/browser/printing/print_job.h9
-rw-r--r--chrome/browser/printing/print_job_unittest.cc117
3 files changed, 2 insertions, 136 deletions
diff --git a/chrome/browser/printing/print_job.cc b/chrome/browser/printing/print_job.cc
index 14a487cd..a2d07fd 100644
--- a/chrome/browser/printing/print_job.cc
+++ b/chrome/browser/printing/print_job.cc
@@ -24,8 +24,6 @@ PrintJob::PrintJob(PrintedPagesSource* source)
is_job_pending_(false),
is_print_dialog_box_shown_(false),
is_canceling_(false) {
- DCHECK(ui_message_loop_);
- ui_message_loop_->AddDestructionObserver(this);
}
PrintJob::PrintJob()
@@ -36,18 +34,14 @@ PrintJob::PrintJob()
is_job_pending_(false),
is_print_dialog_box_shown_(false),
is_canceling_(false) {
- DCHECK(ui_message_loop_);
- ui_message_loop_->AddDestructionObserver(this);
}
PrintJob::~PrintJob() {
- ui_message_loop_->RemoveDestructionObserver(this);
// The job should be finished (or at least canceled) when it is destroyed.
DCHECK(!is_job_pending_);
DCHECK(!is_print_dialog_box_shown_);
DCHECK(!is_canceling_);
- if (worker_.get())
- DCHECK(worker_->message_loop() == NULL);
+ DCHECK(worker_->message_loop() == NULL);
DCHECK_EQ(ui_message_loop_, MessageLoop::current());
}
@@ -148,10 +142,6 @@ int PrintJob::cookie() const {
return document_->cookie();
}
-void PrintJob::WillDestroyCurrentMessageLoop() {
- NOTREACHED();
-}
-
void PrintJob::GetSettings(GetSettingsAskParam ask_user_for_settings,
HWND parent_window) {
DCHECK_EQ(ui_message_loop_, MessageLoop::current());
diff --git a/chrome/browser/printing/print_job.h b/chrome/browser/printing/print_job.h
index 4c334b9..e18d52c 100644
--- a/chrome/browser/printing/print_job.h
+++ b/chrome/browser/printing/print_job.h
@@ -5,7 +5,6 @@
#ifndef CHROME_BROWSER_PRINTING_PRINT_JOB_H_
#define CHROME_BROWSER_PRINTING_PRINT_JOB_H_
-#include "base/message_loop.h"
#include "base/ref_counted.h"
#include "chrome/browser/printing/print_job_worker_owner.h"
#include "chrome/common/notification_service.h"
@@ -33,8 +32,7 @@ class PrinterQuery;
// runs in the UI thread.
class PrintJob : public base::RefCountedThreadSafe<PrintJob>,
public NotificationObserver,
- public PrintJobWorkerOwner,
- public MessageLoop::DestructionObserver {
+ public PrintJobWorkerOwner {
public:
// GetSettings() UI parameter.
enum GetSettingsAskParam {
@@ -50,8 +48,6 @@ class PrintJob : public base::RefCountedThreadSafe<PrintJob>,
PrintJob();
virtual ~PrintJob();
- // Grabs the ownership of the PrintJobWorker from another job, which is
- // usually a PrinterQuery.
void Initialize(PrintJobWorkerOwner* job, PrintedPagesSource* source);
// NotificationObserver
@@ -73,9 +69,6 @@ class PrintJob : public base::RefCountedThreadSafe<PrintJob>,
virtual const PrintSettings& settings() const { return settings_; }
virtual int cookie() const;
- // DestructionObserver
- virtual void WillDestroyCurrentMessageLoop();
-
// Initializes the printing context. This can be done synchronously or not. It
// is fine to call this function multiple times to reinitialize the settings.
// |parent_window| parameter will be the owner of the print setting dialog
diff --git a/chrome/browser/printing/print_job_unittest.cc b/chrome/browser/printing/print_job_unittest.cc
deleted file mode 100644
index 6c65a5d..0000000
--- a/chrome/browser/printing/print_job_unittest.cc
+++ /dev/null
@@ -1,117 +0,0 @@
-// Copyright (c) 2008 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 "base/message_loop.h"
-#include "chrome/browser/printing/print_job.h"
-#include "chrome/browser/printing/printed_pages_source.h"
-#include "googleurl/src/gurl.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-namespace {
-
-class TestSource : public printing::PrintedPagesSource {
- public:
- virtual void RenderOnePrintedPage(printing::PrintedDocument* document,
- int page_number) {
- }
- virtual std::wstring RenderSourceName() {
- return L"";
- }
- virtual GURL RenderSourceUrl() {
- return GURL();
- }
-};
-
-class TestPrintJob : public printing::PrintJob {
- public:
- TestPrintJob(printing::PrintedPagesSource* source, volatile bool* check)
- : printing::PrintJob(source), check_(check) {
- }
- TestPrintJob(volatile bool* check) : check_(check) {
- }
- ~TestPrintJob() {
- *check_ = true;
- }
- private:
- volatile bool* check_;
-};
-
-class TestPrintNotifObserv : public NotificationObserver {
- public:
- // NotificationObserver
- virtual void Observe(NotificationType type,
- const NotificationSource& source,
- const NotificationDetails& details) {
- ASSERT_EQ(NOTIFY_PRINT_JOB_EVENT, type);
- printing::JobEventDetails::Type event_type =
- Details<printing::JobEventDetails>(details)->type();
- EXPECT_NE(printing::JobEventDetails::NEW_DOC, event_type);
- EXPECT_NE(printing::JobEventDetails::NEW_PAGE, event_type);
- EXPECT_NE(printing::JobEventDetails::PAGE_DONE, event_type);
- EXPECT_NE(printing::JobEventDetails::DOC_DONE, event_type);
- EXPECT_NE(printing::JobEventDetails::JOB_DONE, event_type);
- EXPECT_NE(printing::JobEventDetails::ALL_PAGES_REQUESTED, event_type);
- if (event_type == printing::JobEventDetails::USER_INIT_DONE ||
- event_type == printing::JobEventDetails::USER_INIT_CANCELED ||
- event_type == printing::JobEventDetails::DEFAULT_INIT_DONE ||
- event_type == printing::JobEventDetails::FAILED) {
- MessageLoop::current()->Quit();
- return;
- }
- }
-};
-
-} // namespace
-
-TEST(PrintJobTest, SimplePrint) {
- // Test the multithreaded nature of PrintJob to make sure we can use it with
- // known livetime.
- TestPrintNotifObserv observ;
- MessageLoop current;
- NotificationService::current()->AddObserver(
- &observ, NOTIFY_ALL,
- NotificationService::AllSources());
- TestSource source;
- volatile bool check = false;
- scoped_refptr<printing::PrintJob> job(new TestPrintJob(&source, &check));
- job->GetSettings(printing::PrintJob::DEFAULTS, NULL);
- EXPECT_EQ(MessageLoop::current(), job->message_loop());
- current.Run();
- job->Stop();
- job = NULL;
- EXPECT_TRUE(check);
-}
-
-TEST(PrintJobTest, SimplePrintLateInit) {
- volatile bool check = false;
- MessageLoop current;
- scoped_refptr<printing::PrintJob> job(new TestPrintJob(&check));
- job = NULL;
- EXPECT_TRUE(check);
- /* TODO(maruel): Test these.
- job->Initialize()
- job->Observe();
- job->GetSettingsDone();
- job->DetachWorker();
- job->message_loop();
- job->settings();
- job->cookie();
- job->GetSettings(printing::DEFAULTS, printing::ASK_USER, NULL);
- job->StartPrinting();
- job->Stop();
- job->Cancel();
- job->RequestMissingPages();
- job->FlushJob(timeout_ms);
- job->DisconnectSource();
- job->is_job_pending();
- job->is_print_dialog_box_shown();
- job->document();
- // Private
- job->UpdatePrintedDocument(NULL);
- scoped_refptr<printing::JobEventDetails> event_details;
- job->OnNotifyPrintJobEvent(event_details);
- job->OnDocumentDone();
- job->ControlledWorkerShutdown();
- */
-}