waterfoul/spec/interrupt_spec.rb

54 lines
1.5 KiB
Ruby
Raw Normal View History

2016-05-08 09:20:05 +02:00
require 'spec_helper'
describe Waterfoul::Interrupt do
before :each do
2016-07-21 10:08:54 +02:00
$mmu = Waterfoul::MMU.new
2016-05-08 09:20:05 +02:00
end
subject { described_class }
describe '.request_interupt' do
context 'with INTERRUPT_VBLANK interrupt' do
2016-07-21 10:08:54 +02:00
it 'sets bit for VBLANK interupt in IF register' do
subject.request_interrupt Waterfoul::Interrupt::INTERRUPT_JOYPAD
expect($mmu[0xFF0F]).to eq 0x10
end
end
context 'with INTERRUPT_TIMER set' do
it 'sets bit for timer interrupt in IF register' do
subject.request_interrupt Waterfoul::Interrupt::INTERRUPT_TIMER
expect($mmu[0xFF0F]).to eq 0x4
2016-05-08 09:20:05 +02:00
end
end
end
2016-07-21 10:08:54 +02:00
describe '.pending_interrupt' do
context 'when bit 2 of IE and IF register is set' do
before { $mmu[0xFF0F] = 0x4 }
before { $mmu[0xFFFF] = 0x4 }
it 'marks timer interrupt as pending' do
expect(subject.pending_interrupt).to eq Waterfoul::Interrupt::INTERRUPT_TIMER
end
end
context 'when bit 2 of IE register is 0' do
before { $mmu[0xFF0F] = 0x4 }
before { $mmu[0xFFFF] = 0x0 }
it 'responds with no interrupts pending' do
expect(subject.pending_interrupt).to eq Waterfoul::Interrupt::INTERRUPT_NONE
2016-05-08 09:20:05 +02:00
end
end
2016-07-21 10:08:54 +02:00
context 'when 2 interrupts are pending' do
before { $mmu[0xFF0F] = 0x3 }
before { $mmu[0xFFFF] = 0xFF }
it 'responds with higher priority interrupt' do
expect(subject.pending_interrupt).to eq Waterfoul::Interrupt::INTERRUPT_VBLANK
2016-05-08 09:20:05 +02:00
end
end
end
end