diff options
author | jam@chromium.org <jam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-03-12 19:07:31 +0000 |
---|---|---|
committer | jam@chromium.org <jam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-03-12 19:07:31 +0000 |
commit | 825b16687e0de3ef4ec3b7dd60fc1dfb237947c9 (patch) | |
tree | 8831f3f038a28b69c8dd976a7381aa66c1406ff4 /content/browser/browser_url_handler_impl_unittest.cc | |
parent | a60de956ec71ec185684f6d6167d5c8547f3639f (diff) | |
download | chromium_src-825b16687e0de3ef4ec3b7dd60fc1dfb237947c9.zip chromium_src-825b16687e0de3ef4ec3b7dd60fc1dfb237947c9.tar.gz chromium_src-825b16687e0de3ef4ec3b7dd60fc1dfb237947c9.tar.bz2 |
Add a Content API around BrowserURLHandler.
BUG=98716
Review URL: https://chromiumcodereview.appspot.com/9688019
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@126180 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/browser/browser_url_handler_impl_unittest.cc')
-rw-r--r-- | content/browser/browser_url_handler_impl_unittest.cc | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/content/browser/browser_url_handler_impl_unittest.cc b/content/browser/browser_url_handler_impl_unittest.cc new file mode 100644 index 0000000..7109d5d --- /dev/null +++ b/content/browser/browser_url_handler_impl_unittest.cc @@ -0,0 +1,78 @@ +// Copyright (c) 2011 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 "content/browser/browser_url_handler_impl.h" +#include "content/test/test_browser_context.h" +#include "googleurl/src/gurl.h" +#include "testing/gtest/include/gtest/gtest.h" + +class BrowserURLHandlerImplTest : public testing::Test { +}; + +// Test URL rewriter that rewrites all "foo://" URLs to "bar://bar". +static bool FooRewriter(GURL* url, content::BrowserContext* browser_context) { + if (url->scheme() == "foo") { + *url = GURL("bar://bar"); + return true; + } + return false; +} + +// Test URL rewriter that rewrites all "bar://" URLs to "foo://foo". +static bool BarRewriter(GURL* url, content::BrowserContext* browser_context) { + if (url->scheme() == "bar") { + *url = GURL("foo://foo"); + return true; + } + return false; +} + +TEST_F(BrowserURLHandlerImplTest, BasicRewriteAndReverse) { + TestBrowserContext browser_context; + BrowserURLHandlerImpl handler; + + handler.AddHandlerPair(FooRewriter, BarRewriter); + + GURL url("foo://bar"); + GURL original_url(url); + bool reverse_on_redirect = false; + handler.RewriteURLIfNecessary(&url, &browser_context, &reverse_on_redirect); + ASSERT_TRUE(reverse_on_redirect); + ASSERT_EQ("bar://bar", url.spec()); + + // Check that reversing the URL works. + GURL saved_url(url); + bool reversed = handler.ReverseURLRewrite(&url, + original_url, + &browser_context); + ASSERT_TRUE(reversed); + ASSERT_EQ("foo://foo", url.spec()); + + // Check that reversing the URL only works with a matching |original_url|. + url = saved_url; + original_url = GURL("bam://bam"); // Won't be matched by FooRewriter. + reversed = handler.ReverseURLRewrite(&url, original_url, &browser_context); + ASSERT_FALSE(reversed); + ASSERT_EQ(saved_url, url); +} + +TEST_F(BrowserURLHandlerImplTest, NullHandlerReverse) { + TestBrowserContext browser_context; + BrowserURLHandlerImpl handler; + + GURL url("bar://foo"); + GURL original_url(url); + + handler.AddHandlerPair(BrowserURLHandlerImpl::null_handler(), FooRewriter); + bool reversed = handler.ReverseURLRewrite(&url, + original_url, + &browser_context); + ASSERT_FALSE(reversed); + ASSERT_EQ(original_url, url); + + handler.AddHandlerPair(BrowserURLHandlerImpl::null_handler(), BarRewriter); + reversed = handler.ReverseURLRewrite(&url, original_url, &browser_context); + ASSERT_TRUE(reversed); + ASSERT_EQ("foo://foo", url.spec()); +} |