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.3.0.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.3.0-py3-none-any.whl (88.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: slopstopper_cli-0.3.0.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.3.0.tar.gz
Algorithm Hash digest
SHA256 bc59692894978f8f55122320abef25141db033727239fd888f7b684c80c5e3fa
MD5 39f5991fdfceee0a437a2bc0def87f24
BLAKE2b-256 96681d13bc6b69f1ed0d5d4766635b926959a80488894a951c32eb361ba7c591

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: slopstopper_cli-0.3.0-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.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 522a06f87e53ed4ede9fb33e9a0bf2f4272fcbfe911c0631492a40064b2c5d31
MD5 ef5b87332b05f862bdd321301c7886fd
BLAKE2b-256 e5321783e1c7b1a515f8cfd36c9a2a9753d98d10e20fb3eb862f878cbb554ae6

See more details on using hashes here.

Provenance

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