58 lines
1.7 KiB
Elixir
58 lines
1.7 KiB
Elixir
defmodule MIDIPlayerTest do
|
|
use ExUnit.Case
|
|
doctest MIDIPlayer
|
|
|
|
alias MIDIPlayer, as: Player
|
|
|
|
setup do
|
|
{:ok, _pid} = Player.start_link()
|
|
:ok
|
|
end
|
|
|
|
setup_all do
|
|
events = Enum.map(1..4, &MIDIPlayer.Event.Note.new(9, 51, &1 * 500, (&1 + 1) * 500, 127))
|
|
duration = 2000
|
|
[events: events, duration: duration]
|
|
end
|
|
|
|
test "play", %{events: events, duration: duration} do
|
|
assert :ok = Player.generate_schedule(events, duration)
|
|
assert :ok = Player.play()
|
|
Process.sleep(2500)
|
|
end
|
|
|
|
test "pause & resume", %{events: events, duration: duration} do
|
|
Player.generate_schedule(events, duration)
|
|
Player.play()
|
|
Process.sleep(1100)
|
|
assert :ok = Player.pause()
|
|
Process.sleep(500)
|
|
assert :ok = Player.resume()
|
|
Process.sleep(1400)
|
|
end
|
|
|
|
test "pause & resume edge cases", %{events: events, duration: duration} do
|
|
Player.generate_schedule(events, duration)
|
|
assert {:error, :not_started} = Player.pause()
|
|
assert {:error, :not_paused} = Player.resume()
|
|
Player.play()
|
|
Player.pause()
|
|
assert {:error, :already_paused} = Player.pause()
|
|
end
|
|
|
|
test "event conversion" do
|
|
event1 = MIDIPlayer.Event.ChangeProgram.new(0, 1, 40)
|
|
event2 = MIDIPlayer.Event.Note.new(0, 60, 1, 1000, 127)
|
|
events = [event1, event2]
|
|
duration = 100
|
|
assert :ok = Player.generate_schedule(events, duration)
|
|
|
|
change_program = MIDISynth.Command.change_program(0, 40)
|
|
note_on = MIDISynth.Command.note_on(0, 60, 127)
|
|
note_off = MIDISynth.Command.note_off(0, 60)
|
|
|
|
[command1, command2] = Player.get_schedule()
|
|
assert {1, <<^change_program::binary-size(2), ^note_on::binary-size(3)>>} = command1
|
|
assert {1000, ^note_off} = command2
|
|
end
|
|
end
|