From 7074e6880ba3af4dcf35ec191704fe4342fc6d27 Mon Sep 17 00:00:00 2001 From: "scottbyer@chromium.org" Date: Fri, 11 Jun 2010 21:10:58 +0000 Subject: Fix crashy test. http://code.google.com/p/chromium/issues/detail?id=44547 BUG=44547 TEST=PrintDialogCloudTest.HandlersRegistered git-svn-id: svn://svn.chromium.org/chrome/trunk/src@49592 0039d316-1c4b-4281-b951-d872f2087c98 --- chrome/browser/printing/print_dialog_cloud.cc | 2 +- chrome/browser/printing/print_dialog_cloud.h | 2 +- .../browser/printing/print_dialog_cloud_uitest.cc | 65 +++++++++++++++------- 3 files changed, 48 insertions(+), 21 deletions(-) diff --git a/chrome/browser/printing/print_dialog_cloud.cc b/chrome/browser/printing/print_dialog_cloud.cc index 5da3a2ff..796a81d 100644 --- a/chrome/browser/printing/print_dialog_cloud.cc +++ b/chrome/browser/printing/print_dialog_cloud.cc @@ -104,7 +104,7 @@ void CloudPrintService::RegisterPreferences() { if (pref_service->FindPreference(prefs::kCloudPrintServiceURL)) return; std::wstring kDefaultCloudPrintServiceURL( - L"http://www.google.com/cloudprint"); + L"https://www.google.com/cloudprint"); pref_service->RegisterStringPref(prefs::kCloudPrintServiceURL, kDefaultCloudPrintServiceURL); } diff --git a/chrome/browser/printing/print_dialog_cloud.h b/chrome/browser/printing/print_dialog_cloud.h index 175103a..a9736bd 100644 --- a/chrome/browser/printing/print_dialog_cloud.h +++ b/chrome/browser/printing/print_dialog_cloud.h @@ -20,7 +20,7 @@ class PrintDialogCloud { static void CreatePrintDialogForPdf(const FilePath& path_to_pdf); private: - FRIEND_TEST_ALL_PREFIXES(PrintDialogCloudTest, HandlersRegistered); + FRIEND_TEST(PrintDialogCloudTest, HandlersRegistered); explicit PrintDialogCloud(const FilePath& path_to_pdf); ~PrintDialogCloud(); diff --git a/chrome/browser/printing/print_dialog_cloud_uitest.cc b/chrome/browser/printing/print_dialog_cloud_uitest.cc index 469c060..ec8da96 100644 --- a/chrome/browser/printing/print_dialog_cloud_uitest.cc +++ b/chrome/browser/printing/print_dialog_cloud_uitest.cc @@ -50,6 +50,26 @@ class SimpleTestJob : public URLRequestTestJob { explicit SimpleTestJob(URLRequest* request) : URLRequestTestJob(request, test_headers(), Singleton()->GetTestData(), true) {} + + virtual void GetResponseInfo(net::HttpResponseInfo* info) { + URLRequestTestJob::GetResponseInfo(info); + if (request_->url().SchemeIsSecure()) { + // Make up a fake certificate for this response since we don't have + // access to the real SSL info. + const char* kCertIssuer = "Chrome Internal"; + const int kLifetimeDays = 100; + + info->ssl_info.cert = + new net::X509Certificate(request_->url().GetWithEmptyPath().spec(), + kCertIssuer, + base::Time::Now(), + base::Time::Now() + + base::TimeDelta::FromDays(kLifetimeDays)); + info->ssl_info.cert_status = 0; + info->ssl_info.security_bits = 0; + } + } + private: ~SimpleTestJob() {} }; @@ -69,15 +89,21 @@ class TestResult { const GURL GetExpectedUrl() { return expected_url_; } + void set_delegate(TestDelegate* delegate) { + delegate_ = delegate; + } + TestDelegate* delegate() { + return delegate_; + } private: bool result_; GURL expected_url_; + TestDelegate* delegate_; }; } // namespace -class PrintDialogCloudTest : public InProcessBrowserTest, - public NotificationObserver { +class PrintDialogCloudTest : public InProcessBrowserTest { public: PrintDialogCloudTest() : handler_added_(false) { PathService::Get(chrome::DIR_TEST_DATA, &test_data_directory_); @@ -86,6 +112,16 @@ class PrintDialogCloudTest : public InProcessBrowserTest, // Must be static for handing into AddHostnameHandler. static URLRequest::ProtocolFactory Factory; + class PrintDialogCloudTestDelegate : public TestDelegate { + public: + PrintDialogCloudTestDelegate() {} + + virtual void OnResponseCompleted(URLRequest* request) { + ChromeThread::PostTask(ChromeThread::UI, FROM_HERE, + new MessageLoop::QuitTask()); + } + }; + virtual void SetUp() { Singleton()->SetResult(false); InProcessBrowserTest::SetUp(); @@ -96,6 +132,7 @@ class PrintDialogCloudTest : public InProcessBrowserTest, URLRequestFilter* filter = URLRequestFilter::GetInstance(); filter->RemoveHostnameHandler(scheme_, host_name_); handler_added_ = false; + Singleton()->set_delegate(NULL); } InProcessBrowserTest::TearDown(); } @@ -116,23 +153,11 @@ class PrintDialogCloudTest : public InProcessBrowserTest, &PrintDialogCloudTest::Factory); handler_added_ = true; - registrar_.Add(this, NotificationType::LOAD_STOP, - NotificationService::AllSources()); - GURL cloud_print_dialog_url = internal_cloud_print_helpers::CloudPrintService(browser()->profile()). GetCloudPrintServiceDialogURL(); Singleton()->SetExpectedUrl(cloud_print_dialog_url); - } - } - - virtual void Observe(NotificationType type, - const NotificationSource& source, - const NotificationDetails& details) { - if (type == NotificationType::LOAD_STOP) { - MessageLoop::current()->PostTask(FROM_HERE, new MessageLoop::QuitTask()); - registrar_.Remove(this, NotificationType::LOAD_STOP, - NotificationService::AllSources()); + Singleton()->set_delegate(&delegate_); } } @@ -140,18 +165,18 @@ class PrintDialogCloudTest : public InProcessBrowserTest, std::string scheme_; std::string host_name_; FilePath test_data_directory_; - NotificationRegistrar registrar_; + PrintDialogCloudTestDelegate delegate_; }; URLRequestJob* PrintDialogCloudTest::Factory(URLRequest* request, const std::string& scheme) { + request->set_delegate(Singleton()->delegate()); if (request && (request->url() == Singleton()->GetExpectedUrl())) Singleton()->SetResult(true); return new SimpleTestJob(request); } -// Crashy, http://crbug.com/44547. -IN_PROC_BROWSER_TEST_F(PrintDialogCloudTest, DISABLED_HandlersRegistered) { +IN_PROC_BROWSER_TEST_F(PrintDialogCloudTest, HandlersRegistered) { BrowserList::SetLastActive(browser()); ASSERT_TRUE(BrowserList::GetLastActive()); @@ -159,9 +184,11 @@ IN_PROC_BROWSER_TEST_F(PrintDialogCloudTest, DISABLED_HandlersRegistered) { FilePath pdf_file = test_data_directory_.AppendASCII("printing/cloud_print_uitest.pdf"); - new PrintDialogCloud(pdf_file); + { + PrintDialogCloud dialog (pdf_file); ui_test_utils::RunMessageLoop(); + } ASSERT_TRUE(Singleton()->GetResult()); } -- cgit v1.1