mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
85 lines
4.3 KiB
JavaScript
85 lines
4.3 KiB
JavaScript
(function($) {
|
|
var $browser, $breadcrumbs, $browserContainer;
|
|
|
|
module('Browser', {
|
|
setup: function() {
|
|
$.fx.off = true;
|
|
$browser = $('<div>').addClass('browser-test').appendTo('#qunit-fixture');
|
|
$breadcrumbs = $('<div>').attr('id', 'breadcrumbs').appendTo($browser);
|
|
$browserContainer = $('<div>').addClass('container').appendTo($browser);
|
|
ok($browserContainer.cloudBrowser(), 'Browser initialized');
|
|
equal($breadcrumbs.find('ul').size(), 1, 'Breadcrumbs initialized');
|
|
}
|
|
});
|
|
|
|
// Browser tests
|
|
test('Add panel', function() {
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel123' }), 'Add panel');
|
|
equal($browser.find('.panel').size(), 1, 'Browser has 1 panel');
|
|
equal($breadcrumbs.find('ul li').size(), 1, 'Browser has 1 breadcrumb');
|
|
equal($breadcrumbs.find('ul li:first span').html(), 'testPanel123', 'Panel has correct title');
|
|
});
|
|
|
|
test('Add a second panel', function() {
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel123' }), 'Add first panel');
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel456' }), 'Add second panel');
|
|
equal($browser.find('.panel').size(), 2, 'Browser has 2 panels');
|
|
equal($breadcrumbs.find('ul li').size(), 2, 'Browser has 2 breadcrumbs');
|
|
equal($breadcrumbs.find('ul li:last span').html(), 'testPanel456', 'New panel has correct title');
|
|
equal($breadcrumbs.find('ul li:first span').html(), 'testPanel123', 'First panel still has correct title');
|
|
});
|
|
|
|
test('Select panel', function() {
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel123' }), 'Add first panel');
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel456' }), 'Add second panel');
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel789' }), 'Add third panel');
|
|
|
|
stop();
|
|
$browserContainer.cloudBrowser('selectPanel', {
|
|
panel: $browser.find('.panel:first').next(),
|
|
complete: function() {
|
|
start();
|
|
ok(true, 'Select second panel');
|
|
}
|
|
});
|
|
|
|
equal($browser.find('.panel').size(), 2, 'Browser has 2 panels');
|
|
equal($breadcrumbs.find('ul li:first span').html(), 'testPanel123', 'First panel still has correct title');
|
|
equal($breadcrumbs.find('ul li:last span').html(), 'testPanel456', 'Second panel still has correct title');
|
|
equal($breadcrumbs.find('ul li').size(), 2, 'Browser has 2 breadcrumbs');
|
|
|
|
stop();
|
|
$browserContainer.cloudBrowser('selectPanel', {
|
|
panel: $browser.find('.panel:first'),
|
|
complete: function() {
|
|
start();
|
|
ok(true, 'Select first panel');
|
|
}
|
|
});
|
|
|
|
equal($browser.find('.panel').size(), 1, 'Browser has 1 panel');
|
|
equal($breadcrumbs.find('ul li:first span').html(), 'testPanel123', 'First panel still has correct title');
|
|
equal($breadcrumbs.find('ul li').size(), 1, 'Browser has 1 breadcrumb');
|
|
});
|
|
|
|
test('Remove all panels', function() {
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel123' }), 'Add first panel');
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel456' }), 'Add second panel');
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel789' }), 'Add third panel');
|
|
equal($browserContainer.find('.panel').size(), 3, 'Correct # of panels');
|
|
ok($browserContainer.cloudBrowser('removeAllPanels'), 'Remove all panels');
|
|
equal($browserContainer.find('.panel').size(), 0, 'All panels removed');
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel123' }), 'Add 1 panel');
|
|
equal($browserContainer.find('.panel').size(), 1, 'Correct # of panels');
|
|
});
|
|
|
|
test('Maximize panel', function() {
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel123' }), 'Add first panel');
|
|
ok($browserContainer.cloudBrowser('addPanel', { title: 'testPanel456' }), 'Add second panel');
|
|
equal($browserContainer.find('.panel').size(), 2, 'Correct # of panels');
|
|
ok($browserContainer.cloudBrowser('toggleMaximizePanel', { panel: $browserContainer.find('.panel:first')}), 'Maximize first panel');
|
|
ok($browserContainer.find('.panel:first').hasClass('maximized'), 'First panel has maximized style');
|
|
ok(!$browserContainer.find('.panel:last').hasClass('maximized'), 'Last panel has correct style');
|
|
});
|
|
}(jQuery));
|