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

ci: build binary artifacts for pushes/PRs #506

Merged
merged 3 commits into from
Dec 31, 2024
Merged

Conversation

cpu
Copy link
Member

@cpu cpu commented Dec 16, 2024

This branch adds a CI job for all pushes & PRs that builds binary artifacts for rustls-ffi for:

  • Windows (x86_64 MSVC)
  • Debian .deb (x86_64 GNU)
  • Linux (x86_64 GNU)
  • Apple (ARM64 and x86_64)

Binary artifacts are built in release mode using stable rust, with the default crypto provider (aws-lc-rs) and cert compression enabled.

Linux binaries are built on ubuntu-20.04 for greatest compatibility. Users will need glibc 2.31 or greater. For now I've opted not to include a statically linked musl build.

For FIPS, no cert-compression, the ring crypto provider, debug builds, or other customization you will need to build from source.

Users of the .pc files from the bare archive will need to override the prefix to wherever they extract the archive, or use cargo cinstall from src. Package config files in an archive aren't relocatable. The .deb for Debian/Ubuntu has the correct .pc prefix already.

The build library zips are automatically added to the CI run as artifacts. This has the advantage that we don't need any special write permissions and can manually attach binary artifacts to the releases we publish as appropriate. For now I'd like to avoid automating the release process. Artifact links associated with a branch are valid for ~90d.

You can see the artifacts produced for this PR here, under the annotations.

artifacts_000

See an example of a simple C test application built using cmake and pkg-config from the distributed binary releases here: https://github.com/cpu/rustls-ffi-test It's used by testing CI stages that run after the packaging step for each OS/output.

Unpacking the archives gives structure like:

# Linux
.
├── include
│   └── rustls.h
├── lib
│  ├── librustls.a
│  ├── librustls.so
│  ├── librustls.so.0.15.0
│  └── pkgconfig
│      └── rustls.pc
# MacOS
.
├── include
│   └── rustls.h
├── lib
│   ├── librustls.0.15.0.dylib
│   ├── librustls.a
│   ├── librustls.dylib
│   └── pkgconfig
│       └── rustls.pc
# Windows
.
├── bin
│   ├── rustls.dll
│   └── rustls.pdb
├── include
│   └── rustls.h
├── lib
│   ├── pkgconfig
│   │   └── rustls.pc
│   ├── rustls.def
│   ├── rustls.dll.lib
│   └── rustls.lib

The .deb displays the following:

$ dpkg-deb --info librustls_0.15.0_amd64.deb
 new Debian package, version 2.0.
 size 8759588 bytes: control archive=420 bytes.
     211 bytes,     8 lines      control
      26 bytes,     3 lines   *  postinst             #!/bin/sh
 Package: librustls
 Version: 0.15.0
 Architecture: amd64
 Maintainer: Daniel McCarney <[email protected]>
 Description: FFI bindings for the Rustls TLS library
 Section: libs
 Depends: libc6
 Priority: optional
 
$ dpkg-deb --contents librustls_0.15.0_amd64.deb
drwxr-xr-x runner/docker     0 2024-12-22 20:09 ./
drwxr-xr-x runner/docker     0 2024-12-22 20:09 ./usr/
drwxr-xr-x runner/docker     0 2024-12-22 20:09 ./usr/include/
-rw-r--r-- runner/docker 122289 2024-12-22 20:09 ./usr/include/rustls.h
drwxr-xr-x runner/docker      0 2024-12-22 20:09 ./usr/lib/
drwxr-xr-x runner/docker      0 2024-12-22 20:09 ./usr/lib/x86_64-linux-gnu/
-rw-r--r-- runner/docker 38767436 2024-12-22 20:09 ./usr/lib/x86_64-linux-gnu/librustls.a
-rwxr-xr-x runner/docker  6082776 2024-12-22 20:09 ./usr/lib/x86_64-linux-gnu/librustls.so.0.15.0
drwxr-xr-x runner/docker        0 2024-12-22 20:09 ./usr/lib/x86_64-linux-gnu/pkgconfig/
-rw-r--r-- runner/docker      286 2024-12-22 20:09 ./usr/lib/x86_64-linux-gnu/pkgconfig/rustls.pc
lrwxrwxrwx runner/docker        0 2024-12-22 20:09 ./usr/lib/x86_64-linux-gnu/librustls.so -> librustls.so.0.15.0

Resolves #218

@cpu

This comment was marked as outdated.

@cpu cpu self-assigned this Dec 16, 2024
@cpu cpu marked this pull request as draft December 17, 2024 16:59
@cpu

This comment was marked as outdated.

@cpu cpu force-pushed the cpu-bin-artifacts branch 16 times, most recently from e001e8c to ae38c18 Compare December 22, 2024 17:24
@cpu
Copy link
Member Author

cpu commented Dec 22, 2024

I haven't done extensive testing of the built artifacts from an external project yet, I'll try to that shortly.

This shook out some useful findings:

  1. Avoid using xx-latest images in CI for this task... I lost a lot of time debugging some weird Glibc symbol resolution errors with the Linux artifacts before I realized my fork of the repo was using ubuntu-latest == 22.04 and this repo was using ubuntu-latest == 24.04. I knew that change was coming, but thought it would be universally applied .... 🤬

  2. It's best to build with an older Linux image if we can, to keep maximum glibc compat. I'm using 20.04, which also requires building with CC=clang instead of gcc because aws-lc's build system flags the gcc as vulnerable to a nasty compiler bug.

  3. For the MacOS dylib we need to patch the dylib ID to @rpath/librustls.dylib so that it can be located anywhere on the typical search path. The cargo cinstall dylib has its ID hardcoded to the location it spits it out.

In the end I was able to get a repo working with a simple C application that spits out rustls_version() on macos-latest (arm64), macos-13 (x86_64), windows-latest (x86-64) and ubuntu-latest (x86_64) using the pre-built artifacts & cmake's pkg-config integration. You can find that here: https://github.com/cpu/rustls-ffi-test The Linux binaries also work unmodified on my NixOS system.

One place for improvement: I had to lift some of the tests/CMakeList.txt for the Windows build. I think this should be handled automatically through the .pc file of our lib describing the required linker args, but it doesn't seem to be working right. I will chase this down another time.

rustls-ffi / Windows (aws-lc-rs, Debug) (pull_request) Failing after 4m

This seems to be unrelated but still needs to be debugged:

  research.cloudflare.com.ech.configs.bin
  client[2180]: using the platform verifier for certificate verification.
  client[2180]: using ECH config lists 'research.cloudflare.com.ech.configs.bin'
  client[2180]: no compatible/valid ECH configs found in 'research.cloudflare.com.ech.configs.bin'
  client[2180]: failed to configure ECH with any provided config files

@cpu cpu marked this pull request as ready for review December 22, 2024 17:44
@cpu cpu force-pushed the cpu-bin-artifacts branch from 91efb3e to f5e0234 Compare December 22, 2024 20:07
@ctz
Copy link
Member

ctz commented Dec 22, 2024

  • Avoid using xx-latest images in CI for this task... I lost a lot of time debugging some weird Glibc symbol resolution errors with the Linux artifacts before I realized my fork of the repo was using ubuntu-latest == 22.04 and this repo was using ubuntu-latest == 24.04. I knew that change was coming, but thought it would be universally applied .... 🤬

Oh! I think that has also been happening for rustls-libssl.

@cpu
Copy link
Member Author

cpu commented Dec 22, 2024

Oh! I think that has also been happening for rustls-libssl.

Looks like it 😓 Here's a fix PR: rustls/rustls-openssl-compat#45

@cpu cpu force-pushed the cpu-bin-artifacts branch from f5e0234 to 7629416 Compare December 26, 2024 22:22
@cpu
Copy link
Member Author

cpu commented Dec 26, 2024

cpu force-pushed the cpu-bin-artifacts branch

Tidied up my commit history & added testing to the workflow.

@cpu cpu force-pushed the cpu-bin-artifacts branch from 7629416 to c75692b Compare December 26, 2024 22:24
@cpu cpu mentioned this pull request Dec 28, 2024
14 tasks
Copy link
Collaborator

@jsha jsha left a comment

Choose a reason for hiding this comment

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

Looks good to me. Do you want to move the rustls-ffi-test repo into the rustls org at some point?

@cpu
Copy link
Member Author

cpu commented Dec 28, 2024

Thanks for taking a look 🙇

Do you want to move the rustls-ffi-test repo into the rustls org at some point?

Good question - I think with a bit of cmake work to allow finding an existing librustls instead of building it w/ cargo-c we could re-use the client/server tests that are already in-repo. I think that's a better route since it will actually test the functionality as well as building/linking.

I'll make a follow-up issue for that 📝 Edit: #519

cpu added 3 commits December 29, 2024 10:53
* Windows (x86_64 MSVC)
* Linux (x86_64 GNU glibc)
* Apple (ARM64 and x86_64)

Binary artifacts are built in release mode using stable rust, with the
default crypto provider (aws-lc-rs) and cert compression enabled.

Linux binaries are built on ubuntu-20.04 for greatest compatibility.
Users will need glibc 2.31 or greater. For now I've opted not to include
a statically linked musl build.

For FIPS, no cert-compression, the ring crypto provider, debug builds,
or other customization you will need to build from source.

Users of the `.pc` files will need to override the `prefix` to wherever
they extract the archive, or use `cargo cinstall` from src. Package
config files in an archive aren't relocatable.
Uses a small script (`debian/build.sh`) to massage the output of
cargo-c's build into a `.deb` that can be installed on Debian/Ubuntu
systems.
Uses the cpu/rustls-ffi-test repo and the artifacts produced by earlier
stages of the workflow to smoke-test the builds.
@cpu cpu force-pushed the cpu-bin-artifacts branch from c75692b to c4cc238 Compare December 29, 2024 15:54
@cpu
Copy link
Member Author

cpu commented Dec 29, 2024

cpu force-pushed the cpu-bin-artifacts branch

I removed the macos-13 runner. It added a long time to the build process because we had to build cargo-c from source (upstream only publishes binaries for arm64 mac).

Instead I realized we could use the arm64 runner/cargo-c bins to cross-compile the Mac x86_64 build. Much faster. We're now bottlenecked by Windows and I don't think can do much there.

@cpu
Copy link
Member Author

cpu commented Dec 31, 2024

@ctz (No pressure) would you like to review this or should I merge based on Jsha's +1?

@cpu cpu merged commit 773508e into rustls:main Dec 31, 2024
45 checks passed
@cpu cpu deleted the cpu-bin-artifacts branch December 31, 2024 15:54
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.

Ship prebuilt artifacts
3 participants