-
Notifications
You must be signed in to change notification settings - Fork 1.5k
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
Offer Linux aarch64 binary for download #1956
Comments
@mtricolici you are the first one who requests such a build. So I'm not inclined to immediately offer it as artifact on the release page. Would it be ok for you if you could more easily build it yourself via Note that you could always build geckodriver yourself and then distribute this binary across your docker instances. |
make sense. thanks. closing the issue. |
I would suggest to leave this issue open so if wider interest is shown we could consider adding support by default. |
I have also requested the same thing for the same reason, running builds on macOS in Docker. |
For those who want it, you can find an ARM64 geckodriver binary here in this repository: https://github.com/jamesmortensen/geckodriver-arm-binaries/releases There's also some instructions in the README to build it yourself using Docker. |
@whimboo There are a number of Mac M1 and Raspberry Pi users who have requested multi-arch docker-selenium images so they can run tests on their Mac M1 or Raspberry Pi, using the Selenium Docker container images. I am currently working on an experimental community fork of docker-selenium, docker-seleniarm, which builds container images for amd64, arm64, and armhf and publishes to Docker Hub. The biggest challenge we face with multi-arch images is having browser binaries and webdrivers available for those platforms, specifically arm64 (aarch64) and armhf (arm/v7). To simplify the build process of the container images, I built and hosted the aarch64 geckodriver binary myself. When building the docker-seleniarm Firefox images, retrieving the geckodriver binary is now the same for both amd64 and arm64 platforms. This also makes it easier for others to build the seleniarm container images themselves, without having to build the arm64 geckodriver, which is not always easy if you're new to building geckodriver. This Dockerfile from docker-seleniarm will give you an idea of how having a hosted geckodriver arm64 binary is helpful: For now, I think folks can get the Linux ARM binary from https://github.com/jamesmortensen/geckodriver-arm-binaries/releases, but if you wanted to actually host the ARM builds here, I could possibly work on a GitHub Action that builds the binary for Linux aarch64 and publishes as an artifact. |
Thank you for the information @jamesmortensen. Regarding the downloads of the ARM binaries would you mind to specifically name them as Also note that since geckodriver 0.30.0 we officially offer the MacOS ARM binaries for download. So it's really just the Linux ones that are missing. And for these the number of users were too low in the past to actually get these binaries added. If we want to do that it won't work via a github action, but it needs to be done in our own CI. Otherwise we won't be able to run the signing tasks (which wouldn't apply to Linux here). |
@whimboo I made some changes to the README to clarify even further that this is an unofficial build. Please let me know specifically if there is anything else you'd like me to change. https://github.com/jamesmortensen/geckodriver-arm-binaries Also updated the release notes: https://github.com/jamesmortensen/geckodriver-arm-binaries/releases/tag/v0.30.0 |
@jamesmortensen looks fine, thanks! One thing you might still wanna do is to provide md5 hash files for both binary assets. |
@whimboo sorry to be such a noob, but just to confirm:
Is this what you're looking for? If so, I'll add them to the release as:
|
First note that you wanna do that before you upload the builds so maybe even include it into your build script like |
Ah, right, because the idea is to certify that nothing was tampered with in transit... I'll rebuild the drivers and reupload together with the md5 hashes. Thank you. |
I'd be interested in a Linux aarch64 geckodriver release as well. |
@rbruckheimer Please see this unofficial repo. I have built geckodriver aarch64 for 0.31.0. https://github.com/jamesmortensen/geckodriver-arm-binaries/releases/tag/v0.31.0 If you're not comfortable with these unofficial binaries which are not provided by Mozilla, there are instructions in the repo on how to build them yourself. Also, the entire build and release process happens in Github Actions, so you can also audit the process yourself. Hope this helps. |
Note that starting with the 0.31.0 release you can simply build geckodriver directly on your linux aarch64 device by running |
@whimboo this works but it's pretty manual. We are in an environment where testers just run |
Note that I filed https://bugzilla.mozilla.org/show_bug.cgi?id=1779386 to have this request covered on Bugzilla (which we haven't had yet). |
@rbruckheimer Just curious, are you using this node module? https://www.npmjs.com/package/geckodriver It has an environment variable that allows us to specify a different CDN provider, but it just needs a handler to detect aarch64 and download linux-aarch64 geckodriver. If this is the module you're using, it might be easier in the meantime to open an issue with them and see if they can add Linux aarch64 as an additional option. |
@jamesmortensen I do include that package as a dependency; however, I am not using it directly. It's used by webdriverIO and I have no control over its code. |
Several cloud providers now offer aarch64 VMs. If people are slow to adapt them or even just try them out, that's because the ecosystem is still being launched, as exemplified by this ticket. Few people have requested Mozilla for aarch64 binary releases because they have other blockers due to the immature ecosystem. It would be awesome if Mozilla could do something more productive than just saying they are merely one of several blockers for people wanting to use aarch64. I'd see it as one step towards improving Firefox's competitiveness against Chromes (amid the declining popularity) I'm not affiliated with Arm Limited, not even a great fan of ARM instruction sets; however I do believe competitions among different computer architectures will make a positive impact on the future of computing, and decided to spend a few extra hours of my time on the aarch64 deployment of my system. I've been using this for my .Net project https://github.com/rosolko/WebDriverManager.Net type FirefoxConfigWithArm64() =
inherit FirefoxConfig()
let user = "jamesmortensen"
let repo = "geckodriver-arm-binaries"
let rel = $"/{user}/{repo}/releases"
let uri = $"https://github.com{rel}"
override x.GetUrl64() =
if OperatingSystem.IsLinux() && RuntimeInformation.OSArchitecture = Architecture.Arm64 then
// "https://github.com/jamesmortensen/geckodriver-arm-binaries/releases/download/v0.31.0/geckodriver-v0.31.0-linux-aarch64.tar.gz"
$"{uri}/download/v<version>/geckodriver-v<version>-linux-aarch64.tar.gz"
else base.GetUrl64()
override x.GetLatestVersion(): string =
if RuntimeInformation.OSArchitecture = Architecture.Arm64 then
use cli = new HttpClient()
let html = cli.GetStringAsync(uri).Result
let pat = $"\"{rel}/tag/v([\\d.]+)\""
match Regex.Match(html, pat) with
| null -> failwith $"%s{uri} didn't match %s{pat}"
| m -> m.Groups[1].Value
else base.GetLatestVersion() but I have to say having to think about this customization was nothing but a friction to my original project... The unofficial binary above was quite helpful for me but I still had to find a Docker base image with glibc 2.33. With a larger user base that can give feedback (that I hope official binary releases help to create), this shouldn't have been necessary (people knew the need for |
I'd be interested in a Linux aarch64 geckodriver release as well. |
I also need linux aarch64 version |
I'd like to throw my hat in the ring for a ARM build for Linux as well. Like others I'm using Selenium on a M1 Mac within a VM (Parallels running Ubuntu for myself) and having an official release would be extraordinarily useful (with my thanks to @jamesmortensen, which I'm using in the moment). As others have mentioned, ARM is a becoming an increasingly common architecture for use, and given the success of the M1/M2 Apple machines it's going to only expand from here on out. |
With https://bugzilla.mozilla.org/show_bug.cgi?id=1779386 fixed now we will ship Linux aarch64 binaries for geckodriver with its next 0.32.0 release which should happen in the near future. In the meantime feel free to test a nightly build of geckodriver which can be found at: The link to the binary can be found in the lower pane. Please let us know if something doesn't work so that we could still fix it for the upcoming release. Thanks! |
I've just released geckodriver 0.32.0. Linux aarch64 binaries can be found as asset on the release page. |
On M2 Air do I download the "macos" or "macos-aarch64" ? |
@Dibbyo456 the M2 is an arm64/aarch64 architecture, so you'd download the macos-aarch64 build. |
linux aarch64 binaries please? :) I'm on mac . but we run tests in docker...so it's a linux with aarch64
The text was updated successfully, but these errors were encountered: