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

Side by Side Diff: content/browser/browser_url_handler_impl_unittest.cc

Issue 11340029: Move remaining files in content\browser to the content namespace. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 8 years, 1 month 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 (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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 "content/browser/browser_url_handler_impl.h" 5 #include "content/browser/browser_url_handler_impl.h"
6 #include "content/public/test/test_browser_context.h" 6 #include "content/public/test/test_browser_context.h"
7 #include "googleurl/src/gurl.h" 7 #include "googleurl/src/gurl.h"
8 #include "testing/gtest/include/gtest/gtest.h" 8 #include "testing/gtest/include/gtest/gtest.h"
9 9
10 namespace content {
11
10 class BrowserURLHandlerImplTest : public testing::Test { 12 class BrowserURLHandlerImplTest : public testing::Test {
11 }; 13 };
12 14
13 // Test URL rewriter that rewrites all "foo://" URLs to "bar://bar". 15 // Test URL rewriter that rewrites all "foo://" URLs to "bar://bar".
14 static bool FooRewriter(GURL* url, content::BrowserContext* browser_context) { 16 static bool FooRewriter(GURL* url, BrowserContext* browser_context) {
15 if (url->scheme() == "foo") { 17 if (url->scheme() == "foo") {
16 *url = GURL("bar://bar"); 18 *url = GURL("bar://bar");
17 return true; 19 return true;
18 } 20 }
19 return false; 21 return false;
20 } 22 }
21 23
22 // Test URL rewriter that rewrites all "bar://" URLs to "foo://foo". 24 // Test URL rewriter that rewrites all "bar://" URLs to "foo://foo".
23 static bool BarRewriter(GURL* url, content::BrowserContext* browser_context) { 25 static bool BarRewriter(GURL* url, BrowserContext* browser_context) {
24 if (url->scheme() == "bar") { 26 if (url->scheme() == "bar") {
25 *url = GURL("foo://foo"); 27 *url = GURL("foo://foo");
26 return true; 28 return true;
27 } 29 }
28 return false; 30 return false;
29 } 31 }
30 32
31 TEST_F(BrowserURLHandlerImplTest, BasicRewriteAndReverse) { 33 TEST_F(BrowserURLHandlerImplTest, BasicRewriteAndReverse) {
32 content::TestBrowserContext browser_context; 34 TestBrowserContext browser_context;
33 BrowserURLHandlerImpl handler; 35 BrowserURLHandlerImpl handler;
34 36
35 handler.AddHandlerPair(FooRewriter, BarRewriter); 37 handler.AddHandlerPair(FooRewriter, BarRewriter);
36 38
37 GURL url("foo://bar"); 39 GURL url("foo://bar");
38 GURL original_url(url); 40 GURL original_url(url);
39 bool reverse_on_redirect = false; 41 bool reverse_on_redirect = false;
40 handler.RewriteURLIfNecessary(&url, &browser_context, &reverse_on_redirect); 42 handler.RewriteURLIfNecessary(&url, &browser_context, &reverse_on_redirect);
41 ASSERT_TRUE(reverse_on_redirect); 43 ASSERT_TRUE(reverse_on_redirect);
42 ASSERT_EQ("bar://bar", url.spec()); 44 ASSERT_EQ("bar://bar", url.spec());
43 45
44 // Check that reversing the URL works. 46 // Check that reversing the URL works.
45 GURL saved_url(url); 47 GURL saved_url(url);
46 bool reversed = handler.ReverseURLRewrite(&url, 48 bool reversed = handler.ReverseURLRewrite(&url,
47 original_url, 49 original_url,
48 &browser_context); 50 &browser_context);
49 ASSERT_TRUE(reversed); 51 ASSERT_TRUE(reversed);
50 ASSERT_EQ("foo://foo", url.spec()); 52 ASSERT_EQ("foo://foo", url.spec());
51 53
52 // Check that reversing the URL only works with a matching |original_url|. 54 // Check that reversing the URL only works with a matching |original_url|.
53 url = saved_url; 55 url = saved_url;
54 original_url = GURL("bam://bam"); // Won't be matched by FooRewriter. 56 original_url = GURL("bam://bam"); // Won't be matched by FooRewriter.
55 reversed = handler.ReverseURLRewrite(&url, original_url, &browser_context); 57 reversed = handler.ReverseURLRewrite(&url, original_url, &browser_context);
56 ASSERT_FALSE(reversed); 58 ASSERT_FALSE(reversed);
57 ASSERT_EQ(saved_url, url); 59 ASSERT_EQ(saved_url, url);
58 } 60 }
59 61
60 TEST_F(BrowserURLHandlerImplTest, NullHandlerReverse) { 62 TEST_F(BrowserURLHandlerImplTest, NullHandlerReverse) {
61 content::TestBrowserContext browser_context; 63 TestBrowserContext browser_context;
62 BrowserURLHandlerImpl handler; 64 BrowserURLHandlerImpl handler;
63 65
64 GURL url("bar://foo"); 66 GURL url("bar://foo");
65 GURL original_url(url); 67 GURL original_url(url);
66 68
67 handler.AddHandlerPair(BrowserURLHandlerImpl::null_handler(), FooRewriter); 69 handler.AddHandlerPair(BrowserURLHandlerImpl::null_handler(), FooRewriter);
68 bool reversed = handler.ReverseURLRewrite(&url, 70 bool reversed = handler.ReverseURLRewrite(&url,
69 original_url, 71 original_url,
70 &browser_context); 72 &browser_context);
71 ASSERT_FALSE(reversed); 73 ASSERT_FALSE(reversed);
72 ASSERT_EQ(original_url, url); 74 ASSERT_EQ(original_url, url);
73 75
74 handler.AddHandlerPair(BrowserURLHandlerImpl::null_handler(), BarRewriter); 76 handler.AddHandlerPair(BrowserURLHandlerImpl::null_handler(), BarRewriter);
75 reversed = handler.ReverseURLRewrite(&url, original_url, &browser_context); 77 reversed = handler.ReverseURLRewrite(&url, original_url, &browser_context);
76 ASSERT_TRUE(reversed); 78 ASSERT_TRUE(reversed);
77 ASSERT_EQ("foo://foo", url.spec()); 79 ASSERT_EQ("foo://foo", url.spec());
78 } 80 }
81
82 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698