Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
polyscript
Advanced tools
PyScript single core to rule them all
Please read the documentation page to know all the user-facing details around this module.
The working folder (source code of truth) is the ./esm
one, while the ./cjs
is populated as a dual module and to test (but it's 1:1 code, no transpilation except for imports/exports).
# install all dependencies needed by core
npm i
This project requires some automatic artifact creation to:
core.js
or the pyscript.js
file used by most integration testsAccordingly, to build latest project:
# create all artifacts needed to test core
npm run build
# optionally spin a server with CORS, COOP, and COEP enabled
npm run server
If no minification is desired or helpful while debugging potential issues, please use NO_MIN=1
in front of the build step:
NO_MIN=1 npm run build
npm run server
Besides spinning the localhost server via npm run server
, the npm run dev
will watch changes in the ./esm
folder and it will build automatically non optimized artifacts out of the box.
To keep it simple, and due to technical differences between what was in PyScript before and what we actually need for core (special headers, multiple interpreters, different bootstrap logic), core integration tests can be performed simply by running:
npm run test:integration
The package's entry takes care of eventually bootstrapping localhost, starting in parallel all tests, and shutting down the server after, if any was bootstrapped.
The tool to test integration is still playwright but moves things a bit faster (from my side) tests are written in JS.
integration
├ interpreter
│ ├ micropython
│ ├ pyodide
│ ├ ruby-wasm-wasi
│ ├ wasmoon
│ ├ xxx.yy
│ ├ xxx.toml
│ └ utils.js
├ _shared.js
├ micropython.js
├ pyodide.js
├ ruby-wasm-wasi.js
└ wasmoon.js
.html
and other files to test every specific behavior. In this folder, it's possible to share files, config, or anything else that makes sense for one or more interpreters._
(underscore) will be ignored for tests purposes but it can be used by the code itself._shared.js
file as it is for most Pyodide and MicroPython cases.The test/integration.spec.js file simply loops over folders that match interpreters by name and execute in parallel all tests.
To test manually an integration test, simply npm run server
and visit http://localhost:8080/ or http://localhost:8080/test/integration.html to find a list of all integration tests available in the related folder.
As example, reaching http://localhost:8080/test/integration/interpreter/micropython/fetch.html would log in the console and show expectations on the page and this can be easily tested via multiple browsers by simply reaching the very same integration test.
FAQs
PyScript single core to rule them all
The npm package polyscript receives a total of 7,954 weekly downloads. As such, polyscript popularity was classified as popular.
We found that polyscript demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.