Files
beads/docs/TESTING.md
Steve Yegge 25061ea9a7 chore: code health review - test fix and error comments (bd-9g1z, bd-ork0)
- Remove TestFindJSONLPathDefault from .test-skip (now passes)
- Add explanatory comments to 24 ignored error locations in cmd/bd:
  - Cobra flag methods (MarkHidden, MarkRequired, MarkDeprecated)
  - Best-effort cleanup/close operations
  - Process signaling operations

Part of code health review epic bd-tggf.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-22 21:30:57 -08:00

182 lines
4.0 KiB
Markdown

# Testing Guide
## Overview
The beads project has a comprehensive test suite with **~41,000 lines of code** across **205 files** in `cmd/bd` alone.
## Test Performance
- **Total test time:** ~3 minutes (excluding broken tests)
- **Package count:** 20+ packages with tests
- **Compilation overhead:** ~180 seconds (most of the total time)
- **Individual test time:** Only ~3.8 seconds combined for all 313 tests in cmd/bd
## Running Tests
### Quick Start
```bash
# Run all tests (auto-skips known broken tests)
make test
# Or directly:
./scripts/test.sh
# Run specific package
./scripts/test.sh ./cmd/bd/...
# Run specific test pattern
./scripts/test.sh -run TestCreate ./cmd/bd/...
# Verbose output
./scripts/test.sh -v
```
### Environment Variables
```bash
# Set custom timeout (default: 3m)
TEST_TIMEOUT=5m ./scripts/test.sh
# Enable verbose output
TEST_VERBOSE=1 ./scripts/test.sh
# Run specific pattern
TEST_RUN=TestCreate ./scripts/test.sh
```
### Advanced Usage
```bash
# Skip additional tests beyond .test-skip
./scripts/test.sh -skip SomeSlowTest
# Run with custom timeout
./scripts/test.sh -timeout 5m
# Combine flags
./scripts/test.sh -v -run TestCreate ./internal/beads/...
```
## Known Broken Tests
Tests in `.test-skip` are automatically skipped. Current broken tests:
1. **TestFallbackToDirectModeEnablesFlush** (GH #355)
- Location: `cmd/bd/direct_mode_test.go:14`
- Issue: Database deadlock, hangs for 5 minutes
- Impact: Makes test suite extremely slow
## For Claude Code / AI Agents
When running tests during development:
### Best Practices
1. **Use the test script:** Always use `./scripts/test.sh` instead of `go test` directly
- Automatically skips known broken tests
- Uses appropriate timeouts
- Consistent with CI/CD
2. **Target specific tests when possible:**
```bash
# Instead of running everything:
./scripts/test.sh
# Run just what you changed:
./scripts/test.sh -run TestSpecificFeature ./cmd/bd/...
```
3. **Compilation is the bottleneck:**
- The 180-second compilation time dominates
- Individual tests are fast
- Use `-run` to avoid recompiling unnecessarily
4. **Check for new failures:**
```bash
# If you see a new failure, check if it's known:
cat .test-skip
```
### Adding Tests to Skip List
If you discover a broken test:
1. File a GitHub issue documenting the problem
2. Add to `.test-skip`:
```bash
# Issue #NNN: Brief description
TestNameToSkip
```
3. Tests in `.test-skip` support regex patterns
## Test Organization
### Slowest Tests (>0.05s)
The top slow tests in cmd/bd:
- `TestDoctorWithBeadsDir` (1.68s) - Only significantly slow test
- `TestFlushManagerDebouncing` (0.21s)
- `TestDebouncer_*` tests (0.06-0.12s each) - Intentional sleeps for concurrency testing
- `TestMultiWorkspaceDeletionSync` (0.12s)
Most tests are <0.01s and very fast.
### Package Structure
```
cmd/bd/ - Main CLI tests (82 test files, most of the suite)
internal/beads/ - Core beads library tests
internal/storage/ - Storage backend tests (SQLite, memory)
internal/rpc/ - RPC protocol tests
internal/*/ - Various internal package tests
```
## Continuous Integration
The test script is designed to work seamlessly with CI/CD:
```yaml
# Example GitHub Actions
- name: Run tests
run: make test
```
## Debugging Test Failures
### Get detailed output
```bash
./scripts/test.sh -v ./path/to/package/...
```
### Run a single test
```bash
./scripts/test.sh -run '^TestExactName$' ./cmd/bd/...
```
### Check which tests are being skipped
```bash
./scripts/test.sh 2>&1 | head -5
```
Output shows:
```
Running: go test -timeout 3m -skip TestFoo|TestBar ./...
Skipping: TestFoo|TestBar
```
## Contributing
When adding new tests:
1. Keep tests fast (<0.1s if possible)
2. Use `t.Parallel()` for independent tests
3. Clean up resources in `t.Cleanup()` or `defer`
4. Avoid sleeps unless testing concurrency
When tests break:
1. Fix them if possible
2. If unfixable right now, file an issue and add to `.test-skip`
3. Document the issue in `.test-skip` with issue number