mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 03:37:43 +00:00
Browser+WebContent+WebDriver: Move Take Screenshot to WebContent
This commit is contained in:
parent
40b9d248be
commit
de1e882601
9 changed files with 29 additions and 39 deletions
|
@ -146,18 +146,6 @@ void WebDriverConnection::scroll_element_into_view(i32 element_id)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Messages::WebDriverSessionClient::TakeScreenshotResponse WebDriverConnection::take_screenshot()
|
|
||||||
{
|
|
||||||
dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: take_screenshot");
|
|
||||||
if (auto browser_window = m_browser_window.strong_ref()) {
|
|
||||||
auto& tab = browser_window->active_tab();
|
|
||||||
if (tab.on_take_screenshot)
|
|
||||||
return { tab.on_take_screenshot() };
|
|
||||||
}
|
|
||||||
|
|
||||||
return { {} };
|
|
||||||
}
|
|
||||||
|
|
||||||
Messages::WebDriverSessionClient::TakeElementScreenshotResponse WebDriverConnection::take_element_screenshot(i32 element_id)
|
Messages::WebDriverSessionClient::TakeElementScreenshotResponse WebDriverConnection::take_element_screenshot(i32 element_id)
|
||||||
{
|
{
|
||||||
dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: take_element_screenshot {}", element_id);
|
dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: take_element_screenshot {}", element_id);
|
||||||
|
|
|
@ -49,7 +49,6 @@ public:
|
||||||
virtual void add_cookie(Web::Cookie::ParsedCookie const&) override;
|
virtual void add_cookie(Web::Cookie::ParsedCookie const&) override;
|
||||||
virtual void update_cookie(Web::Cookie::Cookie const&) override;
|
virtual void update_cookie(Web::Cookie::Cookie const&) override;
|
||||||
virtual void scroll_element_into_view(i32 element_id) override;
|
virtual void scroll_element_into_view(i32 element_id) override;
|
||||||
virtual Messages::WebDriverSessionClient::TakeScreenshotResponse take_screenshot() override;
|
|
||||||
virtual Messages::WebDriverSessionClient::TakeElementScreenshotResponse take_element_screenshot(i32 element_id) override;
|
virtual Messages::WebDriverSessionClient::TakeElementScreenshotResponse take_element_screenshot(i32 element_id) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -25,6 +25,5 @@ endpoint WebDriverSessionClient {
|
||||||
add_cookie(Web::Cookie::ParsedCookie cookie) =|
|
add_cookie(Web::Cookie::ParsedCookie cookie) =|
|
||||||
update_cookie(Web::Cookie::Cookie cookie) =|
|
update_cookie(Web::Cookie::Cookie cookie) =|
|
||||||
scroll_element_into_view(i32 element_id) => ()
|
scroll_element_into_view(i32 element_id) => ()
|
||||||
take_screenshot() => (Gfx::ShareableBitmap data)
|
|
||||||
take_element_screenshot(i32 element_id) => (Gfx::ShareableBitmap data)
|
take_element_screenshot(i32 element_id) => (Gfx::ShareableBitmap data)
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,4 +21,5 @@ endpoint WebDriverClient {
|
||||||
get_element_tag_name(String element_id) => (Web::WebDriver::Response response)
|
get_element_tag_name(String element_id) => (Web::WebDriver::Response response)
|
||||||
get_element_rect(String element_id) => (Web::WebDriver::Response response)
|
get_element_rect(String element_id) => (Web::WebDriver::Response response)
|
||||||
is_element_enabled(String element_id) => (Web::WebDriver::Response response)
|
is_element_enabled(String element_id) => (Web::WebDriver::Response response)
|
||||||
|
take_screenshot() => (Web::WebDriver::Response response)
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
#include <LibWeb/Page/Page.h>
|
#include <LibWeb/Page/Page.h>
|
||||||
#include <LibWeb/Platform/EventLoopPlugin.h>
|
#include <LibWeb/Platform/EventLoopPlugin.h>
|
||||||
#include <LibWeb/Platform/Timer.h>
|
#include <LibWeb/Platform/Timer.h>
|
||||||
|
#include <LibWeb/WebDriver/Screenshot.h>
|
||||||
#include <WebContent/ConnectionFromClient.h>
|
#include <WebContent/ConnectionFromClient.h>
|
||||||
#include <WebContent/PageHost.h>
|
#include <WebContent/PageHost.h>
|
||||||
#include <WebContent/WebDriverConnection.h>
|
#include <WebContent/WebDriverConnection.h>
|
||||||
|
@ -714,6 +715,31 @@ Messages::WebDriverClient::IsElementEnabledResponse WebDriverConnection::is_elem
|
||||||
return make_success_response(enabled);
|
return make_success_response(enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 17.1 Take Screenshot, https://w3c.github.io/webdriver/#take-screenshot
|
||||||
|
Messages::WebDriverClient::TakeScreenshotResponse WebDriverConnection::take_screenshot()
|
||||||
|
{
|
||||||
|
// 1. If the current top-level browsing context is no longer open, return error with error code no such window.
|
||||||
|
TRY(ensure_open_top_level_browsing_context());
|
||||||
|
|
||||||
|
// 2. When the user agent is next to run the animation frame callbacks:
|
||||||
|
// a. Let root rect be the current top-level browsing context’s document element’s rectangle.
|
||||||
|
// b. Let screenshot result be the result of trying to call draw a bounding box from the framebuffer, given root rect as an argument.
|
||||||
|
// c. Let canvas be a canvas element of screenshot result’s data.
|
||||||
|
// d. Let encoding result be the result of trying encoding a canvas as Base64 canvas.
|
||||||
|
// e. Let encoded string be encoding result’s data.
|
||||||
|
auto* document = m_page_host.page().top_level_browsing_context().active_document();
|
||||||
|
auto root_rect = calculate_absolute_rect_of_element(m_page_host.page(), *document->document_element());
|
||||||
|
|
||||||
|
auto encoded_string = TRY(Web::WebDriver::capture_element_screenshot(
|
||||||
|
[&](auto const& rect, auto& bitmap) { m_page_host.paint(rect, bitmap); },
|
||||||
|
m_page_host.page(),
|
||||||
|
*document->document_element(),
|
||||||
|
root_rect));
|
||||||
|
|
||||||
|
// 3. Return success with data encoded string.
|
||||||
|
return make_success_response(move(encoded_string));
|
||||||
|
}
|
||||||
|
|
||||||
// https://w3c.github.io/webdriver/#dfn-no-longer-open
|
// https://w3c.github.io/webdriver/#dfn-no-longer-open
|
||||||
ErrorOr<void, Web::WebDriver::Error> WebDriverConnection::ensure_open_top_level_browsing_context()
|
ErrorOr<void, Web::WebDriver::Error> WebDriverConnection::ensure_open_top_level_browsing_context()
|
||||||
{
|
{
|
||||||
|
|
|
@ -51,6 +51,7 @@ private:
|
||||||
virtual Messages::WebDriverClient::GetElementTagNameResponse get_element_tag_name(String const& element_id) override;
|
virtual Messages::WebDriverClient::GetElementTagNameResponse get_element_tag_name(String const& element_id) override;
|
||||||
virtual Messages::WebDriverClient::GetElementRectResponse get_element_rect(String const& element_id) override;
|
virtual Messages::WebDriverClient::GetElementRectResponse get_element_rect(String const& element_id) override;
|
||||||
virtual Messages::WebDriverClient::IsElementEnabledResponse is_element_enabled(String const& element_id) override;
|
virtual Messages::WebDriverClient::IsElementEnabledResponse is_element_enabled(String const& element_id) override;
|
||||||
|
virtual Messages::WebDriverClient::TakeScreenshotResponse take_screenshot() override;
|
||||||
|
|
||||||
ErrorOr<void, Web::WebDriver::Error> ensure_open_top_level_browsing_context();
|
ErrorOr<void, Web::WebDriver::Error> ensure_open_top_level_browsing_context();
|
||||||
void restore_the_window();
|
void restore_the_window();
|
||||||
|
|
|
@ -806,8 +806,7 @@ Web::WebDriver::Response Client::handle_take_screenshot(Vector<StringView> const
|
||||||
{
|
{
|
||||||
dbgln_if(WEBDRIVER_DEBUG, "Handling GET /session/<session_id>/screenshot");
|
dbgln_if(WEBDRIVER_DEBUG, "Handling GET /session/<session_id>/screenshot");
|
||||||
auto* session = TRY(find_session_with_id(parameters[0]));
|
auto* session = TRY(find_session_with_id(parameters[0]));
|
||||||
auto result = TRY(session->take_screenshot());
|
return session->web_content_connection().take_screenshot();
|
||||||
return make_json_value(result);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 17.2 Take Element Screenshot, https://w3c.github.io/webdriver/#dfn-take-element-screenshot
|
// 17.2 Take Element Screenshot, https://w3c.github.io/webdriver/#dfn-take-element-screenshot
|
||||||
|
|
|
@ -695,28 +695,6 @@ static ErrorOr<String, Web::WebDriver::Error> encode_bitmap_as_canvas_element(Gf
|
||||||
return encoded_string;
|
return encoded_string;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 17.1 Take Screenshot, https://w3c.github.io/webdriver/#take-screenshot
|
|
||||||
Web::WebDriver::Response Session::take_screenshot()
|
|
||||||
{
|
|
||||||
// 1. If the current top-level browsing context is no longer open, return error with error code no such window.
|
|
||||||
TRY(check_for_open_top_level_browsing_context_or_return_error());
|
|
||||||
|
|
||||||
// 2. When the user agent is next to run the animation frame callbacks:
|
|
||||||
// a. Let root rect be the current top-level browsing context’s document element’s rectangle.
|
|
||||||
// b. Let screenshot result be the result of trying to call draw a bounding box from the framebuffer, given root rect as an argument.
|
|
||||||
auto screenshot = m_browser_connection->take_screenshot();
|
|
||||||
if (!screenshot.is_valid())
|
|
||||||
return Web::WebDriver::Error::from_code(Web::WebDriver::ErrorCode::UnableToCaptureScreen, "Unable to capture screenshot"sv);
|
|
||||||
|
|
||||||
// c. Let canvas be a canvas element of screenshot result’s data.
|
|
||||||
// d. Let encoding result be the result of trying encoding a canvas as Base64 canvas.
|
|
||||||
// e. Let encoded string be encoding result’s data.
|
|
||||||
auto encoded_string = TRY(encode_bitmap_as_canvas_element(*screenshot.bitmap()));
|
|
||||||
|
|
||||||
// 3. Return success with data encoded string.
|
|
||||||
return JsonValue { encoded_string };
|
|
||||||
}
|
|
||||||
|
|
||||||
// 17.2 Take Element Screenshot, https://w3c.github.io/webdriver/#dfn-take-element-screenshot
|
// 17.2 Take Element Screenshot, https://w3c.github.io/webdriver/#dfn-take-element-screenshot
|
||||||
Web::WebDriver::Response Session::take_element_screenshot(StringView parameter_element_id)
|
Web::WebDriver::Response Session::take_element_screenshot(StringView parameter_element_id)
|
||||||
{
|
{
|
||||||
|
|
|
@ -66,7 +66,6 @@ public:
|
||||||
Web::WebDriver::Response add_cookie(JsonValue const& payload);
|
Web::WebDriver::Response add_cookie(JsonValue const& payload);
|
||||||
Web::WebDriver::Response delete_cookie(StringView name);
|
Web::WebDriver::Response delete_cookie(StringView name);
|
||||||
Web::WebDriver::Response delete_all_cookies();
|
Web::WebDriver::Response delete_all_cookies();
|
||||||
Web::WebDriver::Response take_screenshot();
|
|
||||||
Web::WebDriver::Response take_element_screenshot(StringView element_id);
|
Web::WebDriver::Response take_element_screenshot(StringView element_id);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue