summaryrefslogtreecommitdiff
path: root/src/tests/test_tracker.cc
blob: 9285728547ac2168972ab19e2cd438bd64478851 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
// This file is part of the 64k demo project.
// It tests the core functionality of the audio tracker engine.

#include "audio/gen.h"
#include "audio/synth.h"
#include "audio/tracker.h"
// #include "generated/music_data.h" // Will be generated by tracker_compiler
#include <assert.h>
#include <stdio.h>

// Forward declaration for generated data
extern const NoteParams g_tracker_samples[];
extern const uint32_t g_tracker_samples_count;
extern const TrackerPattern g_tracker_patterns[];
extern const uint32_t g_tracker_patterns_count;
extern const TrackerScore g_tracker_score;

void test_tracker_init() {
  synth_init();
  tracker_init();
  printf("Tracker init test PASSED\n");
}

void test_tracker_pattern_triggering() {
  synth_init();
  tracker_init();

  // At time 0.0f, 3 patterns are triggered:
  // - crash (1 event at beat 0.0)
  // - kick_basic (events at beat 0.0, 2.0, 2.5)
  // - hihat_basic (events at beat 0.0, 0.5, 1.0, 1.5, 2.0, 2.5, 3.0, 3.5)
  // With event-based triggering, only events at beat 0.0 trigger immediately.

  // Test 1: At music_time = 0.0f, events at beat 0.0 trigger
  tracker_update(0.0f);
  // Expect 3 voices: crash (beat 0.0), kick (beat 0.0), hihat (beat 0.0)
  assert(synth_get_active_voice_count() == 3);

  // Test 2: At music_time = 0.25f (beat 0.5 @ 120 BPM), hihat event triggers
  // beat_duration = 60.0f / 120.0f = 0.5s per beat
  // beat 0.5 = 0.25s
  tracker_update(0.25f);
  // Expect 4 voices (3 previous + 1 hihat at beat 0.5)
  assert(synth_get_active_voice_count() == 4);

  // Test 3: At music_time = 0.5f (beat 1.0), hihat event triggers
  tracker_update(0.5f);
  // Expect 5 voices (4 previous + 1 hihat at beat 1.0)
  assert(synth_get_active_voice_count() == 5);

  // Test 4: Advance to 2.0f - new patterns trigger at time 2.0f
  tracker_update(2.0f);
  // Many events have triggered by now
  assert(synth_get_active_voice_count() > 5);

  printf("Tracker pattern triggering test PASSED\n");
}

int main() {
  printf("Running Tracker tests...\n");
  test_tracker_init();
  test_tracker_pattern_triggering();
  printf("Tracker tests PASSED\n");
  return 0;
}