A CLI tool that displays network speed test results from Cloudflare's speed test service in a TUI interface.
Warning
If you're seeing zero download speeds, a hotfix has been implemented in v0.6.2. If you are on a version before this, upgrade by following the installation instructions below.
- Speed Tests: Measures download/upload throughput, idle latency, and loaded latency
- Interactive TUI: Real-time charts and statistics
- History: View and manage past test results
- Export: Save results as JSON
- Text/JSON Modes: Headless operation for scripting
- Interface Binding: Bind to specific network interface or source IP
My preferred way if you have cargo installed:
cargo install --git https://github.com/kavehtehrani/cloudflare-speed-cli --features tuiThis works for both older Intel and newer Silicon Mac computers.
brew tap kavehtehrani/tap
brew install cloudflare-speed-cliFor the lazy:
curl -fsSL https://raw.githubusercontent.com/kavehtehrani/cloudflare-speed-cli/main/install.sh | shAs other people have kindly contributed, I've merged their pull requests for the distro they have contributed toward. My main OS is Ubuntu and Fedora, and the main distribution mechanism for this package is via 'cargo-dist' which I have found helpful in generating the compatible binaries via github actions. If you would like to contribute for other distros, please open an issue or send in a pull request.
The package can be installed from the official repositories:
pacman -S cloudflare-speed-cli nix run github:kavehtehrani/cloudflare-speed-cliDownload the static binary for your system from the latest release.
Note: I have checked the binaries on Linux (x64 and ARM64) and on Windows 11 but I do not have an Apple device. If there is any issue please do let me know!
If you have docker installed you can run the speedtest by pulling in the image:
docker pull ghcr.io/kavehtehrani/cloudflare-speed-cli:latest
docker run --rm -it ghcr.io/kavehtehrani/cloudflare-speed-cliIf you also want the history of runs to persist, then you have to mount a volume, e.g.
docker run --rm -it -v cloudflare-speed-data:/root/.local/share/cloudflare-speed-cli ghcr.io/kavehtehrani/cloudflare-speed-cli
Run with the TUI (default):
cloudflare-speed-cliText output mode:
cloudflare-speed-cli --textTo see all options:
cloudflare-speed-cli --helpUses endpoints from speed.cloudflare.com You can read more about how Cloudflare's speedtest works here.
- Network information on Windows is incomplete. I haven't used Windows (outside gaming) in many years and unless there's demand for it I likely won't implement this part. Feel free to open a PR or an issue and we can chat. Honestly the only reason there's a Windows binary at all is because 'cargo-dist' made it so easy to do so.
Contributions and comments are very welcome! Please feel free to open issues or pull requests.


