blob: e37a64f0fe86d6ecc2be021005edfa2a93b3a622 [file] [log] [blame]
// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_PDF_PDF_EXTENSION_TEST_UTIL_H_
#define CHROME_BROWSER_PDF_PDF_EXTENSION_TEST_UTIL_H_
#include <stddef.h>
#include <vector>
#include "testing/gtest/include/gtest/gtest.h"
class Browser;
namespace content {
class RenderFrameHost;
class ToRenderFrameHost;
class WebContents;
} // namespace content
namespace extensions {
class MimeHandlerViewGuest;
} // namespace extensions
namespace gfx {
class Point;
} // namespace gfx
namespace pdf_extension_test_util {
// Options for customizing behavior in `EnsurePDFHasLoadedWithOptions()`.
struct EnsurePDFHasLoadedOptions {
// // Whether to wait for hit test data or not after the PDF successfully
// loads.
bool wait_for_hit_test_data = true;
// The tag name of the PDF embedder element.
std::string pdf_element = "embed";
// True if the PDF embedder frame should be allowed to have multiple
// subframes, false otherwise. This can occur if extensions append subframes
// to the PDF embedder.
bool allow_multiple_frames = false;
};
// Gets the PDF extension host that is the first child of `embedder_host`.
// If multiple frames aren't allowed and there is more than one child frame,
// returns nullptr.
content::RenderFrameHost* GetPdfExtensionHostFromEmbedder(
content::RenderFrameHost* embedder_host,
bool allow_multiple_frames);
// Gets the PDF extension host for a given `WebContents`. There should only be
// one extension host in `contents`, otherwise returns nullptr.
content::RenderFrameHost* GetOnlyPdfExtensionHost(
content::WebContents* contents);
// Gets all the PDF extension hosts for a given `WebContents`.
std::vector<content::RenderFrameHost*> GetPdfExtensionHosts(
content::WebContents* contents);
// Gets the PDF plugin frame for a given `WebContents`. There should only be
// one plugin frame in `contents`, otherwise returns nullptr.
content::RenderFrameHost* GetOnlyPdfPluginFrame(content::WebContents* contents);
// Gets all the PDF plugin frames for a given `WebContents`.
std::vector<content::RenderFrameHost*> GetPdfPluginFrames(
content::WebContents* contents);
// Counts the total number of unique PDF plugin processes.
size_t CountPdfPluginProcesses(const Browser* browser);
// Ensures, inside the given `frame`, that a PDF has either finished
// loading or prompted a password. The result indicates success if the PDF loads
// successfully, otherwise it indicates failure. If it doesn't finish loading,
// the test will hang. The test will fail if the PDF embedder host has multiple
// subframes.
//
// In order to ensure an OOPIF PDF has loaded, `frame` must be an embedder host,
// and the extension host must have already been created.
//
// Waits for hit test data if the PDF successfully loads so that tests that
// attempt to send mouse/pointer events have the necessary hit test data.
[[nodiscard]] testing::AssertionResult EnsurePDFHasLoaded(
const content::ToRenderFrameHost& frame);
// Same as `EnsurePDFHasLoaded()`, but uses `EnsurePDFHasLoadedOptions` to
// customize behavior.
[[nodiscard]] testing::AssertionResult EnsurePDFHasLoadedWithOptions(
const content::ToRenderFrameHost& frame,
const EnsurePDFHasLoadedOptions& options);
gfx::Point ConvertPageCoordToScreenCoord(
content::ToRenderFrameHost guest_main_frame,
const gfx::Point& point);
// Synchronously sets the input focus on the plugin frame by clicking on the
// top-left corner of a PDF document.
void SetInputFocusOnPlugin(content::RenderFrameHost* extension_host,
content::WebContents* embedder_web_contents);
// Returns the `MimeHandlerViewGuest` embedded in `embedder_contents`. If more
// than one `MimeHandlerViewGuest` is found, the test fails.
extensions::MimeHandlerViewGuest* GetOnlyMimeHandlerView(
content::WebContents* embedder_contents);
} // namespace pdf_extension_test_util
#endif // CHROME_BROWSER_PDF_PDF_EXTENSION_TEST_UTIL_H_