blob: bc9af5cb6907e214a0dcbe44858c8da1c5320ccd [file] [log] [blame]
// Copyright 2013 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.
#ifndef CONTENT_BROWSER_MEDIA_MEDIA_BROWSERTEST_H_
#define CONTENT_BROWSER_MEDIA_MEDIA_BROWSERTEST_H_
#include <string>
#include "base/strings/string_split.h"
#include "base/test/scoped_feature_list.h"
#include "content/public/test/content_browser_test.h"
namespace content {
class TitleWatcher;
// A base class for media related browser tests.
class MediaBrowserTest : public ContentBrowserTest {
public:
// ContentBrowserTest implementation.
void SetUpCommandLine(base::CommandLine* command_line) override;
// Runs a html page with a list of URL query parameters.
// If http is true, the test starts a local http test server to load the test
// page, otherwise a local file URL is loaded inside the content shell.
// It uses RunTest() to check for expected test output.
void RunMediaTestPage(const std::string& html_page,
const base::StringPairs& query_params,
const std::string& expected_title,
bool http);
// Opens a URL and waits for the document title to match any of the waited for
// titles. Returns the matching title.
std::string RunTest(const GURL& gurl, const std::string& expected_title);
// Encodes |original_message| to be used in a URI query parameter suitable for
// decoding and usage with DecodeURIComponent in test pages that verify error
// message contents.
std::string EncodeErrorMessage(const std::string& original_message);
// Tears down media playback. Called automatically as part of RunTest(), only
// needed for manually setup tests.
void CleanupTest();
// Adds titles that RunTest() should wait for.
virtual void AddTitlesToAwait(content::TitleWatcher* title_watcher);
private:
base::test::ScopedFeatureList scoped_feature_list_;
};
} // namespace content
#endif // CONTENT_BROWSER_MEDIA_MEDIA_BROWSERTEST_H_