Files
TinyTorch/tests
Vijay Janapa Reddi 1517c6f83d Clean up repository by removing planning and status documents
Removed 42 planning, brainstorming, and status tracking documents that served their purpose during development but are no longer needed for release.

Changes:
- Root: Removed 4 temporary/status files
- binder/: Removed 20 planning documents (kept essential setup files)
- docs/: Removed 16 planning/status documents (preserved all user-facing docs and website dependencies)
- tests/: Removed 2 status documents (preserved all test docs and milestone system)

Preserved files:
- All user-facing documentation (README, guides, quickstarts)
- All website dependencies (INSTRUCTOR_GUIDE, PRIVACY_DATA_RETENTION, TEAM_ONBOARDING)
- All functional configuration files
- All milestone system documentation (7 files in tests/milestones/)

Updated .gitignore to prevent future accumulation of internal development files (.claude/, site/_build/, log files, progress.json)
2025-11-22 21:05:57 -05:00
..
2025-11-22 20:30:58 -05:00

TinyTorch Test Suite

Comprehensive testing organized by purpose and scope.

Test Organization

📦 Module Tests (XX_modulename/)

Purpose: Test individual module functionality
Scope: Single module, isolated behavior
Example: 01_tensor/test_progressive_integration.py

These tests validate that each module works correctly in isolation.

🔗 Integration Tests (integration/)

Purpose: Test cross-module interactions
Scope: Multiple modules working together
Files:

  • test_gradient_flow.py - CRITICAL: Validates gradients flow through entire training stack
  • test_end_to_end_training.py - Full training loops (TODO)
  • test_module_compatibility.py - Module interfaces (TODO)

Why this matters:

  • Catches bugs that unit tests miss
  • Validates the "seams" between modules
  • Ensures training actually works end-to-end

🐛 Debugging Tests (debugging/)

Purpose: Catch common student pitfalls
Scope: Pedagogical - teaches debugging
Files:

  • test_gradient_vanishing.py - Detect/diagnose vanishing gradients (TODO)
  • test_gradient_explosion.py - Detect/diagnose exploding gradients (TODO)
  • test_common_mistakes.py - "Did you forget backward()?" style tests (TODO)

Philosophy: When these tests fail, the error message should teach the student what went wrong and how to fix it.

Autograd Edge Cases (05_autograd/)

Purpose: Stress-test autograd system
Scope: Autograd internals and edge cases
Files:

  • test_broadcasting.py - Broadcasting gradient bugs (TODO)
  • test_computation_graph.py - Graph construction edge cases (TODO)
  • test_backward_edge_cases.py - Numerical stability, etc. (TODO)

Running Tests

All tests

pytest tests/ -v
pytest tests/integration/ -v

Specific test

pytest tests/integration/test_gradient_flow.py -v

Run without pytest

python tests/integration/test_gradient_flow.py

Test Philosophy

  1. Integration tests catch real bugs: The gradient flow test caught the exact bugs that prevented training
  2. Descriptive names: Test names should explain what they test
  3. Good error messages: When tests fail, students should understand why
  4. Pedagogical value: Tests teach correct usage patterns

Adding New Tests

When adding a test, ask:

  • Is it testing one module? → Put in XX_modulename/
  • Is it testing modules working together? → Put in integration/
  • Is it teaching debugging? → Put in debugging/
  • Is it an autograd edge case? → Put in 05_autograd/

Most Important Tests

🔥 Must pass before merging:

  • integration/test_gradient_flow.py - If this fails, training is broken

📚 Module validation:

  • Each module's inline tests (in modules/)
  • Module-specific tests in tests/XX_modulename/

Test Coverage Goals

  • All tensor operations have gradient tests
  • All layers compute gradients correctly
  • All activations integrate with autograd
  • All loss functions compute gradients
  • All optimizers update parameters
  • End-to-end training converges (TODO)
  • Common pitfalls are detected (TODO)