mirror of
https://github.com/pyscript/pyscript.git
synced 2025-12-20 02:37:41 -05:00
This PR adds support for optionally running pyodide in a web worker: - add a new option config.execution_thread, which can be `main` or `worker`. The default is `main` - improve the test machinery so that we run all tests twice, once for `main` and once for `worker` - add a new esbuild target which builds the code for the worker The support for workers is not complete and many features are still missing: there are 71 tests which are marked as `@skip_worker`, but we can fix them in subsequent PRs. The vast majority of tests fail because js.document is unavailable: for it to run transparently, we need the "auto-syncify" feature of synclink. Co-authored-by: Hood Chatham <roberthoodchatham@gmail.com> Co-authored-by: Madhur Tandon <20173739+madhur-tandon@users.noreply.github.com>
285 lines
8.5 KiB
Python
285 lines
8.5 KiB
Python
from .support import PyScriptTest, skip_worker
|
|
|
|
|
|
class TestElement(PyScriptTest):
|
|
"""Test the Element api"""
|
|
|
|
def test_element_id(self):
|
|
"""Test the element id"""
|
|
self.pyscript_run(
|
|
"""
|
|
<div id="foo"></div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
print(el.id)
|
|
</py-script>
|
|
"""
|
|
)
|
|
assert self.console.log.lines[-1] == "foo"
|
|
|
|
py_terminal = self.page.wait_for_selector("py-terminal")
|
|
assert "foo" in py_terminal.inner_text()
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_value(self):
|
|
"""Test the element value"""
|
|
self.pyscript_run(
|
|
"""
|
|
<input id="foo" value="bar">
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
print(el.value)
|
|
</py-script>
|
|
"""
|
|
)
|
|
assert self.console.log.lines[-1] == "bar"
|
|
|
|
py_terminal = self.page.wait_for_selector("py-terminal")
|
|
assert "bar" in py_terminal.inner_text()
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_innerHtml(self):
|
|
"""Test the element innerHtml"""
|
|
self.pyscript_run(
|
|
"""
|
|
<div id="foo"><b>bar</b></div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
print(el.innerHtml)
|
|
</py-script>
|
|
"""
|
|
)
|
|
assert self.console.log.lines[-1] == "<b>bar</b>"
|
|
|
|
py_terminal = self.page.wait_for_selector("py-terminal")
|
|
assert "bar" in py_terminal.inner_text()
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_write_no_append(self):
|
|
"""Test the element write"""
|
|
self.pyscript_run(
|
|
"""
|
|
<div id="foo"></div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.write("Hello!")
|
|
el.write("World!")
|
|
</py-script>
|
|
"""
|
|
)
|
|
div = self.page.wait_for_selector("#foo")
|
|
assert "World!" in div.inner_text()
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_write_append(self):
|
|
"""Test the element write"""
|
|
self.pyscript_run(
|
|
"""
|
|
<div id="foo"></div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.write("Hello!")
|
|
el.write("World!", append=True)
|
|
</py-script>
|
|
"""
|
|
)
|
|
parent_div = self.page.wait_for_selector("#foo")
|
|
|
|
assert "Hello!" in parent_div.inner_text()
|
|
# confirm that the second write was appended
|
|
assert "Hello!<div>World!</div>" in parent_div.inner_html()
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_clear_div(self):
|
|
"""Test the element clear"""
|
|
self.pyscript_run(
|
|
"""
|
|
<div id="foo">Hello!</div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.clear()
|
|
</py-script>
|
|
"""
|
|
)
|
|
div = self.page.locator("#foo")
|
|
assert div.inner_text() == ""
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_clear_input(self):
|
|
"""Test the element clear"""
|
|
self.pyscript_run(
|
|
"""
|
|
<input id="foo" value="bar">
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.clear()
|
|
</py-script>
|
|
"""
|
|
)
|
|
input = self.page.wait_for_selector("#foo")
|
|
assert input.input_value() == ""
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_select(self):
|
|
"""Test the element select"""
|
|
self.pyscript_run(
|
|
"""
|
|
<select id="foo">
|
|
<option value="bar">Bar</option>
|
|
</select>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.select("bar", from_content=True)
|
|
</py-script>
|
|
"""
|
|
)
|
|
select = self.page.wait_for_selector("#foo")
|
|
assert select.inner_text() == "Bar"
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_clone_no_id(self):
|
|
"""Test the element clone"""
|
|
self.pyscript_run(
|
|
"""
|
|
<div id="foo">Hello!</div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.clone()
|
|
</py-script>
|
|
"""
|
|
)
|
|
divs = self.page.locator("#foo")
|
|
assert divs.count() == 2
|
|
assert divs.first.inner_text() == "Hello!"
|
|
assert divs.last.inner_text() == "Hello!"
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_clone_with_id(self):
|
|
"""Test the element clone"""
|
|
self.pyscript_run(
|
|
"""
|
|
<div id="foo">Hello!</div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.clone(new_id="bar")
|
|
</py-script>
|
|
"""
|
|
)
|
|
divs = self.page.locator("#foo")
|
|
assert divs.count() == 1
|
|
assert divs.inner_text() == "Hello!"
|
|
|
|
clone = self.page.locator("#bar")
|
|
assert clone.inner_text() == "Hello!"
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_clone_to_other_element(self):
|
|
"""Test the element clone"""
|
|
self.pyscript_run(
|
|
"""
|
|
<div id="container">
|
|
<div id="bond">
|
|
Bond
|
|
</div>
|
|
<div id="james">
|
|
James
|
|
</div>
|
|
</div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
|
|
bond_div = Element("bond")
|
|
james_div = Element("james")
|
|
|
|
bond_div.clone(new_id="bond-2", to=james_div)
|
|
</py-script>
|
|
"""
|
|
)
|
|
bond_divs = self.page.locator("#bond")
|
|
james_divs = self.page.locator("#james")
|
|
bond_2_divs = self.page.locator("#bond-2")
|
|
|
|
assert bond_divs.count() == 1
|
|
assert james_divs.count() == 1
|
|
assert bond_2_divs.count() == 1
|
|
|
|
container_div = self.page.locator("#container")
|
|
# Make sure that the clones are rendered in the right order
|
|
assert container_div.inner_text() == "Bond\nJames\nBond"
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_remove_single_class(self):
|
|
"""Test the element remove_class"""
|
|
self.pyscript_run(
|
|
"""
|
|
<div id="foo" class="bar baz"></div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.remove_class("bar")
|
|
</py-script>
|
|
"""
|
|
)
|
|
div = self.page.locator("#foo")
|
|
assert div.get_attribute("class") == "baz"
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_remove_multiple_classes(self):
|
|
"""Test the element remove_class"""
|
|
self.pyscript_run(
|
|
"""
|
|
<div id="foo" class="foo bar baz"></div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.remove_class(["foo", "baz", "bar"])
|
|
</py-script>
|
|
"""
|
|
)
|
|
div = self.page.locator("#foo")
|
|
assert div.get_attribute("class") == ""
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_add_single_class(self):
|
|
"""Test the element add_class"""
|
|
self.pyscript_run(
|
|
"""
|
|
<style> .red { color: red; } </style>
|
|
<div id="foo">Hi!</div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.add_class("red")
|
|
</py-script>
|
|
"""
|
|
)
|
|
div = self.page.locator("#foo")
|
|
assert div.get_attribute("class") == "red"
|
|
|
|
@skip_worker("FIXME: js.document")
|
|
def test_element_add_multiple_class(self):
|
|
"""Test the element add_class"""
|
|
self.pyscript_run(
|
|
"""
|
|
<style> .red { color: red; } .bold { font-weight: bold; } </style>
|
|
<div id="foo">Hi!</div>
|
|
<py-script>
|
|
from pyscript import Element
|
|
el = Element("foo")
|
|
el.add_class(["red", "bold"])
|
|
</py-script>
|
|
"""
|
|
)
|
|
div = self.page.locator("#foo")
|
|
assert div.get_attribute("class") == "red bold"
|