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

Side by Side Diff: chrome/browser/chromeos/login/eula_browsertest.cc

Issue 23625015: Consolidate TestURLFetcherFactory::SetFakeResponse (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Could have spelled it Cloud... Created 7 years, 3 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "base/strings/utf_string_conversions.h" 5 #include "base/strings/utf_string_conversions.h"
6 #include "chrome/browser/ui/browser.h" 6 #include "chrome/browser/ui/browser.h"
7 #include "chrome/browser/ui/tabs/tab_strip_model.h" 7 #include "chrome/browser/ui/tabs/tab_strip_model.h"
8 #include "chrome/common/url_constants.h" 8 #include "chrome/common/url_constants.h"
9 #include "chrome/test/base/in_process_browser_test.h" 9 #include "chrome/test/base/in_process_browser_test.h"
10 #include "chrome/test/base/ui_test_utils.h" 10 #include "chrome/test/base/ui_test_utils.h"
11 #include "content/public/test/browser_test_utils.h" 11 #include "content/public/test/browser_test_utils.h"
12 #include "net/http/http_response_headers.h" 12 #include "net/http/http_response_headers.h"
13 #include "net/url_request/test_url_fetcher_factory.h" 13 #include "net/url_request/test_url_fetcher_factory.h"
14 #include "testing/gmock/include/gmock/gmock.h" 14 #include "testing/gmock/include/gmock/gmock.h"
15 15
16 using ::testing::Exactly; 16 using ::testing::Exactly;
17 using ::testing::Invoke; 17 using ::testing::Invoke;
18 using ::testing::_; 18 using ::testing::_;
19 19
20 namespace { 20 namespace {
21 21
22 const char kEULAURL[] = "https://www.google.com/intl/en-US/chrome/eula_text.html "; 22 const char kEULAURL[] =
akalin 2013/09/19 18:54:00 may as well change this to a const GURL -- static
Mattias Nissler (ping if slow) 2013/09/20 15:33:53 Makes sense, but suprisingly it's the first time I
akalin 2013/09/20 23:06:43 Consulted with other people, and I think you're ri
23 "https://www.google.com/intl/en-US/chrome/eula_text.html";
23 const char kFakeOnlineEULA[] = "No obligations at all"; 24 const char kFakeOnlineEULA[] = "No obligations at all";
24 const char kOfflineEULAWarning[] = "A copy of the Google Terms of Service"; 25 const char kOfflineEULAWarning[] = "A copy of the Google Terms of Service";
25 26
26 class TermsOfServiceProcessBrowserTest : public InProcessBrowserTest { 27 class TermsOfServiceProcessBrowserTest : public InProcessBrowserTest {
27 }; 28 };
28 29
29 class TestURLFetcherCallback { 30 class TestURLFetcherCallback {
30 public: 31 public:
31 scoped_ptr<net::FakeURLFetcher> CreateURLFetcher( 32 scoped_ptr<net::FakeURLFetcher> CreateURLFetcher(
32 const GURL& url, 33 const GURL& url,
(...skipping 16 matching lines...) Expand all
49 fetcher->set_response_headers(download_headers); 50 fetcher->set_response_headers(download_headers);
50 } 51 }
51 52
52 // Load chrome://terms. Make sure online version is shown. 53 // Load chrome://terms. Make sure online version is shown.
53 IN_PROC_BROWSER_TEST_F(TermsOfServiceProcessBrowserTest, LoadOnline) { 54 IN_PROC_BROWSER_TEST_F(TermsOfServiceProcessBrowserTest, LoadOnline) {
54 TestURLFetcherCallback url_callback; 55 TestURLFetcherCallback url_callback;
55 net::FakeURLFetcherFactory factory( 56 net::FakeURLFetcherFactory factory(
56 NULL, 57 NULL,
57 base::Bind(&TestURLFetcherCallback::CreateURLFetcher, 58 base::Bind(&TestURLFetcherCallback::CreateURLFetcher,
58 base::Unretained(&url_callback))); 59 base::Unretained(&url_callback)));
59 factory.SetFakeResponse(kEULAURL, kFakeOnlineEULA, true); 60 factory.SetFakeResponse(GURL(kEULAURL), kFakeOnlineEULA, true);
60 EXPECT_CALL(url_callback, OnRequestCreate(GURL(kEULAURL), _)) 61 EXPECT_CALL(url_callback, OnRequestCreate(GURL(kEULAURL), _))
61 .Times(Exactly(1)) 62 .Times(Exactly(1))
62 .WillRepeatedly(Invoke(AddMimeHeader)); 63 .WillRepeatedly(Invoke(AddMimeHeader));
63 64
64 ui_test_utils::NavigateToURL(browser(), GURL(chrome::kChromeUITermsURL)); 65 ui_test_utils::NavigateToURL(browser(), GURL(chrome::kChromeUITermsURL));
65 content::WebContents* web_contents = 66 content::WebContents* web_contents =
66 browser()->tab_strip_model()->GetActiveWebContents(); 67 browser()->tab_strip_model()->GetActiveWebContents();
67 EXPECT_EQ(1, ui_test_utils::FindInPage(web_contents, 68 EXPECT_EQ(1, ui_test_utils::FindInPage(web_contents,
68 ASCIIToUTF16(kFakeOnlineEULA), 69 ASCIIToUTF16(kFakeOnlineEULA),
69 true, 70 true,
70 true, 71 true,
71 NULL, 72 NULL,
72 NULL)); 73 NULL));
73 } 74 }
74 75
75 // Load chrome://terms with no internet connectivity. 76 // Load chrome://terms with no internet connectivity.
76 // Make sure offline version is shown. 77 // Make sure offline version is shown.
77 IN_PROC_BROWSER_TEST_F(TermsOfServiceProcessBrowserTest, LoadOffline) { 78 IN_PROC_BROWSER_TEST_F(TermsOfServiceProcessBrowserTest, LoadOffline) {
78 net::FakeURLFetcherFactory factory(NULL); 79 net::FakeURLFetcherFactory factory(NULL);
79 factory.SetFakeResponse(kEULAURL, "", false); 80 factory.SetFakeResponse(GURL(kEULAURL), "", false);
80 81
81 ui_test_utils::NavigateToURL(browser(), GURL(chrome::kChromeUITermsURL)); 82 ui_test_utils::NavigateToURL(browser(), GURL(chrome::kChromeUITermsURL));
82 content::WebContents* web_contents = 83 content::WebContents* web_contents =
83 browser()->tab_strip_model()->GetActiveWebContents(); 84 browser()->tab_strip_model()->GetActiveWebContents();
84 85
85 #if defined(GOOGLE_CHROME_BUILD) 86 #if defined(GOOGLE_CHROME_BUILD)
86 EXPECT_NE(0, ui_test_utils::FindInPage(web_contents, 87 EXPECT_NE(0, ui_test_utils::FindInPage(web_contents,
87 ASCIIToUTF16(kOfflineEULAWarning), 88 ASCIIToUTF16(kOfflineEULAWarning),
88 true, 89 true,
89 true, 90 true,
90 NULL, 91 NULL,
91 NULL)); 92 NULL));
92 #else 93 #else
93 std::string body; 94 std::string body;
94 ASSERT_TRUE(content::ExecuteScriptAndExtractString( 95 ASSERT_TRUE(content::ExecuteScriptAndExtractString(
95 web_contents, 96 web_contents,
96 "window.domAutomationController.send(document.body.textContent)", 97 "window.domAutomationController.send(document.body.textContent)",
97 &body)); 98 &body));
98 EXPECT_NE(std::string(), body); 99 EXPECT_NE(std::string(), body);
99 #endif 100 #endif
100 } 101 }
101 102
102 } // namespace 103 } // namespace
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698