Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add WASM wheels build #1653

Draft
wants to merge 2 commits into
base: main
Choose a base branch
from
Draft

Add WASM wheels build #1653

wants to merge 2 commits into from

Conversation

gbolmier
Copy link
Member

@gbolmier gbolmier commented Nov 28, 2024

Let's first test the build of the WASM wheels in an independant workflow so that it is easier to iterate and make sure it works before adding the logic to the pypi workflow.

See #1649 thread for more context.

Current blocker is a conflict between River pandas<3.0.0,>=2.2.3 requirement and Pyodide pandas version (2.2.0) (see run error).

Let's first test the build of the WASM wheels in an independant
workflow so that it is easier to iterate and make sure it works
before adding the logic to the pypi workflow.
@gbolmier gbolmier force-pushed the build-wasm-wheels branch 2 times, most recently from e780d5f to e0fb7b5 Compare November 28, 2024 05:09
@MaxHalford
Copy link
Member

Great stuff @gbolmier!

For the pandas version, I guess it's fine to loosen it on our end.

@gbolmier
Copy link
Member Author

For the pandas version, I guess it's fine to loosen it on our end.

I would prefer too, if possible. @agriyakhetarpal do you remember why you bumped pandas from ^2.1 to ^2.2.3 in #1632?

I just realized that Pyodide is not supporting NumPy >=2.0 yet (see supported list). That's why their supported pandas version is 2.2.0 (which is not supporting NumPy >=2.0 (see reqs).

@agriyakhetarpal does it mean that we need to wait for Pyodide to support newer pandas and NumPy versions in order to test River's WASM build?

@agriyakhetarpal
Copy link
Contributor

Hi @gbolmier, sorry for the late response – this PR got buried in my notifications!

Yes, you are right. We will currently need to wait for a Pyodide release to be able to grab NumPy >= 2.0 and pandas >= 2.2.3. The reason for bumping pandas to ^2.2.3 was indeed due to the NumPy build-time constraint (IIRC, 2.2.2 is the first version to build against NumPy v2).

@agriyakhetarpal
Copy link
Contributor

Hi @gbolmier and @MaxHalford, Pyodide 0.27 has been released on 01/01/2025: https://github.com/pyodide/pyodide/releases/tag/0.27.0

We should be able to go ahead with this PR now 🚀 This does require pypa/cibuildwheel#2117, though – but we may switch to the non-cibuildwheel implementation and that would work just fine.

Here's an example workflow if you'd like: https://github.com/scikit-image/scikit-image/blob/107c1a9a2c49f86668c41e8e5a1c101d71ff122f/.github/workflows/emscripten.yml, which just needs the PYODIDE_VERSION to be set to 0.27.0 instead of the alpha release.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants