No description
Find a file
2026-05-21 23:29:41 +02:00
.forgejo/workflows actions: install a python and let's hope the rest will work 2026-02-14 22:02:47 +01:00
.woodpecker CI: tell woodpecker about our new testing situation 2026-05-18 23:49:04 +02:00
src/teilchensammler_cli codestyle: fiddle with type hints and LSP hints 2026-04-08 23:46:50 +02:00
testing tests: snapshots are in "testing/" now as well 2026-05-14 11:53:48 +02:00
.gitignore git: ignore all our releasenotes 2026-02-22 19:30:47 +01:00
changelog.md just: we has a release thing now! 2026-02-21 01:23:38 +01:00
database.db add database.db hoping it helps on CI 2026-02-14 22:46:24 +01:00
justfile just: a little bit less brace expansions for a lot more readability 2026-05-21 23:29:41 +02:00
mise.lock meta: refresh dependencies and tooling 2026-04-27 15:56:57 +02:00
mise.toml make prek a dev dependency 2026-05-19 00:10:59 +02:00
prek.toml tests: snapshots are in "testing/" now as well 2026-05-14 11:53:48 +02:00
pyproject.toml make prek a dev dependency 2026-05-19 00:10:59 +02:00
README.md readme: improved Wording and, perhaps, clarification 2026-05-18 23:50:24 +02:00
requirements.dev.txt Release version 0.5.8 2026-05-14 11:55:53 +02:00
requirements.txt Release version 0.5.8 2026-05-14 11:55:53 +02:00
uv.lock make prek a dev dependency 2026-05-19 00:10:59 +02:00

Teilchensammler

This is a little TUI based on Textual for entering new Teilchen and for searching for existing Teilchen. Data is kept in a sqlite database.

It is not yet usable. It has tests.

Running tests

uv run pytest tests.py
# or if you have just
just test

Observing the app's console

The console can be used to observe log messages, since those logs really should not go to the terminal.

You will need two terminals:

  1. One for showing the console,
  2. The other to run the app.

Since we use uv, the incantation is a bit different from the official documenation.

In one terminal:

uv run textual console
# or if you have just
just console

And in the other:

uv run textual run --dev src/teilchensammler_cli/__init__.py
# or if you have just
just run-console

Developing

To re-create bronsen's development environment, sort of, you need several shiny new toys:

  • just to run the recipes from justfile
  • uv for all the python executing stuff, also venv and versioning
  • prek as a replacement for pre-commit
  • ruff to lint and format the python code
  • markdownlint-cli2 to keep some sort of consistency in our markdowns
  • ty as LSP and type checker

I use just; just runs uv, prek, ruff, and so on. It's indirection and abstraction all the way down.

However, you can also do without all these!

Merge Requests

You know how these work.

Commit style

I prefer simple commit titles, and am not a fan of conventional commits. Do provide as much detail as desired in the message's body. Commit early, commit often; rebase frequently.

Tests

Yes! Please write tests: simple ones, trivial ones; complicated ones, slow ones.

Tests should be written in pytest fashion. Use all the plugins except brittle ones.

Bug Reports, Feature Requests

Create them by clicking "Issues" at the top of the repo page. Do not worry too much about labels.

Please be specific and provide logs, screenshots, or even a test that replicates the problem.

Architectural Changes

These are unlikely to be accepted. This tool is not intended to scale. There might be web front end thing automatically provided by Textual.

Configurations for tools the bronsen does not currently use

Oh sure, I'll accept those. Please create a merge request that adds the file.

AI

Please don't: this is my little human-created thing.

Creating a new release

(This is so bronsen can forget.)

  • run tests; make sure they pass

  • commit

  • uv version --bump {segment}

    Where segment is one of: major, minor, patch, stable, alpha, beta, rc, post, dev

  • commit

  • When we really really want to release:

    • make sure just alltests passes
    • touch releasenotes.md and edit that file
    • just release {Release Name can be several words}
  • Ponder the magnificence of what was accomplished.