|
|
/* Copyright 2016 LasLabs Inc. * License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl). */
odoo.define_section('web_responsive', ['web_responsive'], function(test) { "use strict"; // It provides a base drawer compatible interface for testing
self.initInterface = function(AppDrawer) { var $el = $('<div class="drawer drawer--left">'); $el.append( $('<header role="banner">') .append( $('<button class="drawer-toggle"><span class="drawer-hamburger-icon">') ) .append( $('<nav class="drawer-nav"><ul class="drawer-menu"><li class="drawer-menu-item">') ) .append( $('<div class="panel-title" id="appDrawerAppPanelHead">') ) ).append($('<main role="main">')); self.$clickZone = $('<a class="oe_menu_leaf">'); self.$secondaryMenu = $('<div><div class="oe_secondary_menus_container">'); self.$dropdown = $('<div class="dropdown-scrollable">'); $el.append(self.$clickZone) .append(self.$secondaryMenu) .append(self.$dropdown); var $document = $("#qunit-fixture"); $document.append($el); self.drawer = new AppDrawer.AppDrawer(); return $document; }; self.linkGrid = function() { for(var i=0; i < 3; i++){ self.drawer.$el.append( $('<div class="row">').append( $('<a class="col-md-6" id="a_' + i + '"><span class="app-drawer-icon-app /></a>' + '<a class="col-md-6" id="b_' + i + '"><span class="app-drawer-icon-app /></a>' ) ) ); self.drawer.$appLinks = $('a.col-md-6'); } }; test('It should set initialized after success init', function(assert, AppDrawer) { self.initInterface(AppDrawer); assert.ok(self.drawer.initialized); } ); test('It should close drawer after click on clickZone', {asserts: 1}, function(assert, AppDrawer) { self.initInterface(AppDrawer); self.$clickZone.click(); var d = $.Deferred(); setTimeout(function() { assert.ok(self.drawer.$el.hasClass('drawer-close')); d.resolve(); }, 100); return d; } ); test('It should collapse open secondary menus during handleClickZones', {asserts: 1}, function(assert, AppDrawer) { self.initInterface(AppDrawer); self.$clickZone.click(); var d = $.Deferred(); setTimeout(function() { assert.equal(self.$secondaryMenu.attr('aria-expanded'), 'false'); d.resolve(); }, 100); return d; } ); test('It should update max-height on scrollable dropdowns', function(assert, AppDrawer) { self.initInterface(AppDrawer); self.drawer.handleWindowResize(); var height = $(window).height() * self.drawer.dropdownHeightFactor; assert.equal( self.$dropdown.css('max-height'), height + 'px' ); } ); test('It should return keybuffer + new key', function(assert, AppDrawer) { self.initInterface(AppDrawer); self.drawer.keyBuffer = 'TES'; var res = self.drawer.handleKeyBuffer(84); assert.equal(res, 'TEST'); } ); test('It should clear keybuffer after timeout', {asserts: 1}, function(assert, AppDrawer) { self.initInterface(AppDrawer); self.drawer.keyBuffer = 'TES'; self.drawer.keyBufferTime = 10; self.drawer.handleKeyBuffer(84); var d = $.Deferred(); setTimeout(function() { assert.equal(self.drawer.keyBuffer, ""); d.resolve(); }, 100); return d; } ); test('It should trigger core bus event for drawer close', ['web.core'], {asserts: 1}, function(assert, AppDrawer, core) { self.initInterface(AppDrawer); self.drawer.onDrawerOpen(); var d = $.Deferred(); core.bus.on('drawer.closed', this, function() { assert.ok(true); d.resolve(); }); self.drawer.$el.trigger({type: 'drawer.closed'}); return d; } ); test('It should set isOpen to false when closing', {asserts: 1}, function(assert, AppDrawer) { self.initInterface(AppDrawer); self.drawer.onDrawerOpen(); var d = $.Deferred(); setTimeout(function() { assert.equal(self.drawer.isOpen, false); d.resolve(); }); self.drawer.$el.trigger({type: 'drawer.closed'}); return d; } ); test('It should set isOpen to true when opening', {asserts: 1}, function(assert, AppDrawer) { self.initInterface(AppDrawer); var d = $.Deferred(); self.drawer.$el.trigger({type: 'drawer.opened'}); setTimeout(function() { assert.ok(self.drawer.isOpen); d.resolve(); }); return d; } ); test('It should trigger core bus event for drawer open', ['web.core'], {asserts: 1}, function(assert, AppDrawer, core) { self.initInterface(AppDrawer); self.drawer.onDrawerOpen(); var d = $.Deferred(); core.bus.on('drawer.opened', this, function() { assert.ok(true); d.resolve(); }); self.drawer.$el.trigger({type: 'drawer.opened'}); return d; } ); test('It should choose link to right', function(assert, AppDrawer) { self.initInterface(AppDrawer); self.linkGrid(); var $appLink = $('#a_1'), $expect = $('#a_2'), $res = self.drawer.findAdjacentAppLink( $appLink, self.drawer.RIGHT ); assert.equal($res[0].id, $expect[0].id); } ); test('It should choose link to left', function(assert, AppDrawer) { self.initInterface(AppDrawer); self.linkGrid(); var $appLink = $('#a_2'), $expect = $('#a_1'), $res = self.drawer.findAdjacentAppLink( $appLink, self.drawer.LEFT ); assert.equal($res[0].id, $expect[0].id); } ); test('It should choose link above', function(assert, AppDrawer) { self.initInterface(AppDrawer); self.linkGrid(); var $appLink = $('#a_1'), $expect = $('#a_0'), $res = self.drawer.findAdjacentAppLink( $appLink, self.drawer.UP ); assert.equal($res[0].id, $expect[0].id); } ); test('It should choose link below', function(assert, AppDrawer) { self.initInterface(AppDrawer); self.linkGrid(); var $appLink = $('#a_1'), $expect = $('#a_2'), $res = self.drawer.findAdjacentAppLink( $appLink, self.drawer.DOWN ); assert.equal($res[0].id, $expect[0].id); } ); test('It should choose first link if next on last', function(assert, AppDrawer) { self.initInterface(AppDrawer); self.linkGrid(); var $appLink = $('#b_2'), $expect = $('#a_0'), $res = self.drawer.findAdjacentAppLink( $appLink, self.drawer.RIGHT ); assert.equal($res[0].id, $expect[0].id); } ); test('It should choose bottom link if up on top', function(assert, AppDrawer) { self.initInterface(AppDrawer); self.linkGrid(); var $appLink = $('#a_0'), $expect = $('#a_2'), $res = self.drawer.findAdjacentAppLink( $appLink, self.drawer.UP ); assert.equal($res[0].id, $expect[0].id); } ); test('It should choose top link if down on bottom', function(assert, AppDrawer) { self.initInterface(AppDrawer); self.linkGrid(); var $appLink = $('#a_2'), $expect = $('#a_0'), $res = self.drawer.findAdjacentAppLink( $appLink, self.drawer.DOWN ); assert.equal($res[0].id, $expect[0].id); } ); });
|