summaryrefslogtreecommitdiffstats
path: root/content/browser/session_history_browsertest.cc
diff options
context:
space:
mode:
authorphajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-05-28 17:00:37 +0000
committerphajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-05-28 17:00:37 +0000
commit0d31fbc5d7c041f9ddc0f46faf16b0123c5c2bb3 (patch)
treec3c60822caeabb8382fa5be457d81408775e21ff /content/browser/session_history_browsertest.cc
parent96da69d1ae43ad3feff0ac96a280d3212467f9b5 (diff)
downloadchromium_src-0d31fbc5d7c041f9ddc0f46faf16b0123c5c2bb3.zip
chromium_src-0d31fbc5d7c041f9ddc0f46faf16b0123c5c2bb3.tar.gz
chromium_src-0d31fbc5d7c041f9ddc0f46faf16b0123c5c2bb3.tar.bz2
Revert "Revert 202112 "GTTF: Convert most tests in content to use Embedd...""
This is a resubmit of https://codereview.chromium.org/15505003 TBR=avi BUG=96594 Review URL: https://codereview.chromium.org/15740023 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@202586 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/browser/session_history_browsertest.cc')
-rw-r--r--content/browser/session_history_browsertest.cc37
1 files changed, 34 insertions, 3 deletions
diff --git a/content/browser/session_history_browsertest.cc b/content/browser/session_history_browsertest.cc
index b2698b9d..d8a24ef 100644
--- a/content/browser/session_history_browsertest.cc
+++ b/content/browser/session_history_browsertest.cc
@@ -2,6 +2,7 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+#include "base/stringprintf.h"
#include "base/string_util.h"
#include "base/utf_string_conversions.h"
#include "content/public/browser/navigation_controller.h"
@@ -14,17 +15,43 @@
#include "content/shell/shell.h"
#include "content/test/content_browser_test.h"
#include "content/test/content_browser_test_utils.h"
-#include "net/test/spawned_test_server/spawned_test_server.h"
+#include "net/test/embedded_test_server/embedded_test_server.h"
+#include "net/test/embedded_test_server/http_response.h"
+#include "net/test/embedded_test_server/http_request.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace content {
+namespace {
+
+// Handles |request| by serving a response with title set to request contents.
+scoped_ptr<net::test_server::HttpResponse> HandleEchoTitleRequest(
+ const std::string& echotitle_path,
+ const net::test_server::HttpRequest& request) {
+ if (!StartsWithASCII(request.relative_url, echotitle_path, true))
+ return scoped_ptr<net::test_server::HttpResponse>(NULL);
+
+ scoped_ptr<net::test_server::BasicHttpResponse> http_response(
+ new net::test_server::BasicHttpResponse);
+ http_response->set_code(net::test_server::SUCCESS);
+ http_response->set_content(
+ base::StringPrintf(
+ "<html><head><title>%s</title></head></html>",
+ request.content.c_str()));
+ return http_response.PassAs<net::test_server::HttpResponse>();
+}
+
+} // namespace
+
class SessionHistoryTest : public ContentBrowserTest {
protected:
SessionHistoryTest() {}
virtual void SetUpOnMainThread() OVERRIDE {
- ASSERT_TRUE(test_server()->Start());
+ ASSERT_TRUE(embedded_test_server()->InitializeAndWaitUntilReady());
+ embedded_test_server()->RegisterRequestHandler(
+ base::Bind(&HandleEchoTitleRequest, "/echotitle"));
+
NavigateToURL(shell(), GURL(kAboutBlankURL));
}
@@ -66,7 +93,8 @@ class SessionHistoryTest : public ContentBrowserTest {
}
GURL GetURL(const std::string file) {
- return test_server()->GetURL(std::string("files/session_history/") + file);
+ return embedded_test_server()->GetURL(
+ std::string("/session_history/") + file);
}
void NavigateAndCheckTitle(const char* filename,
@@ -297,6 +325,9 @@ IN_PROC_BROWSER_TEST_F(SessionHistoryTest, CrossFrameFormBackForward) {
// navigations. Bug 730379.
// If this flakes use http://crbug.com/61619.
IN_PROC_BROWSER_TEST_F(SessionHistoryTest, FragmentBackForward) {
+ embedded_test_server()->RegisterRequestHandler(
+ base::Bind(&HandleEchoTitleRequest, "/echotitle"));
+
ASSERT_FALSE(CanGoBack());
GURL fragment(GetURL("fragment.html"));