2013-12-23 00:06:02 +01:00
|
|
|
using Base.Test
|
2014-01-03 16:41:00 +01:00
|
|
|
using AudioIO
|
2013-12-23 00:06:02 +01:00
|
|
|
|
2014-01-03 16:41:00 +01:00
|
|
|
test_info = AudioIO.DeviceInfo(44100, 512)
|
|
|
|
dev_input = zeros(AudioIO.AudioSample, test_info.buf_size)
|
2013-12-23 00:06:02 +01:00
|
|
|
|
|
|
|
# A TestNode just renders out 1:buf_size each frame
|
2014-01-03 16:41:00 +01:00
|
|
|
type TestNode <: AudioIO.AudioNode
|
2013-12-23 00:06:02 +01:00
|
|
|
end
|
|
|
|
|
2014-01-03 16:41:00 +01:00
|
|
|
function AudioIO.render(node::TestNode,
|
|
|
|
device_input::AudioIO.AudioBuf,
|
|
|
|
info::AudioIO.DeviceInfo)
|
|
|
|
return AudioIO.AudioSample[1:info.buf_size]
|
2013-12-23 00:06:02 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
#### AudioMixer Tests ####
|
|
|
|
|
|
|
|
# TODO: there should be a setup/teardown mechanism and some way to isolate
|
|
|
|
# tests
|
|
|
|
|
2013-12-30 10:31:54 +01:00
|
|
|
info("Testing AudioMixer...")
|
2013-12-23 00:06:02 +01:00
|
|
|
mix = AudioMixer()
|
2014-01-03 16:41:00 +01:00
|
|
|
@test mix.mix_inputs == AudioIO.AudioNode[]
|
|
|
|
@test AudioIO.render(mix, dev_input, test_info) == zeros(AudioIO.AudioSample, test_info.buf_size)
|
2013-12-23 00:06:02 +01:00
|
|
|
|
|
|
|
testnode = TestNode()
|
|
|
|
mix = AudioMixer([testnode])
|
2014-01-03 16:41:00 +01:00
|
|
|
@test mix.mix_inputs == AudioIO.AudioNode[testnode]
|
|
|
|
@test AudioIO.render(mix, dev_input, test_info) == AudioIO.AudioSample[1:test_info.buf_size]
|
2013-12-23 00:06:02 +01:00
|
|
|
|
|
|
|
test1 = TestNode()
|
|
|
|
test2 = TestNode()
|
|
|
|
mix = AudioMixer([test1, test2])
|
2014-01-03 16:41:00 +01:00
|
|
|
@test AudioIO.render(mix, dev_input, test_info) == 2 * AudioIO.AudioSample[1:test_info.buf_size]
|
2013-12-23 00:06:02 +01:00
|
|
|
|
2013-12-30 12:29:43 +01:00
|
|
|
info("Testing SinOSC...")
|
|
|
|
freq = 440
|
|
|
|
t = linspace(1 / test_info.sample_rate,
|
|
|
|
test_info.buf_size / test_info.sample_rate,
|
|
|
|
test_info.buf_size)
|
2014-01-03 16:41:00 +01:00
|
|
|
test_vect = convert(AudioIO.AudioBuf, sin(2pi * t * freq))
|
2013-12-30 12:29:43 +01:00
|
|
|
osc = SinOsc(freq)
|
2014-01-03 16:41:00 +01:00
|
|
|
rendered = AudioIO.render(osc, dev_input, test_info)
|
2013-12-30 12:29:43 +01:00
|
|
|
@test_approx_eq(rendered, test_vect)
|