mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 02:17:34 +00:00
Browser+WebContent+WebDriver: Move Get Title to WebContent
This commit is contained in:
parent
7f142745e2
commit
2c9549cb76
9 changed files with 18 additions and 27 deletions
|
@ -27,12 +27,4 @@ void WebDriverConnection::quit()
|
||||||
browser_window->close();
|
browser_window->close();
|
||||||
}
|
}
|
||||||
|
|
||||||
Messages::WebDriverSessionClient::GetTitleResponse WebDriverConnection::get_title()
|
|
||||||
{
|
|
||||||
dbgln_if(WEBDRIVER_DEBUG, "WebDriverConnection: get_title");
|
|
||||||
if (auto browser_window = m_browser_window.strong_ref())
|
|
||||||
return { browser_window->active_tab().title() };
|
|
||||||
return { "" };
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,7 +38,6 @@ public:
|
||||||
virtual void die() override { }
|
virtual void die() override { }
|
||||||
|
|
||||||
virtual void quit() override;
|
virtual void quit() override;
|
||||||
virtual Messages::WebDriverSessionClient::GetTitleResponse get_title() override;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
WebDriverConnection(NonnullOwnPtr<Core::Stream::LocalSocket> socket, NonnullRefPtr<BrowserWindow> browser_window);
|
WebDriverConnection(NonnullOwnPtr<Core::Stream::LocalSocket> socket, NonnullRefPtr<BrowserWindow> browser_window);
|
||||||
|
|
|
@ -13,6 +13,4 @@
|
||||||
|
|
||||||
endpoint WebDriverSessionClient {
|
endpoint WebDriverSessionClient {
|
||||||
quit() =|
|
quit() =|
|
||||||
|
|
||||||
get_title() => (String title)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,7 @@ endpoint WebDriverClient {
|
||||||
back() => (Web::WebDriver::Response response)
|
back() => (Web::WebDriver::Response response)
|
||||||
forward() => (Web::WebDriver::Response response)
|
forward() => (Web::WebDriver::Response response)
|
||||||
refresh() => (Web::WebDriver::Response response)
|
refresh() => (Web::WebDriver::Response response)
|
||||||
|
get_title() => (Web::WebDriver::Response response)
|
||||||
get_window_rect() => (Web::WebDriver::Response response)
|
get_window_rect() => (Web::WebDriver::Response response)
|
||||||
set_window_rect(JsonValue payload) => (Web::WebDriver::Response response)
|
set_window_rect(JsonValue payload) => (Web::WebDriver::Response response)
|
||||||
maximize_window() => (Web::WebDriver::Response response)
|
maximize_window() => (Web::WebDriver::Response response)
|
||||||
|
|
|
@ -346,6 +346,21 @@ Messages::WebDriverClient::RefreshResponse WebDriverConnection::refresh()
|
||||||
return make_success_response({});
|
return make_success_response({});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 10.6 Get Title, https://w3c.github.io/webdriver/#dfn-get-title
|
||||||
|
Messages::WebDriverClient::GetTitleResponse WebDriverConnection::get_title()
|
||||||
|
{
|
||||||
|
// 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());
|
||||||
|
|
||||||
|
// FIXME: 2. Handle any user prompts and return its value if it is an error.
|
||||||
|
|
||||||
|
// 3. Let title be the initial value of the title IDL attribute of the current top-level browsing context's active document.
|
||||||
|
auto title = m_page_host.page().top_level_browsing_context().active_document()->title();
|
||||||
|
|
||||||
|
// 4. Return success with data title.
|
||||||
|
return make_success_response(move(title));
|
||||||
|
}
|
||||||
|
|
||||||
// 11.8.1 Get Window Rect, https://w3c.github.io/webdriver/#dfn-get-window-rect
|
// 11.8.1 Get Window Rect, https://w3c.github.io/webdriver/#dfn-get-window-rect
|
||||||
Messages::WebDriverClient::GetWindowRectResponse WebDriverConnection::get_window_rect()
|
Messages::WebDriverClient::GetWindowRectResponse WebDriverConnection::get_window_rect()
|
||||||
{
|
{
|
||||||
|
|
|
@ -40,6 +40,7 @@ private:
|
||||||
virtual Messages::WebDriverClient::BackResponse back() override;
|
virtual Messages::WebDriverClient::BackResponse back() override;
|
||||||
virtual Messages::WebDriverClient::ForwardResponse forward() override;
|
virtual Messages::WebDriverClient::ForwardResponse forward() override;
|
||||||
virtual Messages::WebDriverClient::RefreshResponse refresh() override;
|
virtual Messages::WebDriverClient::RefreshResponse refresh() override;
|
||||||
|
virtual Messages::WebDriverClient::GetTitleResponse get_title() override;
|
||||||
virtual Messages::WebDriverClient::GetWindowRectResponse get_window_rect() override;
|
virtual Messages::WebDriverClient::GetWindowRectResponse get_window_rect() override;
|
||||||
virtual Messages::WebDriverClient::SetWindowRectResponse set_window_rect(JsonValue const& payload) override;
|
virtual Messages::WebDriverClient::SetWindowRectResponse set_window_rect(JsonValue const& payload) override;
|
||||||
virtual Messages::WebDriverClient::MaximizeWindowResponse maximize_window() override;
|
virtual Messages::WebDriverClient::MaximizeWindowResponse maximize_window() override;
|
||||||
|
|
|
@ -539,8 +539,7 @@ Web::WebDriver::Response Client::handle_get_title(Vector<StringView> const& para
|
||||||
{
|
{
|
||||||
dbgln_if(WEBDRIVER_DEBUG, "Handling GET /session/<session_id>/title");
|
dbgln_if(WEBDRIVER_DEBUG, "Handling GET /session/<session_id>/title");
|
||||||
auto* session = TRY(find_session_with_id(parameters[0]));
|
auto* session = TRY(find_session_with_id(parameters[0]));
|
||||||
auto result = TRY(session->get_title());
|
return session->web_content_connection().get_title();
|
||||||
return make_json_value(result);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 11.1 Get Window Handle, https://w3c.github.io/webdriver/#get-window-handle
|
// 11.1 Get Window Handle, https://w3c.github.io/webdriver/#get-window-handle
|
||||||
|
|
|
@ -172,19 +172,6 @@ Web::WebDriver::Response Session::set_timeouts(JsonValue const& payload)
|
||||||
return JsonValue {};
|
return JsonValue {};
|
||||||
}
|
}
|
||||||
|
|
||||||
// 10.6 Get Title, https://w3c.github.io/webdriver/#dfn-get-title
|
|
||||||
Web::WebDriver::Response Session::get_title()
|
|
||||||
{
|
|
||||||
// 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());
|
|
||||||
|
|
||||||
// FIXME: 2. Handle any user prompts and return its value if it is an error.
|
|
||||||
|
|
||||||
// 3. Let title be the initial value of the title IDL attribute of the current top-level browsing context's active document.
|
|
||||||
// 4. Return success with data title.
|
|
||||||
return JsonValue(m_browser_connection->get_title());
|
|
||||||
}
|
|
||||||
|
|
||||||
// 11.1 Get Window Handle, https://w3c.github.io/webdriver/#get-window-handle
|
// 11.1 Get Window Handle, https://w3c.github.io/webdriver/#get-window-handle
|
||||||
Web::WebDriver::Response Session::get_window_handle()
|
Web::WebDriver::Response Session::get_window_handle()
|
||||||
{
|
{
|
||||||
|
|
|
@ -51,7 +51,6 @@ public:
|
||||||
Web::WebDriver::Response stop();
|
Web::WebDriver::Response stop();
|
||||||
JsonObject get_timeouts();
|
JsonObject get_timeouts();
|
||||||
Web::WebDriver::Response set_timeouts(JsonValue const& payload);
|
Web::WebDriver::Response set_timeouts(JsonValue const& payload);
|
||||||
Web::WebDriver::Response get_title();
|
|
||||||
Web::WebDriver::Response get_window_handle();
|
Web::WebDriver::Response get_window_handle();
|
||||||
ErrorOr<void, Variant<Web::WebDriver::Error, Error>> close_window();
|
ErrorOr<void, Variant<Web::WebDriver::Error, Error>> close_window();
|
||||||
Web::WebDriver::Response get_window_handles() const;
|
Web::WebDriver::Response get_window_handles() const;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue