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.4.1.tar.gz (101.7 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.4.1-py3-none-any.whl (88.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: slopstopper_cli-0.4.1.tar.gz
  • Upload date:
  • Size: 101.7 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.4.1.tar.gz
Algorithm Hash digest
SHA256 313cca8de56f1e9662b486d807a8d210162470e0cf89854e9f7630ba025930a0
MD5 de637e96018ce49ffb1675ff0ed4acef
BLAKE2b-256 43b57cc3c2b7ff94bd28849fcb80ab28de935a94522996b14838a83eca5ee71b

See more details on using hashes here.

Provenance

The following attestation bundles were made for slopstopper_cli-0.4.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.4.1-py3-none-any.whl.

File metadata

  • Download URL: slopstopper_cli-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 88.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.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 75a0768147a9928c55806e0220353c5a53f128c3d5dd8988f8586b32ceaed2f1
MD5 e748a34debb6f9360a1708525ec45b3c
BLAKE2b-256 17893b4dc914ceb7ffe96c3e7a770bad0e9335f9b9c65d5ff3723262e37d0aeb

See more details on using hashes here.

Provenance

The following attestation bundles were made for slopstopper_cli-0.4.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