Skip to content

Conversation

@benbrandt
Copy link
Member

@benbrandt benbrandt commented Nov 6, 2024

Moves the test_examples.sh and lint_examples.sh to Rust integration tests.

This is indeed much nicer and makes it possible to actually test the Http and Tcp ones, for which I introduced a bug in my last changes that was now caught 🤦🏻

for (ready, pollable), waker in zip(zip(ready, pollables), wakers):
if ready:
pollable.__exit__()
pollable.__exit__(None, None, None)
Copy link
Member Author

@benbrandt benbrandt Nov 6, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This was the issue I introduced by doing the mypy types to match the usual __exit__ pattern... maybe this was a mistake.

@benbrandt
Copy link
Member Author

Ok classic "works on my machine" but not CI... I'll try and dig in. I think I may need to rework some of this

Comment on lines 203 to 213
Command::new("python3")
.current_dir(dir.path())
.args(["-m", "venv", ".venv"])
.assert()
.success();

Command::new("./.venv/bin/pip")
.current_dir(dir.path())
.args(["install", "wasmtime"])
.assert()
.success();
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@dicej I'm not sure if you have a preference here or not. This makes sure the tests can run as long as you have Python installed. But we could also have some docs in the contributing section that python + wasmtime should already be setup. We'll have the same issue with mypy for linting.

@benbrandt
Copy link
Member Author

@dicej ok after much wrestling with windows, this should be ready. All example running and linting is now happening in Rust tests, and with that I was able to get much better coverage.

Copy link
Collaborator

@dicej dicej left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks great overall. Thanks so much for doing this!

As I mentioned inline, I tend to prefer we use library crates and/or std over shelling out to curl, tar, and nc since it reduces the number of utilities that need to be installed to run the tests. Another advantage is that we would have more precise control for the HTTP and TCP examples: rather than telling e.g. curl to do timed retries while waiting for wasmtime to start listening for connections, we could programmatically start the server on an emphemeral port and then use reqwest to send a request to that port (which also avoids potential port conflicts if we ever have more than one HTTP test running in parallel). The downside is that there are more steps to setting up an HTTP server and hooking it up to wasmtime vs. just running wasmtime serve. Anyway, none of that is a blocker, but something to keep in mind as we add more examples and/or tests.

I do think it's reasonable to shell out to pip and python given that it would presumably be more complicated to replace those with library crates.

.success()
.stdout("Component built successfully\n");

Command::new("wasmtime")
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We could use wasmtime as a library here (and elsewhere) instead of requiring the command to be installed. Only the sandbox test needs to use the Python wrapper for wasmtime; the rest could use it as a library.

.success()
.stdout("Component built successfully\n");

let mut nc_handle = std::process::Command::new("nc")
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could use std::net::TcpStream (or the tokio equivalent) instead of nc here.

.join(if cfg!(windows) { "Scripts" } else { "bin" })
}

fn install_numpy(path: &Path) {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's slightly annoying we have two copies of this function and venv_path across bindings.rs and componentize.rs, but I'm not sure it's worth consolidating them into their own library crate. Something to revisit if the amount of duplication increases over time.

@dicej dicej merged commit c54e926 into bytecodealliance:main Nov 7, 2024
3 checks passed
@benbrandt
Copy link
Member Author

Good points. I was so focused on just getting the readme examples to work, I neglected this (at some point I thought of pulling in wasmtime as a lib, but pressed on).

I can do a round two when I get a chance to clean this up and be a little more maintainable. It would also have the benefit of running the nc example on Windows.

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.

2 participants