Metadata-Version: 2.1
Name: speedcheck
Version: 0.0.5
Summary: Simple CLI for running internet speed tests
Home-page: https://github.com/samapriya/speedcheck
Author: Samapriya Roy
Author-email: samapriya.roy@gmail.com
License: Apache 2.0
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Natural Language :: English
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Operating System :: OS Independent
Requires-Python: >=3.9
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: deepdiff >=7.0.1
Requires-Dist: playwright >=1.44.0
Requires-Dist: requests >=2.32.3
Requires-Dist: speedtest-cli >=2.1.3
Requires-Dist: websockets >=12.0

<p align="center">
  <img src="https://github.com/samapriya/speedcheck/assets/6677629/f5eab7b1-ee73-4074-b1fa-662b8bc42752" width="128" height="128" alt="Your image description">
</p>

<p align="center">
  <strong>
    SpeedCheck: A Simple combined Internet Speedtest
    <a href="https://pypi.org/project/speedcheck"></a>
  </strong>
</p>

<p align="center">
  <a href="https://github.com/samapriya/speedcheck/actions/workflows/CI.yml"><img
    src="https://github.com/samapriya/speedcheck/actions/workflows/CI.yml/badge.svg"
    alt="Build"
  /></a>
  <a href="https://pypi.org/project/speedcheck"><img
    src="https://img.shields.io/pypi/v/speedcheck"
    alt="Python Package Index"
  /></a>
  <a href="https://opensource.org/licenses/Apache-2.0"><img
    src="https://img.shields.io/badge/License-Apache%202.0-blue.svg"
    alt="License"
  /></a>
</p>

<p align="center">
  Run a quick speed check across multiple speed test providers
  Simple CLI to combine these and provide a JSON response for all
</p>

**SpeedCheck** is a simple command-line interface (CLI) tool designed to help users measure their internet speed using various popular speed test providers. Read about the [motivation and additional details about this project here](https://datacommons.substack.com/p/data-commons-and-connectivity-exploring). Whether you want to check the performance of your connection through Cloudflare, Fast.com, Ookla, or M-Lab, SpeedCheck provides a unified and straightforward way to run these tests from the command line. This tool consolidates multiple speed test services into one easy-to-use package, allowing users to quickly and efficiently assess their internet connection's download and upload speeds, latency, and overall performance.


## Features

- Run speed tests from multiple providers:
  - Cloudflare
  - Fast.com
  - Ookla
  - M-Lab
  - Speed Smart
  - Open Speed Test
- Check and compare the installed version of SpeedCheck with the latest version available on PyPI.
- Get information about the speed tests supported by SpeedCheck.
- SpeedCheck also notifies you if a newer version of the package is available on PyPI.

## Installation

To install SpeedCheck, use pip:

```
pip install speedcheck
```

## Setup
We recommend using a virtual environment to manage dependencies. Once your virtual environment is set up, make sure to run the following command to ensure that the necessary browsers are downloaded

```
speedcheck setup
```

The rest of the dependencies are handled through setup.py. This project is in its early stages, so your feedback and contributions are highly appreciated.

## Usage

**Getting Information**: To get information about the supported speed tests, use the info command:

```
speedcheck info
```

**Running Speed Tests**: To run a speed test, use the run command followed by the --type argument to specify the speed test provider.

```
speedcheck run --type [provider]
```

Replace **provider** with one of the following options:

* cloudflare
* fast
* ookla
* mlab
* speedsmart
* openspeedtest

Example:

```
speedcheck run --type cloudflare
```

## Contributing
Contributions are welcome! Please open an issue or submit a pull request on GitHub. We encourage pull requests to add additional testers to the SpeedCheck tool.

## Contact
For any questions or suggestions, feel free to open an issue on the GitHub repository.

## Changelog

#### v0.0.5
- added ```speedcheck setup``` tool to handle playwright & playwright dependencies

#### v0.0.4
- updated cloudflare runner to handle IP address with no region metadata
- added IP to region lookup service

#### v0.0.3
- avoid printing extraneous information for cloudflare tests
- added additional dependency information & blog link
- updated readme with logo and badges
- enabled version check

#### v0.0.2
- added speedsmart and openspeedtest
- increased project maturity to beta
- added readme docs
