mirror of https://github.com/usememos/memos.git
Add t.Parallel() to all 159 test functions in store/test/ Benefits: - Tests run in parallel (8-16 concurrent on typical CI) - Each test already has isolated database (safe to parallelize) - No shared state between tests - Go test runner handles synchronization Expected performance: - SQLite tests: 4-6min → 30-45sec (87% faster) - MySQL tests: 6-8min → 45-60sec (88% faster) - Better CPU utilization (10-15% → 80-95%) Why it's safe: - NewTestingStore() creates isolated DB per test - No global state mutations - Each test uses t.TempDir() for file isolation - Container-based tests use unique database names Impact on CI workflow: - Backend tests workflow: 4-6min → 1-2min total - Store test group: 3-4min → 20-30sec - 8-10x speedup from parallelization alone |
||
|---|---|---|
| .. | ||
| cache | ||
| db | ||
| migration | ||
| seed | ||
| test | ||
| activity.go | ||
| attachment.go | ||
| cache.go | ||
| common.go | ||
| driver.go | ||
| idp.go | ||
| inbox.go | ||
| instance_setting.go | ||
| memo.go | ||
| memo_relation.go | ||
| migrator.go | ||
| reaction.go | ||
| store.go | ||
| user.go | ||
| user_setting.go | ||