Skip to content

Commit

Permalink
chore(roll): roll Playwright to 1.34.3 (#1930)
Browse files Browse the repository at this point in the history
  • Loading branch information
mxschmitt authored May 26, 2023
1 parent 7a91855 commit e6a7a37
Show file tree
Hide file tree
Showing 11 changed files with 360 additions and 6 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ Playwright is a Python library to automate [Chromium](https://www.chromium.org/H

| | Linux | macOS | Windows |
| :--- | :---: | :---: | :---: |
| Chromium <!-- GEN:chromium-version -->113.0.5672.53<!-- GEN:stop --> ||||
| Chromium <!-- GEN:chromium-version -->114.0.5735.35<!-- GEN:stop --> ||||
| WebKit <!-- GEN:webkit-version -->16.4<!-- GEN:stop --> ||||
| Firefox <!-- GEN:firefox-version -->113.0<!-- GEN:stop --> ||||

Expand Down
7 changes: 7 additions & 0 deletions playwright/_impl/_browser_context.py
Original file line number Diff line number Diff line change
Expand Up @@ -478,6 +478,13 @@ async def wait_for_event(
pass
return await event_info

def expect_console_message(
self,
predicate: Callable[[ConsoleMessage], bool] = None,
timeout: float = None,
) -> EventContextManagerImpl[ConsoleMessage]:
return self.expect_event(Page.Events.Console, predicate, timeout)

def expect_page(
self,
predicate: Callable[[Page], bool] = None,
Expand Down
32 changes: 32 additions & 0 deletions playwright/async_api/_generated.py
Original file line number Diff line number Diff line change
Expand Up @@ -13733,6 +13733,38 @@ async def wait_for_event(
)
)

def expect_console_message(
self,
predicate: typing.Optional[typing.Callable[["ConsoleMessage"], bool]] = None,
*,
timeout: typing.Optional[float] = None
) -> AsyncEventContextManager["ConsoleMessage"]:
"""BrowserContext.expect_console_message

Performs action and waits for a `ConsoleMessage` to be logged by in the pages in the context. If predicate is
provided, it passes `ConsoleMessage` value into the `predicate` function and waits for `predicate(message)` to
return a truthy value. Will throw an error if the page is closed before the `browser_context.on('console')` event
is fired.

Parameters
----------
predicate : Union[Callable[[ConsoleMessage], bool], None]
Receives the `ConsoleMessage` object and resolves to truthy value when the waiting should resolve.
timeout : Union[float, None]
Maximum time to wait for in milliseconds. Defaults to `30000` (30 seconds). Pass `0` to disable timeout. The
default value can be changed by using the `browser_context.set_default_timeout()`.

Returns
-------
EventContextManager[ConsoleMessage]
"""

return AsyncEventContextManager(
self._impl_obj.expect_console_message(
predicate=self._wrap_handler(predicate), timeout=timeout
).future
)

def expect_page(
self,
predicate: typing.Optional[typing.Callable[["Page"], bool]] = None,
Expand Down
32 changes: 32 additions & 0 deletions playwright/sync_api/_generated.py
Original file line number Diff line number Diff line change
Expand Up @@ -13799,6 +13799,38 @@ def wait_for_event(
)
)

def expect_console_message(
self,
predicate: typing.Optional[typing.Callable[["ConsoleMessage"], bool]] = None,
*,
timeout: typing.Optional[float] = None
) -> EventContextManager["ConsoleMessage"]:
"""BrowserContext.expect_console_message

Performs action and waits for a `ConsoleMessage` to be logged by in the pages in the context. If predicate is
provided, it passes `ConsoleMessage` value into the `predicate` function and waits for `predicate(message)` to
return a truthy value. Will throw an error if the page is closed before the `browser_context.on('console')` event
is fired.

Parameters
----------
predicate : Union[Callable[[ConsoleMessage], bool], None]
Receives the `ConsoleMessage` object and resolves to truthy value when the waiting should resolve.
timeout : Union[float, None]
Maximum time to wait for in milliseconds. Defaults to `30000` (30 seconds). Pass `0` to disable timeout. The
default value can be changed by using the `browser_context.set_default_timeout()`.

Returns
-------
EventContextManager[ConsoleMessage]
"""
return EventContextManager(
self,
self._impl_obj.expect_console_message(
predicate=self._wrap_handler(predicate), timeout=timeout
).future,
)

def expect_page(
self,
predicate: typing.Optional[typing.Callable[["Page"], bool]] = None,
Expand Down
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@
InWheel = None
from wheel.bdist_wheel import bdist_wheel as BDistWheelCommand

driver_version = "1.34.0-alpha-may-17-2023"
driver_version = "1.34.3"


def extractall(zip: zipfile.ZipFile, path: str) -> None:
Expand Down
5 changes: 3 additions & 2 deletions tests/async/test_browsercontext.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
# limitations under the License.

import asyncio
import re
from urllib.parse import urlparse

import pytest
Expand Down Expand Up @@ -477,13 +478,13 @@ def handler(route, request, ordinal):
def handler4(route, request):
handler(route, request, 4)

await context.route("**/empty.html", handler4)
await context.route(re.compile("empty.html"), handler4)

await page.goto(server.EMPTY_PAGE)
assert intercepted == [4]

intercepted = []
await context.unroute("**/empty.html", handler4)
await context.unroute(re.compile("empty.html"), handler4)
await page.goto(server.EMPTY_PAGE)
assert intercepted == [3]

Expand Down
8 changes: 8 additions & 0 deletions tests/async/test_browsercontext_events.py
Original file line number Diff line number Diff line change
Expand Up @@ -180,3 +180,11 @@ def handle_route(request: HttpRequestWithPostBody) -> None:
await dialog.accept("hello")
await promise
await popup.evaluate("window.result") == "hello"


async def test_console_event_should_work_with_context_manager(page: Page) -> None:
async with page.context.expect_console_message() as cm_info:
await page.evaluate("() => console.log('hello')")
message = await cm_info.value
assert message.text == "hello"
assert message.page == page
5 changes: 3 additions & 2 deletions tests/async/test_interception.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@

import asyncio
import json
import re

import pytest

Expand Down Expand Up @@ -75,13 +76,13 @@ def handler4(route):
intercepted.append(4)
asyncio.create_task(route.continue_())

await page.route("**/empty.html", handler4)
await page.route(re.compile("empty.html"), handler4)

await page.goto(server.EMPTY_PAGE)
assert intercepted == [4]

intercepted = []
await page.unroute("**/empty.html", handler4)
await page.unroute(re.compile("empty.html"), handler4)
await page.goto(server.EMPTY_PAGE)
assert intercepted == [3]

Expand Down
200 changes: 200 additions & 0 deletions tests/sync/test_browsercontext_events.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,200 @@
# Copyright (c) Microsoft Corporation.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from typing import Optional

import pytest

from playwright.sync_api import Dialog, Page

from ..server import HttpRequestWithPostBody, Server


def test_console_event_should_work(page: Page) -> None:
with page.context.expect_console_message() as console_info:
page.evaluate("() => console.log('hello')")
message = console_info.value
assert message.text == "hello"
assert message.page == page


def test_console_event_should_work_in_popup(page: Page) -> None:
with page.context.expect_console_message() as console_info:
with page.expect_popup() as popup_info:
page.evaluate(
"""() => {
const win = window.open('');
win.console.log('hello');
}"""
)
message = console_info.value
popup = popup_info.value
assert message.text == "hello"
assert message.page == popup


# console message from javascript: url is not reported at all
@pytest.mark.skip_browser("firefox")
def test_console_event_should_work_in_popup_2(page: Page, browser_name: str) -> None:
with page.context.expect_console_message(
lambda msg: msg.type == "log"
) as console_info:
with page.context.expect_page() as page_info:
page.evaluate(
"""async () => {
const win = window.open('javascript:console.log("hello")');
await new Promise(f => setTimeout(f, 0));
win.close();
}"""
)
message = console_info.value
popup = page_info.value
assert message.text == "hello"
assert message.page == popup


# console message from javascript: url is not reported at all
@pytest.mark.skip_browser("firefox")
def test_console_event_should_work_in_immediately_closed_popup(
page: Page, browser_name: str
) -> None:
with page.context.expect_console_message(
lambda msg: msg.type == "log"
) as console_info:
with page.context.expect_page() as page_info:
page.evaluate(
"""() => {
const win = window.open('');
win.console.log('hello');
win.close();
}"""
)
message = console_info.value
popup = page_info.value
assert message.text == "hello"
assert message.page == popup


def test_dialog_event_should_work1(page: Page) -> None:
dialog1: Optional[Dialog] = None

def handle_page_dialog(dialog: Dialog) -> None:
nonlocal dialog1
dialog1 = dialog
dialog.accept("hello")

page.on("dialog", handle_page_dialog)

dialog2: Optional[Dialog] = None

def handle_context_dialog(dialog: Dialog) -> None:
nonlocal dialog2
dialog2 = dialog

page.context.on("dialog", handle_context_dialog)

assert page.evaluate("() => prompt('hey?')") == "hello"
assert dialog1
assert dialog1 == dialog2
assert dialog1.message == "hey?"
assert dialog1.page == page


def test_dialog_event_should_work_in_popup1(page: Page) -> None:
dialog: Optional[Dialog] = None

def handle_dialog(d: Dialog) -> None:
nonlocal dialog
dialog = d
dialog.accept("hello")

page.context.on("dialog", handle_dialog)

with page.expect_popup() as popup_info:
assert page.evaluate("() => window.open('').prompt('hey?')") == "hello"
popup = popup_info.value
assert dialog
assert dialog.message == "hey?"
assert dialog.page == popup


# console message from javascript: url is not reported at all
@pytest.mark.skip_browser("firefox")
def test_dialog_event_should_work_in_popup_2(page: Page, browser_name: str) -> None:
def handle_dialog(dialog: Dialog) -> None:
assert dialog.message == "hey?"
assert dialog.page is None
dialog.accept("hello")

page.context.on("dialog", handle_dialog)

assert page.evaluate("() => window.open('javascript:prompt(\"hey?\")')")


# console message from javascript: url is not reported at all
@pytest.mark.skip_browser("firefox")
def test_dialog_event_should_work_in_immdiately_closed_popup(page: Page) -> None:
popup = None

def handle_popup(p: Page) -> None:
nonlocal popup
popup = p

page.on("popup", handle_popup)

with page.context.expect_console_message() as console_info:
page.evaluate(
"""() => {
const win = window.open();
win.console.log('hello');
win.close();
}"""
)
message = console_info.value

assert message.text == "hello"
assert message.page == popup


def test_dialog_event_should_work_with_inline_script_tag(
page: Page, server: Server
) -> None:
def handle_route(request: HttpRequestWithPostBody) -> None:
request.setHeader("content-type", "text/html")
request.write(b"""<script>window.result = prompt('hey?')</script>""")
request.finish()

server.set_route("/popup.html", handle_route)
page.goto(server.EMPTY_PAGE)
page.set_content("<a href='popup.html' target=_blank>Click me</a>")

def handle_dialog(dialog: Dialog) -> None:
assert dialog.message == "hey?"
assert dialog.page == popup
dialog.accept("hello")

page.context.on("dialog", handle_dialog)

with page.expect_popup() as popup_info:
page.click("a")
popup = popup_info.value
assert popup.evaluate("window.result") == "hello"


def test_console_event_should_work_with_context_manager(page: Page) -> None:
with page.context.expect_console_message() as cm_info:
page.evaluate("() => console.log('hello')")
message = cm_info.value
assert message.text == "hello"
assert message.page == page
19 changes: 19 additions & 0 deletions tests/sync/test_locators.py
Original file line number Diff line number Diff line change
Expand Up @@ -863,6 +863,25 @@ def test_should_support_locator_filter(page: Page) -> None:
expect(page.locator("div").filter(has_not_text="foo")).to_have_count(2)


def test_locators_should_support_locator_and(page: Page) -> None:
page.set_content(
"""
<div data-testid=foo>hello</div><div data-testid=bar>world</div>
<span data-testid=foo>hello2</span><span data-testid=bar>world2</span>
"""
)
expect(page.locator("div").and_(page.locator("div"))).to_have_count(2)
expect(page.locator("div").and_(page.get_by_test_id("foo"))).to_have_text(["hello"])
expect(page.locator("div").and_(page.get_by_test_id("bar"))).to_have_text(["world"])
expect(page.get_by_test_id("foo").and_(page.locator("div"))).to_have_text(["hello"])
expect(page.get_by_test_id("bar").and_(page.locator("span"))).to_have_text(
["world2"]
)
expect(
page.locator("span").and_(page.get_by_test_id(re.compile("bar|foo")))
).to_have_count(2)


def test_locators_has_does_not_encode_unicode(page: Page, server: Server) -> None:
page.goto(server.EMPTY_PAGE)
locators = [
Expand Down
Loading

0 comments on commit e6a7a37

Please sign in to comment.