require 'spec_helper' describe Locomotive::SettingsMenuCell do # FIXME: This does not seem to work correctly, rspec-cells should allow this to be called # as if it were a controller. # render_views let(:menu) { render_cell('admin/settings_menu', :show) } describe 'show menu' do before(:each) do CellsResetter.new_settings_menu_cell_klass({ :main => 'settings', :sub => 'site' }) end it 'has 3 items' do menu.should have_selector('li', :count => 3) end it 'has a link to edit the current site' do menu.should have_link('Site') end it 'has a link to edit the template files' do menu.should have_link('Theme files') end it 'has a link to edit my account' do menu.should have_link('My account') end end describe 'add a new menu item' do before(:each) do CellsResetter.new_settings_menu_cell_klass({ :main => 'settings', :sub => 'site' }) Admin::SettingsMenuCell.update_for(:testing_add) { |m| m.add(:my_link, :label => 'My link', :url => 'http://www.locomotivecms.com') } end it 'has 4 items' do menu.should have_selector('li', :count => 4) end it 'has a new link' do menu.should have_link('My link') end end describe 'remove a new menu item' do before(:each) do CellsResetter.new_settings_menu_cell_klass({ :main => 'settings', :sub => 'site' }) Admin::SettingsMenuCell.update_for(:testing_remove) { |m| m.remove(:theme_assets) } end it 'has 2 items' do menu.should have_selector('li', :count => 2) end it 'does not have the link to edit the template files' do menu.should_not have_link('Theme files') end end describe 'modify an existing menu item' do before(:each) do CellsResetter.new_settings_menu_cell_klass({ :main => 'settings', :sub => 'site' }) Admin::SettingsMenuCell.update_for(:testing_update) { |m| m.modify(:theme_assets, { :label => 'Modified !' }) } end it 'still has 3 items' do menu.should have_selector('li', :count => 3) end it 'has a modified menu item' do menu.should_not have_link('Theme files') menu.should have_link('Modified !') end end after(:all) do CellsResetter.clean! end end