2015-07-02 19:50:48 +00:00
|
|
|
/*****************************************************************************
|
|
|
|
* Open MCT Web, Copyright (c) 2014-2015, United States Government
|
|
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
|
|
* Administration. All rights reserved.
|
|
|
|
*
|
|
|
|
* Open MCT Web is licensed under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*
|
|
|
|
* Open MCT Web includes source code licensed under additional open source
|
|
|
|
* licenses. See the Open Source Licenses file (LICENSES.md) included with
|
|
|
|
* this source code distribution or the Licensing information page available
|
|
|
|
* at runtime from the About dialog for additional information.
|
|
|
|
*****************************************************************************/
|
2015-09-22 18:14:55 +00:00
|
|
|
/*global define,describe,it,expect,beforeEach,jasmine*/
|
2015-07-02 19:50:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Module defining ContextMenuActionSpec. Created by shale on 07/02/2015.
|
|
|
|
*/
|
|
|
|
define(
|
|
|
|
["../../src/actions/ContextMenuAction", "../../src/gestures/GestureConstants"],
|
|
|
|
function (ContextMenuAction, GestureConstants) {
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
var JQLITE_FUNCTIONS = [ "on", "off", "find", "append", "remove" ],
|
|
|
|
DOMAIN_OBJECT_METHODS = [ "getId", "getModel", "getCapability", "hasCapability", "useCapability" ],
|
|
|
|
MENU_DIMENSIONS = GestureConstants.MCT_MENU_DIMENSIONS;
|
|
|
|
|
|
|
|
|
|
|
|
describe("The 'context menu' action", function () {
|
|
|
|
var mockCompile,
|
|
|
|
mockCompiledTemplate,
|
|
|
|
mockMenu,
|
|
|
|
mockDocument,
|
|
|
|
mockBody,
|
2015-10-02 21:14:34 +00:00
|
|
|
mockPopupService,
|
2015-07-02 19:50:48 +00:00
|
|
|
mockRootScope,
|
2015-08-04 17:11:25 +00:00
|
|
|
mockAgentService,
|
2015-07-02 19:50:48 +00:00
|
|
|
mockScope,
|
|
|
|
mockElement,
|
|
|
|
mockDomainObject,
|
|
|
|
mockEvent,
|
2015-10-02 21:14:34 +00:00
|
|
|
mockPopup,
|
2015-07-02 21:00:54 +00:00
|
|
|
mockActionContext,
|
|
|
|
action;
|
2015-07-02 19:50:48 +00:00
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
mockCompile = jasmine.createSpy("$compile");
|
|
|
|
mockCompiledTemplate = jasmine.createSpy("template");
|
|
|
|
mockMenu = jasmine.createSpyObj("menu", JQLITE_FUNCTIONS);
|
|
|
|
mockDocument = jasmine.createSpyObj("$document", JQLITE_FUNCTIONS);
|
|
|
|
mockBody = jasmine.createSpyObj("body", JQLITE_FUNCTIONS);
|
2015-10-02 21:14:34 +00:00
|
|
|
mockPopupService =
|
|
|
|
jasmine.createSpyObj("popupService", ["display"]);
|
|
|
|
mockPopup = jasmine.createSpyObj("popup", [
|
|
|
|
"dismiss",
|
|
|
|
"goesLeft",
|
|
|
|
"goesUp"
|
|
|
|
]);
|
2015-07-02 19:50:48 +00:00
|
|
|
mockRootScope = jasmine.createSpyObj("$rootScope", ["$new"]);
|
2015-08-04 17:11:25 +00:00
|
|
|
mockAgentService = jasmine.createSpyObj("agentService", ["isMobile"]);
|
2015-10-02 21:14:34 +00:00
|
|
|
mockScope = jasmine.createSpyObj("scope", ["$destroy"]);
|
2015-07-02 19:50:48 +00:00
|
|
|
mockElement = jasmine.createSpyObj("element", JQLITE_FUNCTIONS);
|
|
|
|
mockDomainObject = jasmine.createSpyObj("domainObject", DOMAIN_OBJECT_METHODS);
|
2015-07-29 22:06:39 +00:00
|
|
|
mockEvent = jasmine.createSpyObj("event", ["preventDefault", "stopPropagation"]);
|
2015-10-02 21:14:34 +00:00
|
|
|
mockEvent.pageX = 123;
|
|
|
|
mockEvent.pageY = 321;
|
2015-07-02 19:50:48 +00:00
|
|
|
|
|
|
|
mockCompile.andReturn(mockCompiledTemplate);
|
|
|
|
mockCompiledTemplate.andReturn(mockMenu);
|
|
|
|
mockDocument.find.andReturn(mockBody);
|
|
|
|
mockRootScope.$new.andReturn(mockScope);
|
2015-10-02 21:14:34 +00:00
|
|
|
mockPopupService.display.andReturn(mockPopup);
|
2015-08-07 21:39:59 +00:00
|
|
|
|
2015-07-02 21:00:54 +00:00
|
|
|
mockActionContext = {key: 'menu', domainObject: mockDomainObject, event: mockEvent};
|
2015-09-22 18:14:55 +00:00
|
|
|
|
2015-07-02 21:00:54 +00:00
|
|
|
action = new ContextMenuAction(
|
2015-07-02 19:50:48 +00:00
|
|
|
mockCompile,
|
|
|
|
mockDocument,
|
|
|
|
mockRootScope,
|
2015-10-02 21:14:34 +00:00
|
|
|
mockPopupService,
|
2015-08-04 17:11:25 +00:00
|
|
|
mockAgentService,
|
2015-07-02 21:00:54 +00:00
|
|
|
mockActionContext
|
2015-07-02 19:50:48 +00:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2015-10-02 21:14:34 +00:00
|
|
|
it("displays a popup when performed", function () {
|
2015-07-02 21:00:54 +00:00
|
|
|
action.perform();
|
2015-10-02 21:14:34 +00:00
|
|
|
expect(mockPopupService.display).toHaveBeenCalledWith(
|
|
|
|
mockMenu,
|
|
|
|
[ mockEvent.pageX, mockEvent.pageY ],
|
|
|
|
jasmine.any(Object)
|
|
|
|
);
|
2015-07-02 19:50:48 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it("prevents the default context menu behavior", function () {
|
2015-07-02 21:00:54 +00:00
|
|
|
action.perform();
|
2015-07-02 19:50:48 +00:00
|
|
|
expect(mockEvent.preventDefault).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
2015-10-02 21:14:34 +00:00
|
|
|
it("adds classes to menus based on position", function () {
|
|
|
|
var booleans = [ false, true ];
|
|
|
|
|
|
|
|
booleans.forEach(function (goLeft) {
|
|
|
|
booleans.forEach(function (goUp) {
|
|
|
|
mockPopup.goesLeft.andReturn(goLeft);
|
|
|
|
mockPopup.goesUp.andReturn(goUp);
|
|
|
|
action.perform();
|
|
|
|
expect(!!mockScope.menuClass['go-up'])
|
|
|
|
.toEqual(goUp);
|
|
|
|
expect(!!mockScope.menuClass['go-left'])
|
|
|
|
.toEqual(goLeft);
|
|
|
|
});
|
|
|
|
});
|
2015-07-02 19:50:48 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it("removes a menu when body is clicked", function () {
|
|
|
|
// Show the menu
|
2015-07-02 21:00:54 +00:00
|
|
|
action.perform();
|
2015-08-07 21:39:59 +00:00
|
|
|
|
2015-07-02 19:50:48 +00:00
|
|
|
// Verify precondition
|
2015-08-07 21:39:59 +00:00
|
|
|
expect(mockBody.remove).not.toHaveBeenCalled();
|
2015-07-02 19:50:48 +00:00
|
|
|
|
2015-07-02 21:00:54 +00:00
|
|
|
// Find and fire body's mousedown listener
|
2015-07-02 19:50:48 +00:00
|
|
|
mockBody.on.calls.forEach(function (call) {
|
2015-07-02 21:00:54 +00:00
|
|
|
if (call.args[0] === 'mousedown') {
|
2015-07-02 19:50:48 +00:00
|
|
|
call.args[1]();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// Menu should have been removed
|
2015-10-02 21:14:34 +00:00
|
|
|
expect(mockPopup.dismiss).toHaveBeenCalled();
|
2015-07-02 19:50:48 +00:00
|
|
|
|
|
|
|
// Listener should have been detached from body
|
2015-08-07 21:39:59 +00:00
|
|
|
expect(mockBody.off).toHaveBeenCalledWith(
|
|
|
|
'mousedown',
|
|
|
|
jasmine.any(Function)
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("removes a menu when it is clicked", function () {
|
|
|
|
// Show the menu
|
|
|
|
action.perform();
|
|
|
|
|
|
|
|
// Verify precondition
|
|
|
|
expect(mockMenu.remove).not.toHaveBeenCalled();
|
|
|
|
|
2015-10-02 21:14:34 +00:00
|
|
|
// Find and fire menu's click listener
|
2015-08-07 21:39:59 +00:00
|
|
|
mockMenu.on.calls.forEach(function (call) {
|
|
|
|
if (call.args[0] === 'click') {
|
|
|
|
call.args[1]();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// Menu should have been removed
|
2015-10-02 21:14:34 +00:00
|
|
|
expect(mockPopup.dismiss).toHaveBeenCalled();
|
2015-07-02 19:50:48 +00:00
|
|
|
});
|
2015-09-22 18:14:55 +00:00
|
|
|
|
2015-07-29 22:06:39 +00:00
|
|
|
it("keeps a menu when menu is clicked", function () {
|
|
|
|
// Show the menu
|
|
|
|
action.perform();
|
|
|
|
// Find and fire body's mousedown listener
|
2015-08-04 23:48:41 +00:00
|
|
|
mockMenu.on.calls.forEach(function (call) {
|
|
|
|
if (call.args[0] === 'mousedown') {
|
|
|
|
call.args[1](mockEvent);
|
|
|
|
}
|
|
|
|
});
|
2015-07-29 22:06:39 +00:00
|
|
|
|
|
|
|
// Menu should have been removed
|
2015-10-02 21:14:34 +00:00
|
|
|
expect(mockPopup.dismiss).not.toHaveBeenCalled();
|
2015-07-29 22:06:39 +00:00
|
|
|
|
|
|
|
// Listener should have been detached from body
|
|
|
|
expect(mockBody.off).not.toHaveBeenCalled();
|
|
|
|
});
|
2015-09-22 18:14:55 +00:00
|
|
|
|
2015-08-05 19:14:16 +00:00
|
|
|
it("keeps a menu when menu is clicked on mobile", function () {
|
2015-08-04 17:11:25 +00:00
|
|
|
mockAgentService.isMobile.andReturn(true);
|
2015-07-29 22:06:39 +00:00
|
|
|
action = new ContextMenuAction(
|
|
|
|
mockCompile,
|
|
|
|
mockDocument,
|
|
|
|
mockRootScope,
|
2015-10-02 21:14:34 +00:00
|
|
|
mockPopupService,
|
2015-08-04 17:11:25 +00:00
|
|
|
mockAgentService,
|
2015-07-29 22:06:39 +00:00
|
|
|
mockActionContext
|
|
|
|
);
|
|
|
|
action.perform();
|
2015-09-22 18:14:55 +00:00
|
|
|
|
2015-08-04 23:48:41 +00:00
|
|
|
mockMenu.on.calls.forEach(function (call) {
|
|
|
|
if (call.args[0] === 'touchstart') {
|
|
|
|
call.args[1](mockEvent);
|
|
|
|
}
|
|
|
|
});
|
2015-10-02 21:14:34 +00:00
|
|
|
|
|
|
|
expect(mockPopup.dismiss).not.toHaveBeenCalled();
|
2015-07-29 22:06:39 +00:00
|
|
|
});
|
2015-07-02 19:50:48 +00:00
|
|
|
});
|
|
|
|
}
|
2015-08-07 21:39:59 +00:00
|
|
|
);
|