- Introduction
- Docs
- Commands
- Pre-requisites
- Installation and Downloads
- FAQ
- Other Resources
- Bug Tracker and Support
- Unit Tests
- Development
- Contributing
- Changelog
- License and Copyright
- Author and Thanks
pingping is a special library which understands multi linguistic of ping output and translated the result to machine understandable format. i.e. Json
pingping is a vendor independent library where you can parse any language ping output
pingping support tcping which works on transport layer i.e. Ping on proxy server, here ping refers to seding packets via tcp protocol to check the connectivity.
How to use pingping?
-
Command Line
Typepingping <ip-address>orpingping <ip-address> --web. For more help typepingping -h -
Python
It's very simple, create an object of Ping and call ping method with ip address. Internally it calls system ping command and captures the needed result.
How to run ping command?
# cli
pingping 192.168.1.1
pingping 1.1.1.1
# python code
obj = Ping()
print(obj.ping('192.168.1.1'))
print(obj.ping('1.1.1.1'))
# python tcping ping
obj = Ping(command='tcping', layer=4, timeout=3)
print(obj.ping('192.168.1.1'))
print(obj.ping('1.1.1.1'))It returns Json output and easy to understand by the keys of it.
{"ip": "192.168.1.1", "loss_percentage": 100.0}
{"ip": "1.1.1.1", "loss_percentage": 0.0, "min": 55.669, "avg": 78.198, "max": 130.778, "time_in": "ms"}How to capture result from ping output?
I am having ping result how to analise the output of it.
Ping.fetch_ping_data(ping_output) # it's a class method.It automatically identifies the ip address and important details from it. It doesn't have any language barier.
{"ip": "1.1.1.1", "loss_percentage": 0.0, "min": 55.669, "avg": 78.198, "max": 130.778, "time_in": "ms"}Usage pingping <ip-address>
-c | --count <Number>
-l4 | --web | --tcp | --http (ping over proxy)
-h | --help
pingping supports Python 3.9+. The OS should not matter.
- shconfparser is used to capture the data.
The best way to get pingping is with pip or uv:
pip install pingpingOr using uv:
uv pip install pingpingIf you're interested in the source, you can always pull from the github repo:
git clone https://github.com/network-tools/pingping.git
cd pingping
uv sync --all-extras # Install with dev dependencies- Question: What Python versions does pingping support?
Answer: pingping requires Python 3.8 or higher. All releases are tested against Python 3.8, 3.9, 3.10, 3.11, and 3.12.
- Python3 documentation is a good way to learn python
- Python GeeksforGeeks
- JSON
- Please report any suggestions, bug reports, or annoyances with pingping through the Github bug tracker. If you're having problems with general python issues, consider searching for a solution on Stack Overflow.
- If you can't find a solution for your problem or need more help, you can ask a question.
- You can also ask on the Stack Exchange Network Engineering site.
-
pingping project unit tests are running at GitHub Actions via pytest for Python 3.9+.
-
The current build status is:
This project uses modern Python tooling:
- uv - Fast Python package installer and resolver
- ruff - Fast Python linter
- black - Code formatter
- pytest - Testing framework
- testiq - Test quality analysis tool
# Install uv if you haven't already
curl -LsSf https://astral.sh/uv/install.sh | sh
# Clone and set up the project
git clone https://github.com/network-tools/pingping.git
cd pingping
# Install dependencies
make install
# Run tests
make test
# Run all quality checks (linter, formatter, tests)
make allThe project includes a Makefile for common development tasks:
make help # Show all available commands
# Run testiq analysis (using Makefile)
make testiq
# Get test quality score
make testiq-score
# Generate HTML report
make testiq-html
open testiq_report.htmlOr use commands directly:
# Generate coverage data for TestIQ
uv run pytest --testiq-output=testiq_coverage.json
# Analyze for duplicate tests (skip similarity with threshold 1.0)
uv run testiq analyze testiq_coverage.json --threshold 1.0
# Get test quality score
uv run testiq quality-score testiq_coverage.jsonn all CI checks locallyAnalyze test quality and find duplicates using TestIQ:
# Generate coverage data for TestIQ
uv run pytest --testiq-output=testiq_coverage.json
# Analyze for duplicate tests (skip similarity with threshold 1.0)
uv run testiq analyze testiq_coverage.json --threshold 1.0
# Get test quality score
uv run testiq quality-score testiq_coverage.json
# Generate HTML report with test duplicates analysis
uv run testiq analyze testiq_coverage.json --threshold 1.0 --format html --output testiq_report.html
open testiq_report.htmlWe welcome contributions! Please see our Contributing Guide for detailed information on:
- Setting up your development environment
- Running tests and quality checks
- Code style guidelines
- Submitting pull requests
See CHANGELOG.md for a detailed history of changes to this project.
-
pingping is licensed MIT 2019
pingping was developed by Kiran Kumar Kotari