Files
beads/docs/TESTING.md
Steve Yegge 0040e8029b feat: Add test infrastructure with automatic skip list
Overview: Added comprehensive test infrastructure to handle the large
test suite (41K LOC, 313 tests in cmd/bd alone) with automatic skipping
of known broken tests.

Changes:
- .test-skip: List of broken tests to skip (with GH issue references)
- scripts/test.sh: Smart test runner that auto-skips broken tests
- docs/TESTING.md: Comprehensive testing guide
- .claude/test-strategy.md: Quick reference for AI agents
- Updated Makefile to use new test script

Known Issues Filed:
- GH #355: TestFallbackToDirectModeEnablesFlush (database deadlock)
- GH #356: TestFindJSONLPathDefault (wrong JSONL filename)

Performance: 3min total (180s compilation, 3.8s execution)

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-21 22:43:04 -05:00

187 lines
4.2 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
2. **TestFindJSONLPathDefault** (GH #356)
- Location: `internal/beads/beads_test.go:175`
- Issue: Expects `issues.jsonl` but code returns `beads.jsonl`
- Impact: Assertion failure
## 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