Einrichtung
Voraussetzungen: Python 3.11+, uv, Node.js 18+, pnpm.LLM_API_KEY ist nur erforderlich, um das Backend lokal auszuführen oder eine automatisch übersetzte Locale-Ausgabe bei Commit in der Vorschau anzuzeigen. Mitwirkende ohne einen Schlüssel können weiterhin EN-Änderungen committen — ein GitHub Actions-Workflow übersetzt nach dem PR-Merge auf master. Siehe i18n unten.Typsicherheit
mypy strict mode ist erzwungen. Die gesamte Codebasis besteht ohne Fehler, und der Pre-Commit-Hook führt mypy auf jeder gestaffelten.py-Datei mit vollständiger Import-Chain-Überprüfung aus.
Regeln:
- Typ-Hinweise erforderlich auf allen öffentlichen Funktionen.
- Kein
# type: ignoreaußer fürimport-untyped(Bibliotheken von Drittanbietern ohne Stubs). - Verwenden Sie
from __future__ import annotationsfür Forward References. - Beheben Sie die tatsächlichen Typen – unterdrücken Sie niemals Fehler, um CI zu bestehen.
Testen
Jedes neue Modul muss eine entsprechende Testdatei haben. Jeder Feature-Commit muss Tests enthalten.| Konvention | Muster |
|---|---|
| Datei | tests/test_{module}.py |
| Klasse | Test{Feature} |
| Methode | test_{behavior_under_test} |
- Alle vorhandenen Tests müssen vor dem Commit erfolgreich sein:
uv run pytest tests/ -x -q. - Tests dürfen nicht von externen Diensten abhängen — mocken Sie Datenbanken, MCP-Server, HTTP-Endpunkte und LLM-Aufrufe mit
unittest.mock/AsyncMock. - Führen Sie Tests mit Coverage aus:
uv run pytest --cov=fim_one.
Code-Stil
- Async-first. Verwenden Sie
async deffür I/O-gebundene Operationen. Wrappen Sie synchrone Aufrufe mitasyncio.to_thread()anstatt den Event Loop zu blockieren. - Ruff zum Linting.
uv run ruff check src/— Zeilenlänge beträgt 100 Zeichen. - Minimale
__init__.pyExporte. Exportieren Sie nur die öffentliche API; halten Sie interne Symbole privat. - Paketmanager.
uvfür Python,pnpmfür Frontend. Verwenden Sie niemalspipodernpm.
Git-Konventionen
Atomare Commits. Eine logische Änderung pro Commit. Teilen Sie unabhängige Änderungen auf, auch wenn sie zusammen entwickelt wurden. Commit-Nachrichtenformat:type: description
| Type | Wann zu verwenden |
|---|---|
feat | Neue benutzergerichtete Funktion |
fix | Fehlerbehebung |
refactor | Code-Umstrukturierung ohne Verhaltensänderung |
docs | Nur Dokumentation |
test | Tests hinzufügen oder aktualisieren |
chore | Build, CI, Abhängigkeitsaktualisierungen |
--no-verify. Die Pre-Commit-Pipeline existiert, um Fehler zu erkennen, bevor sie das Repository erreichen.
Pre-commit Hook-Pipeline
Der Hook wird bei jedem Commit automatisch ausgeführt. Er verarbeitet nur gestaffelte Dateien, die für jeden Schritt relevant sind – wenn Sie nur Python-Dateien geändert haben, wird der i18n-Schritt übersprungen und umgekehrt.| Reihenfolge | Schritt | Auslöser | Funktion |
|---|---|---|---|
| 0 | Locale-Edit-Schutz | Alle gestaffelten Dateien unter messages/{locale}/, docs/{locale}/ oder README.{locale}.md | Bricht den Commit ab – kein Override möglich. Beheben Sie Übersetzungen über scripts/translation-glossary.md. |
| 1 | OpenAPI-Spec-Regeneration | src/fim_one/web/**/*.py geändert | Exportiert docs/openapi.json neu aus FastAPI-Routen |
| 2 | i18n-Übersetzung | messages/en/*.json, docs/*.mdx oder README.md geändert (benötigt lokalen LLM_API_KEY, sonst wird es nach dem Merge von CI verarbeitet) | Übersetzt neue/geänderte Schlüssel in alle Zielsprachen |
| 3 | mypy-Typprüfung | Beliebige src/fim_one/**/*.py geändert | Führt mypy mit vollständiger Import-Kette auf gestaffelten Dateien aus |
| 4 | MDX-Validierung | Beliebige .mdx-Datei gestaffelt | Validiert JSX/MDX-Syntax, bevor sie Mintlify erreicht |
i18n
FIM One unterstützt 6 Sprachen (EN, ZH, JA, KO, DE, FR). Übersetzungen sind vollständig automatisiert. Bearbeiten Sie nur englische Quelldateien:frontend/messages/en/{namespace}.json— UI-Stringsdocs/*.mdx(Stammebene, nicht in Locale-Unterverzeichnissen) — DokumentationREADME.md— Projekt-Readme
messages/zh/, docs/zh/, README.zh.md usw.) werden automatisch generiert und der Pre-Commit-Hook lehnt Commits ab, die diese manuell bearbeiten. Um eine Fehlübersetzung zu beheben, bearbeiten Sie scripts/translation-glossary.md — die in jeden Übersetzungs-Prompt injizierte Single Source of Truth für jede Übersetzungsregel — und generieren Sie dann betroffene Dateien mit uv run scripts/translate.py --files <en-sources> --force neu. Jede Glossar-Korrektur gilt dauerhaft für alle fünf Sprachen.
Zwei Wege zur Generierung von Locale-Dateien:
- Lokaler Pre-Commit-Hook — wird ausgeführt, wenn
LLM_API_KEYin.envgesetzt ist. Die Übersetzung erfolgt vor dem Push, sodass Sie die Ausgabe in der Vorschau anzeigen können. - CI-Fallback — wenn der lokale Hook keinen Schlüssel hatte und übersprungen wurde, übersetzt
.github/workflows/i18n-sync.ymlnach dem Merge aufmasterund committed das Ergebnis automatisch.
messages/en/{ns}.json — andere Locale-Dateien werden beim nächsten Commit oder nach dem Merge auf CI generiert.
Vollständige Neuübersetzung erzwingen: uv run scripts/translate.py --all (erfordert lokalen LLM_API_KEY).
Datenbankmigrationen
Dev verwendet SQLite, Produktion verwendet PostgreSQL. Ein Satz von Alembic-Migrationsdateien muss auf beiden funktionieren. Wichtige Regeln:- Jedes neue ORM-Modell oder jede neue Spalte muss eine Migration haben — verlassen Sie sich niemals auf
metadata.create_all(). - Alle Migrationen müssen idempotent sein — verwenden Sie Hilfsfunktionen aus
fim_one.migrations.helpers(table_exists,table_has_column,index_exists). - Boolean-Standardwerte:
server_default=sa.text("FALSE")/sa.text("TRUE"). Niemals"0"/"1"— PostgreSQL lehnt Integer-Literale für Boolean-Spalten ab. - SQLite kann
ALTER COLUMNnicht ausführen — verwenden Sieop.batch_alter_table()für Änderungen an Spaltenbeschränkungen. - Nach dem Schreiben einer Migration führen Sie sofort
uv run alembic upgrade headaus, um sie anzuwenden.