require 'test_helper' module Vedeu class DummyRenderer def self.render(*output) :dummy end end class FooRenderer def self.render(*output) :foo end end describe Renderers do let(:described) { Vedeu::Renderers } let(:output) {} before { Vedeu.stubs(:log) Vedeu::Renderers.reset } after { Vedeu::Renderers.reset } describe '.renderers' do subject { described.renderers } it { subject.must_be_instance_of(Module) } context 'API' do before { Vedeu::Renderers.renderer(*renderers) } subject { Vedeu.renderers.render(output) } # @todo Add more tests. # context 'when a single renderer is defined' do # let(:renderers) { DummyRenderer } # it { subject.must_equal([:dummy]) } # end # @todo Add more tests. # context 'when multiple renderers are defined' do # let(:renderers) { [DummyRenderer, FooRenderer] } # it { subject.must_equal([:dummy, :foo]) } # end context 'when no renderers are defined' do let(:renderers) {} it { subject.must_equal(output) } end end end describe '.render' do let(:output) {} before do Vedeu.stubs(:focus).returns(:vedeu_renderers_render) Vedeu::Renderers.reset Vedeu::Renderers.renderer(DummyRenderer) Vedeu.stubs(:trigger).with(:_hide_cursor_) Vedeu.stubs(:trigger).with(:_show_cursor_) end subject { described.render(output) } context 'when an interface/view has been defined' do it do DummyRenderer.expects(:render).with(output) subject end context 'when there is content' do let(:output) { Vedeu::Cells::Escape .new(value: Vedeu::EscapeSequences::Esc.hide_cursor) } it 'hides the cursor before rendering the content to avoid cursor ' \ 'flicker' do Vedeu.expects(:trigger).with(:_hide_cursor_) subject end it 'shows the cursor after rendering the content' do Vedeu.expects(:trigger).with(:_show_cursor_) subject end it { subject.must_be_instance_of(Vedeu::Cells::Escape) } end context 'when there is no content' do it { subject.must_be_instance_of(NilClass) } end end end describe '.renderer' do let(:renderers) {} subject { described.renderer(*renderers) } it { subject.must_be_instance_of(Set) } context 'with a single renderer' do let(:renderers) { DummyRenderer } it { subject.size.must_equal(1) } end context 'with multiple renderers' do let(:renderers) { [DummyRenderer, FooRenderer] } it { subject.size.must_equal(2) } end context 'with no renderer' do let(:renderers) {} it { subject.size.must_equal(0) } end end describe '.reset!' do subject { described.reset! } it { described.must_respond_to(:reset) } it { subject.must_be_instance_of(Set) } it { subject.size.must_equal(0) } end end # Renderers end # Vedeu