mirror of
https://github.com/pyscript/pyscript.git
synced 2025-12-20 10:47:35 -05:00
* add test and example files * update config to include python plugins in build * add markdown plugin * remove full pyscript execution from pyodide * move loading of pyscript.py from pyodide loagInterpreter to main setupVirtualEnv and add function to create python CE plugins * add plugin class to pyscript.py * add missing import * fix plugin path * add fetchPythonPlugins to PyScriptApp * remove old comments * fix test * add support for python plugins beyond custom elements and add app to python namespace in main * inject reference to PyScript app onto python plugins * add example hook onto markdown plugin * change plugin events logs * remove unused PyPlugin * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * fix type import * add docstring to fetchPythonPlugins * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * rename addPythonPlugin method * address PR comment * call python plugins on hooks after the interpreted is ready * add test for event hooks and split the test in 2 separate plugins to isolte type of plugins tests * change python plugins initialization and registration, to inject the app from app itself instead of on the plugins themselves * handle case when plugin cannot load due to missing plugin attribute * add test for fail scenario when a plugin module does not have a plugin attribute * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * add deprecation warning for pyscript objects loaded in global namespace * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * remove all from global scope * remove create_custom_element from global scope * rename create_custom_element to define_custom_element * rename attributes in define_custom_element and add docstrings * better handle connect event output * add warning to py_markdown plugin * remove debugging logs * improve tests * remove debugging log * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * remove unused import * add executable shebang * add pyodide mock module * fmt and lint * Update to pyodide.ffi.create_proxy per pyodide v21 api change * Mock pyodide as package instead of mdoule * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * add __init__ to pyodide package * Update pyscriptjs/src/plugin.ts fix logger name Co-authored-by: Antonio Cuni <anto.cuni@gmail.com> * fix pyodide import but handling the diff in their API change * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * oops, conflict resolution blooper * Fix failing integration tests Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: Jeff Glass <glass.jeffrey@gmail.com> Co-authored-by: Antonio Cuni <anto.cuni@gmail.com> Co-authored-by: FabioRosado <fabiorosado@outlook.com>
134 lines
4.0 KiB
Python
134 lines
4.0 KiB
Python
from playwright.sync_api import expect
|
|
|
|
from .support import PyScriptTest
|
|
|
|
|
|
class TestPyTerminal(PyScriptTest):
|
|
def test_py_terminal(self):
|
|
"""
|
|
1. <py-terminal> should redirect stdout and stderr to the DOM
|
|
|
|
2. they also go to the console as usual
|
|
|
|
3. note that the console also contains PY_COMPLETE, which is a pyodide
|
|
initialization message, but py-terminal doesn't. This is by design
|
|
"""
|
|
self.pyscript_run(
|
|
"""
|
|
<py-terminal></py-terminal>
|
|
|
|
<py-script>
|
|
import sys
|
|
print('hello world')
|
|
print('this goes to stderr', file=sys.stderr)
|
|
print('this goes to stdout')
|
|
</py-script>
|
|
"""
|
|
)
|
|
term = self.page.locator("py-terminal")
|
|
term_lines = term.inner_text().splitlines()
|
|
assert term_lines == [
|
|
"hello world",
|
|
"this goes to stderr",
|
|
"this goes to stdout",
|
|
]
|
|
assert self.console.log.lines[-3:] == [
|
|
"hello world",
|
|
"this goes to stderr",
|
|
"this goes to stdout",
|
|
]
|
|
|
|
def test_two_terminals(self):
|
|
"""
|
|
Multiple <py-terminal>s can cohexist.
|
|
A <py-terminal> receives only output from the moment it is added to
|
|
the DOM.
|
|
"""
|
|
self.pyscript_run(
|
|
"""
|
|
<py-terminal id="term1"></py-terminal>
|
|
|
|
<py-script>
|
|
import js
|
|
print('one')
|
|
term2 = js.document.createElement('py-terminal')
|
|
term2.id = 'term2'
|
|
js.document.body.append(term2)
|
|
|
|
print('two')
|
|
print('three')
|
|
</py-script>
|
|
"""
|
|
)
|
|
term1 = self.page.locator("#term1")
|
|
term2 = self.page.locator("#term2")
|
|
term1_lines = term1.inner_text().splitlines()
|
|
term2_lines = term2.inner_text().splitlines()
|
|
assert term1_lines == ["one", "two", "three"]
|
|
assert term2_lines == ["two", "three"]
|
|
|
|
def test_auto_attribute(self):
|
|
self.pyscript_run(
|
|
"""
|
|
<py-terminal auto></py-terminal>
|
|
|
|
<button id="my-button" py-onClick="print('hello world')">Click me</button>
|
|
"""
|
|
)
|
|
term = self.page.locator("py-terminal")
|
|
expect(term).to_be_hidden()
|
|
self.page.locator("button").click()
|
|
expect(term).to_be_visible()
|
|
assert term.inner_text() == "hello world\n"
|
|
|
|
def test_config_auto(self):
|
|
"""
|
|
config.terminal == "auto" is the default: a <py-terminal auto> is
|
|
automatically added to the page
|
|
"""
|
|
self.pyscript_run(
|
|
"""
|
|
<button id="my-button" py-onClick="print('hello world')">Click me</button>
|
|
"""
|
|
)
|
|
term = self.page.locator("py-terminal")
|
|
expect(term).to_be_hidden()
|
|
assert "No <py-terminal> found, adding one" in self.console.info.text
|
|
#
|
|
self.page.locator("button").click()
|
|
expect(term).to_be_visible()
|
|
assert term.inner_text() == "hello world\n"
|
|
|
|
def test_config_true(self):
|
|
"""
|
|
If we set config.terminal == true, a <py-terminal> is automatically added
|
|
"""
|
|
self.pyscript_run(
|
|
"""
|
|
<py-config>
|
|
terminal = true
|
|
</py-config>
|
|
|
|
<py-script>
|
|
print('hello world')
|
|
</py-script>
|
|
"""
|
|
)
|
|
term = self.page.locator("py-terminal")
|
|
expect(term).to_be_visible()
|
|
assert term.inner_text() == "hello world\n"
|
|
|
|
def test_config_false(self):
|
|
"""
|
|
If we set config.terminal == false, no <py-terminal> is added
|
|
"""
|
|
self.pyscript_run(
|
|
"""
|
|
<py-config>
|
|
terminal = false
|
|
</py-config>
|
|
"""
|
|
)
|
|
term = self.page.locator("py-terminal")
|
|
assert term.count() == 0
|