No description
Find a file
bronsen e5bb663ee8
All checks were successful
ci/woodpecker/push/workflow Pipeline was successful
main,database: add debug log stanzas
closes: #7
2026-02-22 20:59:45 +01: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: move command line arguments into environment variables 2026-02-20 22:53:30 +01:00
__snapshots__/tests tests: update snapshot after changing placeholder text for input field 2026-02-22 16:45:27 +01:00
src/teilchensammler_cli main,database: add debug log stanzas 2026-02-22 20:59:45 +01: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
conftest.py tests: create custom mark for test functions 2026-02-20 21:23:48 +01:00
database.db add database.db hoping it helps on CI 2026-02-14 22:46:24 +01:00
justfile just: export requirements when building a release 2026-02-22 20:24:37 +01:00
mise.toml prek: never use colors 2026-02-22 12:09:06 +01:00
prek.toml prek: we don't have yamls to check 2026-02-22 12:17:12 +01:00
pyproject.toml Release version 0.5.3 2026-02-22 20:24:50 +01:00
README.md doc: update notes about releasing since the script now works for the most part 2026-02-22 12:09:53 +01:00
requirements.dev.txt Release version 0.5.3 2026-02-22 20:24:50 +01:00
requirements.txt Release version 0.5.3 2026-02-22 20:24:50 +01:00
tests.py codestyle: move "statement" out of with block 2026-02-22 19:05:37 +01:00
uv.lock Release version 0.5.3 2026-02-22 20:24:50 +01: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
  • 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

I use just; just uses 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 must be written in pytest fashion. Use all the plugins. Tests and fixtures should go into tests.py, until such time the file become too big and unwieldy.

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-frontend thing automatically provided by Textual.

Configs for tools the bronsen does not currently use

Oh sure, I'll accept those. Please create a merge request that adds the file. I'll make an effort to update those to the best of my capabilities.

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:

    • just release {Release Name can be several words}