-
Notifications
You must be signed in to change notification settings - Fork 5.9k
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
Workaround for Boost compilation error with Clang 18 and libc++ in ossfuzz buildpack-deps #15713
Conversation
@@ -59,26 +62,19 @@ RUN apt-get update; \ | |||
pygments-lexer-solidity \ | |||
pylint \ | |||
requests \ | |||
tabulate \ | |||
z3-solver; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Z3 is already installed from source in the steps below, so this is unnecessary. I also removed CMake, as it is already included in the base image.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is the python package of Z3
, which is unrelated to the Z3 binary built below.
However, if it can be removed without anything breaking, that it's good to remove it :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, it is not used by any CI job based on the ossfuzz image as far as I know. The chk_proofs which is the job that runs the script mentioned here: #15551 (comment) uses the Ubuntu 24.04 image and it is not run by ossfuzz. This is why I'm also wondering if all the smt stuff is really needed here, or if we should just remove it from this image.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok, I updated Z3 and CVC5, but I kept the removal of the z3-python
, I don't think it is relevant for this image. Because it is required by the tests under test/formal
, which indeed uses the z3 python bindings, but I believe the fuzzer does not run such tests. Maybe there are more things that we could cleanup as well.
This comment was marked as outdated.
This comment was marked as outdated.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Soft approve. Let's wait until end of week for @bshastry to chime in regarding the base image change.
Sure, better to have a response from him on that. Also, honestly, we could maybe even cleanup a bit more our current image. Do we fuzz with smt enabled? |
If you end up not removing the solvers, then they should be updated as was done for other Docker images in #15551. |
61b3046
to
2278b26
Compare
7d91183
to
baadd1a
Compare
This comment was marked as outdated.
This comment was marked as outdated.
LGTM if build passes :-) |
@r0qs, it would be better to unify it with the way I updated the other Docker images. |
baadd1a
to
837208c
Compare
Yes, I guess just fetching the released binaries should be sufficient indeed. But notice that Z3 was build as static library, not sure if this was a requirement. |
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM!
This PR implements the same workaround applied by the ossfuzz maintainers to the Solidity ossfuzz setup:
https://github.com/google/oss-fuzz/blob/5a9322260c4c66e7eb3e5d922b9fee6621ffd8da/projects/solidity/Dockerfile#L17-L18
It replaces
base-clang
withbase-builder
, the same image used by ossfuzz, that utilizes Clang 15. This change allows us to continue running our instance in CI until a fix for the main issue is available.Workaround for: #15711