Skip to main content

Portable code-quality suite — security, hygiene, reliability.

Project description

slopstopper-cli

The SlopStopper quality suite, packaged as a pipx-installable CLI.

Status: Beta. Every check in the public catalogue runs through this package. The CI workflows under .github/workflows/ss-*.yml install slopstopper-cli and call slopstopper run <category>:<check> — same code path you use locally.

Install

End-user (most adopters):

pipx install slopstopper-cli
slopstopper --version
slopstopper checks list
slopstopper doctor

Published to PyPI on every release tag. pipx upgrade slopstopper-cli pulls the latest. Each release is also attached to the latest GitHub Release with a Sigstore build-provenance attestation — verify with gh attestation verify <wheel> --owner hungovercoders.

Development (editable, from a clone of this repo):

pip install -e ./cli
slopstopper run hygiene:docs-size

CLI surface

slopstopper run <category>:<check>             # run a check, write reports under .ss/reports/
slopstopper emit <c>:<n> --target {pr-comment,issue}
slopstopper discover <check> --event <e>       # resolve pages.<check> from sitemap / changed / list
slopstopper config get <key> [<default>]       # read .slopstopper.yml
slopstopper templates {list, path <n>, eject <n>}   # inspect / customise bundled templates
slopstopper serve                              # bundled static server (auto-detects worker/headers.json)
slopstopper checks list [--category <c>] [--json]
slopstopper doctor                             # verify external tools are installed
slopstopper --quiet …                          # suppress decorative output (CI logs)

slopstopper with no args prints a banner of the commands above plus a quick-start block.

Run the tests

# From the repo root:
task -t cli/Taskfile.yml test

# Or from cli/:
task test

# Filter to a single test:
task -t cli/Taskfile.yml test -- -k docs_size

The same task test target is what CI runs (see .github/workflows/ci-cli.yml), so local and CI invocations stay in sync. The Taskfile creates and reuses a project-local venv at cli/.venv/ (gitignored) so it doesn't conflict with system Python under PEP 668.

This workflow is slopstopper-internal — it is not part of the distributed ss-*-check.yml suite and is never seeded into adopter repos.

Layout

  • slopstopper/cli.py — argparse dispatcher + bare-invocation banner
  • slopstopper/output.py — shared formatters (running / success / warn / error / footer / --quiet)
  • slopstopper/config.py.slopstopper.yml reader (stdlib-only YAML subset)
  • slopstopper/templates.py — bundled-template resolver + templates {list, path, eject} API
  • slopstopper/emit.pygh CLI wrapper for PR comment + main-branch issue emission
  • slopstopper/discovery.py — pages-to-audit resolver for reliability checks
  • slopstopper/checks/ — one module per check; registry in __init__.py
  • slopstopper/data/ — bundled Playwright specs, lighthouserc dev/prod, server.js

Adding a check

  1. Add slopstopper/checks/<name>.py exposing run(args) -> int. Start the module docstring with a one-line summary (slopstopper checks list reads it).
  2. Register it in slopstopper/checks/__init__.py's REGISTRY dict.
  3. Write the report to .ss/reports/<category>/<name>-report.md in the CWD.
  4. Use from slopstopper import output for any user-facing print calls so --quiet and the consistent visual language come for free.
  5. If the check should be postable to a PR or issue, declare a META dict in the module — emit.py reads it.

Skills for agents

The trio under .claude/skills/slopstopper-{install,update,triage}/SKILL.md is the long-form playbook for Claude Code agents working with this CLI. Update them when you add or rename a check, env var, or task ss:* target.

Acknowledgements

slopstopper-cli ships with no third-party Python dependencies — every check invokes its tool via subprocess only. Full credit, licences and upstream links for every tool we drive live in ATTRIBUTIONS.md.

License

MIT — see LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

slopstopper_cli-0.5.1.tar.gz (108.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

slopstopper_cli-0.5.1-py3-none-any.whl (91.7 kB view details)

Uploaded Python 3

File details

Details for the file slopstopper_cli-0.5.1.tar.gz.

File metadata

  • Download URL: slopstopper_cli-0.5.1.tar.gz
  • Upload date:
  • Size: 108.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for slopstopper_cli-0.5.1.tar.gz
Algorithm Hash digest
SHA256 98228f08787448a5156cb930569997e5fe52a18229ddaa48d7a9458bc4b8e402
MD5 f72d946f503ad432f87b04999908ea5d
BLAKE2b-256 912e86d364d7abced3352f3dacf49c9fad9bf0b1fc55e04dc09934822f247671

See more details on using hashes here.

Provenance

The following attestation bundles were made for slopstopper_cli-0.5.1.tar.gz:

Publisher: ss-release.yml on hungovercoders/slopstopper

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file slopstopper_cli-0.5.1-py3-none-any.whl.

File metadata

  • Download URL: slopstopper_cli-0.5.1-py3-none-any.whl
  • Upload date:
  • Size: 91.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for slopstopper_cli-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c6e4c740d3058c310501514c8b134ad5a98f88951c1d832dc8ffde2e26652a71
MD5 08845005cd5a99e427ef8ea37715be2e
BLAKE2b-256 02aed7f39073309c2c35937a59c8e7ea0b42a12885302e30288574219998fc01

See more details on using hashes here.

Provenance

The following attestation bundles were made for slopstopper_cli-0.5.1-py3-none-any.whl:

Publisher: ss-release.yml on hungovercoders/slopstopper

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page