mirror of
https://github.com/pyscript/pyscript.git
synced 2026-02-28 14:01:35 -05:00
Refactor pyexec (#1318)
This is some refactoring I did on the way towards resolving pyscript#1313. I added a new _run_pyscript Python function which executes the code inside a context manager that sets the display target. We can then return a JS object wrapper directly from Python. I moved the "installation" of the pyscript module to loadInterpreter, and pyimport pyscript_py there and give it a type. This avoids a bunch of creating and deleting of proxies for pyscript_py and allows us to give it a type once and for all. I also did some minor logic cleanup in a few places.
This commit is contained in:
@@ -1,18 +1,26 @@
|
||||
import type { AppConfig } from '../../src/pyconfig';
|
||||
import { InterpreterClient } from '../../src/interpreter_client';
|
||||
import { RemoteInterpreter } from '../../src/remote_interpreter';
|
||||
import { CaptureStdio } from '../../src/stdio';
|
||||
import * as Synclink from 'synclink';
|
||||
import { describe, beforeAll, afterAll, it, expect } from '@jest/globals';
|
||||
// We can't import RemoteInterpreter at top level because we need to mock the
|
||||
// Python package in setup.ts
|
||||
// But we can import the types at top level.
|
||||
// TODO: is there a better way to handle this?
|
||||
import type { RemoteInterpreter } from '../../src/remote_interpreter';
|
||||
|
||||
describe('RemoteInterpreter', () => {
|
||||
let interpreter: InterpreterClient;
|
||||
let stdio: CaptureStdio = new CaptureStdio();
|
||||
let RemoteInterpreter;
|
||||
const { port1, port2 } = new MessageChannel();
|
||||
beforeAll(async () => {
|
||||
const SRC = '../pyscriptjs/node_modules/pyodide/pyodide.js';
|
||||
const config: AppConfig = { interpreters: [{ src: SRC }] };
|
||||
// Dynamic import of RemoteInterpreter sees our mocked Python package.
|
||||
({ RemoteInterpreter } = await import('../../src/remote_interpreter'));
|
||||
const remote_interpreter = new RemoteInterpreter(SRC);
|
||||
|
||||
port1.start();
|
||||
port2.start();
|
||||
Synclink.expose(remote_interpreter, port2);
|
||||
|
||||
6
pyscriptjs/tests/unit/setup.ts
Normal file
6
pyscriptjs/tests/unit/setup.ts
Normal file
@@ -0,0 +1,6 @@
|
||||
import { jest } from '@jest/globals';
|
||||
import { directoryManifest } from '../../directoryManifest.mjs';
|
||||
|
||||
jest.unstable_mockModule('../../src/python_package', async () => ({
|
||||
python_package: await directoryManifest('./src/python/'),
|
||||
}));
|
||||
Reference in New Issue
Block a user