-
Notifications
You must be signed in to change notification settings - Fork 832
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
Outdated Cargo.lock file? #1986
Comments
Thanks for the report! We're updating our Rust versions in CI including moving aarch64 macos to 1.49, so we'll get it fixed in #1985 |
1985: Bump Rust used in CI to 1.48 r=MarkMcCaskey a=MarkMcCaskey We also switch from `nightly` to `1.49` for aarch64 macos because it became a tier 2 target in `1.49` Resolves #1986 # Review - [x] Add a short description of the the change to the CHANGELOG.md file Co-authored-by: Mark McCaskey <[email protected]>
Reopening because I don't know if this was actually fixed, we attempted to build Wasmer on aarch64-apple-darwin with Rust 1.49 and had no problems doing so locally. Additionally it worked in CI, is there something we're missing to be able to reproduce this issue? |
Yes, it does look like we're missing something... See in particular this comment: Homebrew/homebrew-core#68341 (comment) And perhaps this one, though I really only say things I've said before in slightly different words. However, it may still clarify some things: Homebrew/homebrew-core#68341 (comment) Edit: Sorry, in case you don't feel like chasing links, I actually explain the content of those two links in my next comment. |
Hey - When I run
|
But, I guess, to explain more fully here so you don't have to keep chasing links I share: The reason I assumed it was a stale lock file was that wasmer builds (consistently) fail on our ARM runners. Our build script does nothing out of the ordinary, it just (essentially) runs
after extracting the contents of the release tarball in a build directory. However, we discovered that if, instead, we ran
then the build no longer fails. Could something else cause this pattern of observations? That said, I don't know how to reconcile this with @ezfe's experience above. |
Oh, I think the command we have to run is in the wasmer-cli, not the workspace per se (I think this changed from The command to run should be: cargo install --path lib/cli |
That command does start the install process for me error[E0432]: unresolved import `syn::export`
--> /Users/ezekielelin/.cargo/registry/src/github.aaakk.us.kg-1ecc6299db9ec823/enumset_derive-0.5.0/src/lib.rs:10:10
|
10 | use syn::export::Span;
| ^^^^^^ could not find `export` in `syn`
error: aborting due to previous error
For more information about this error, try `rustc --explain E0432`.
error: could not compile `enumset_derive`
To learn more, run the command again with --verbose.
warning: build failed, waiting for other jobs to finish...
error: failed to compile `wasmer-cli v1.0.0 (/Users/ezekielelin/temp_dev/wasmer/lib/cli)`, intermediate artifacts can be found at `/Users/ezekielelin/temp_dev/wasmer/target`
Caused by:
build failed |
Just saw the same error, it was caused because 5 hours ago when Since
This is a major issue (since Tagging also @Lymia as she is the owner of the Right now all packages that depend on the |
Following up on this, what's the justification for homebrew updating locked deps? My understanding was that the intention of lockfiles was to provide a known, good set of dependency versions to allow binaries to continue to build and function as expected. It seems a bit strange to bypass the idea of the lockfile here. Thanks for looking into this @syrusakbary! That's useful information. As a side, if you've run But updating outside of the wasmer tree means that those dependency versions in wasmer have not necessarily gone through our CI / testing process. So I wouldn't recommend, in general, updating locked dependencies before building and shipping binaries. (unless the new build is also tested to the builder's satisfaction, then it doesn't matter) I suppose if everyone semvers completely correctly and none of the code has any undefined behavior, then updating locked deps should be safe. |
Sorry, you must've misunderstood me (or perhaps I was unclear). We don't update locked dependencies: our standard |
Oh okay! Sorry about the misunderstanding! I just assumed that's what was going on because of how I was able to reproduce it. So I'm actually not familiar with the I'm not completely clear on what that means, but that naively sounds like the opposite of what I would expect that flag to do. |
Yea, the docs here are a bit unclear too... but my understanding, based on lots of If you don't pass the |
From
|
Fascinating, that sounds like there's no way to use lockfiles like I expected with Feels like I must be missing some important information about how to use lockfiles correctly, I'll look into it some more -- thanks! |
@syrusakbary @carlocab Regarding the
|
Unfortunately we won't be able to publish a new release with a git dependency (crates.io does not allow it last I checked, because git repos aren't guaranteed to stay online, etc.), so I don't think that solves the Thanks for following up on this though! And for the information about the fix |
Homebrew CI tests are failing not only on Big Sur ARM but also on 10.14 and 10.15 x86_64 macOS (x86_64 11.0 is pending), after sucessfully building with The failure output is this:
On my local M1 MacBook, I tried generating a
I was thinking, maybe we are only building the CLI, and the Wasmer engine needs to be built separately as of 1.0.0.. The documentation for Wasmer says that to build wasmer from source you need to run I tried compiling with that on my machine, and nope, same error.
I wanted to check one more thing to see if my generated pub fn main() {}
#[no_mangle]
pub extern fn sum(a: i32, b: i32) -> i32 {
a + b
} and compiled it using
Same error. |
After looking through the
🎉🎉🎉 Looks like as of Wasmer 1.0, you have to specify which compiler it should use. The default compiler, which is compatible with arm64 as well as being the one provided in their CI releases, is |
Thanks to @richiksc for sorting out a working build of wasmer. Though, now we need to work out what the correct options to use for the |
We now have an official build and bottle of wasmer 1.0.0 on Homebrew. However, we still are building with just That's probably out of scope of this issue however. Given that the current Cargo.lock file builds succesfully with |
I agree. Thanks for the help everyone! |
Sorry about the delay, we detect features in the Makefile, so |
Summary
wasmer is currently failing to build for Homebrew with Rust 1.49 on Apple Silicon: Homebrew/homebrew-core#68089, Homebrew/homebrew-core#68341, CI logs
It appears this is due to a stale lock file, causing
cargo install --locked
to pull in dependencies that do not work for wasmer on Apple Silicon. Is it possible for theCargo.lock
file to be updated? If this could be done with a new release, that would be especially helpful.Additional details
Related: Homebrew/homebrew-core#68301
The text was updated successfully, but these errors were encountered: