require 'test_helper' module Vedeu module DSL describe Interface do let(:described) { Vedeu::DSL::Interface } let(:instance) { described.new(model) } let(:model) { Vedeu.interface 'actinium' do # ... end } let(:client) {} before { Vedeu.interfaces.reset } describe '#initialize' do subject { instance } it { subject.must_be_instance_of(Vedeu::DSL::Interface) } it { subject.instance_variable_get('@model').must_equal(model) } it { subject.instance_variable_get('@client').must_equal(client) } end describe '#border' do subject { instance.border do # ... end } it { subject.must_be_instance_of(Vedeu::Border) } context 'when the block is not given' do subject { instance.border } it { proc { subject }.must_raise(InvalidSyntax) } end end # describe '#define' do # interface = Interface.new({ name: 'widget' }) # it 'creates and stores a new interface' do # interface.define.must_be_instance_of(API::Interface) # end # it 'allows the setting of colours' do # Interface.build do # colour foreground: '#aadd00', background: '#222222' # end.must_equal( # { # border: {}, # colour: { # foreground: '#aadd00', # background: '#222222' # }, # cursor: :hide, # delay: 0.0, # geometry: {}, # group: '', # lines: [], # name: '', # parent: nil, # style: '', # } # ) # end # it 'allows the setting of styles' do # Interface.build do # style 'underline' # end.must_equal( # { # border: {}, # colour: {}, # cursor: :hide, # delay: 0.0, # geometry: {}, # group: '', # lines: [], # name: '', # parent: nil, # style: "underline", # } # ) # end # it 'allows the use of other interfaces for attributes like geometry' do # IO.console.stub(:winsize, [25, 40]) do # interface = Vedeu.interface 'my_interface' do # geometry do # x 5 # y 5 # width 5 # height 5 # end # end # Interface.build do # name 'my_other_interface' # y use('my_interface').south # end.must_equal({ # border: {}, # colour: {}, # cursor: :hide, # delay: 0.0, # geometry: { # y: 11 # }, # group: '', # lines: [], # name: "my_other_interface", # parent: nil, # style: '', # }) # end # end # it 'allows the setting of a delay for events triggered for this ' \ # 'interface' do # Interface.build do # delay 1.0 # end.must_equal( # { # border: {}, # colour: {}, # cursor: :hide, # delay: 1.0, # geometry: {}, # group: '', # lines: [], # name: '', # parent: nil, # style: '', # }) # end # it 'allows the interface to be part of a group- useful for creating ' \ # 'separate views' do # Interface.build do # group 'my_group' # end.must_equal( # { # border: {}, # colour: {}, # cursor: :hide, # delay: 0.0, # geometry: {}, # group: "my_group", # lines: [], # name: '', # parent: nil, # style: '', # } # ) # end # end # describe '#centred' do # it 'returns false if the value is false or nil' do # DSL::Interface.new.centred(false).must_equal(false) # end # it 'returns true' do # DSL::Interface.new.centred.must_equal(true) # end # end describe '#cursor' do let(:value) {} before { Vedeu.cursors.reset } subject { instance.cursor(value) } it { subject Vedeu.cursors.find('actinium').state.visible?.must_equal(false) } context 'when the value is false' do let(:value) { false } it { subject Vedeu.cursors.find('actinium').state.visible?.must_equal(false) } end context 'when the value is :hide' do let(:value) { :hide } it { subject Vedeu.cursors.find('actinium').state.visible?.must_equal(false) } end context 'when the value is :show' do let(:value) { :show } it { subject Vedeu.cursors.find('actinium').state.visible?.must_equal(true) } end context 'when the value is true' do let(:value) { true } it { subject Vedeu.cursors.find('actinium').state.visible?.must_equal(true) } end context 'when the value is :yes' do let(:value) { :yes } it { subject Vedeu.cursors.find('actinium').state.visible?.must_equal(true) } end end describe '#cursor!' do subject { instance.cursor! } it { subject Vedeu.cursors.find('actinium').state.visible?.must_equal(true) } end describe '#delay' do it 'sets the delay attribute' do Vedeu.interface 'cobalt' do delay 0.25 end Vedeu.use('cobalt').delay.must_equal(0.25) end end describe '#focus!' do context 'when a single call is made' do before do Vedeu::Focus.reset Vedeu.interface('curium') { focus! } end it 'sets the interface as current' do Vedeu.focus.must_equal('curium') end end # context 'when multiple calls are made' do # before do # Vedeu::Focus.reset # Vedeu.interface('curium') { focus! } # Vedeu.interface('iodine') {} # Vedeu.interface('dysprosium') { focus! } # end # it 'the last call will set that interface to be current' do # Vedeu.focus.must_equal('dysprosium') # end # end context 'when no calls are made' do before do Vedeu::Focus.reset Vedeu.interface('curium') {} Vedeu.interface('dysprosium') {} end it 'the first interface defined will be current' do Vedeu.focus.must_equal('curium') end end end describe '#geometry' do subject { instance.geometry do # ... end } it { subject.must_be_instance_of(Vedeu::Geometry) } context 'when the require block is not provided' do subject { instance.geometry } it { proc { subject }.must_raise(InvalidSyntax) } end end describe '#group' do let(:value) { 'elements' } subject { instance.group(value) } it { subject.must_be_instance_of(String) } context 'when the value is empty or nil' do let(:value) { '' } it { subject.must_equal(false) } end end describe '#keys' do subject { instance.keys do # ... end } it { subject.must_be_instance_of(Vedeu::Keymap) } context 'when the required block is not provided' do subject { instance.keys } it { proc { subject }.must_raise(InvalidSyntax) } end # before do # Keymaps.reset # Vedeu.interface 'iron' do # keys do # key('k') { :k_pressed } # end # end # end # it 'defines a keymap for the interface' do # Keymaps.interface_key?('k').must_equal(true) # end # it 'defines a keymap for the interface' do # Keymaps.interface_keys('iron').must_equal(['k']) # end # context 'when the block is not given' do # it { proc { Vedeu.interface('iron') { keys } }.must_raise(InvalidSyntax) } # end end describe '#lines' do subject { instance.lines do # ... end } it { subject.must_be_instance_of(Vedeu::Lines) } context 'when the required block is not provided' do subject { instance.lines } it { proc { subject }.must_raise(InvalidSyntax) } end # it 'adds a blank line with no arguments' do # interface = Vedeu.interface 'carbon' do # line # end # interface.must_be_instance_of(API::Interface) # interface.attributes.must_equal( # { # border: {}, # colour: {}, # cursor: :hide, # delay: 0.0, # geometry: {}, # group: '', # lines: [ # { # colour: {}, # streams: { # text: '' # }, # style: [], # } # ], # name: 'carbon', # parent: nil, # style: '', # } # ) # end # it 'adds a line directly with a value and no block' do # interface = Vedeu.interface 'carbon' do # line 'This is some text...' # end # interface.must_be_instance_of(API::Interface) # interface.attributes.must_equal( # { # border: {}, # colour: {}, # cursor: :hide, # delay: 0.0, # geometry: {}, # group: '', # lines: [ # { # colour: {}, # parent: composition, # streams: { # text: "This is some text..." # }, # style: [], # } # ], # name: 'carbon', # parent: nil, # style: '', # } # ) # end # it 'allows the addition of more attributes with a block' do # interface = Vedeu.interface 'silicon' do # lines do # text 'This is different text...' # end # end # interface.must_be_instance_of(API::Interface) # interface.attributes.must_equal( # { # border: {}, # colour: {}, # cursor: :hide, # delay: 0.0, # geometry: {}, # group: '', # lines: [ # { # colour: {}, # parent: composition, # streams: [ # { # text: "This is different text..." # } # ], # style: [], # } # ], # name: "silicon", # parent: nil, # style: '', # } # ) # end end describe '#name' do it 'sets the name attribute' do Vedeu.interface do name 'nickel' end Vedeu.use('nickel').name.must_equal('nickel') end end end # Interface end # DSL end # Vedeu