mirror of
https://github.com/nasa/openmct.git
synced 2024-12-24 23:36:41 +00:00
0b635afcf7
ContextMenu and InfoButton Gesture tests remain.
147 lines
6.4 KiB
JavaScript
147 lines
6.4 KiB
JavaScript
/*****************************************************************************
|
|
* 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.
|
|
*****************************************************************************/
|
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
|
|
|
define(
|
|
['../../src/services/InfoService', '../../src/InfoConstants'],
|
|
function (InfoService, InfoConstants) {
|
|
"use strict";
|
|
|
|
describe("The info service", function () {
|
|
var mockCompile,
|
|
mockDocument,
|
|
testWindow,
|
|
mockRootScope,
|
|
mockAgentService,
|
|
mockCompiledTemplate,
|
|
testScope,
|
|
mockBody,
|
|
mockElement,
|
|
service;
|
|
|
|
beforeEach(function () {
|
|
mockCompile = jasmine.createSpy('$compile');
|
|
mockDocument = jasmine.createSpyObj('$document', ['find']);
|
|
testWindow = { innerWidth: 1000, innerHeight: 100 };
|
|
mockRootScope = jasmine.createSpyObj('$rootScope', ['$new']);
|
|
mockAgentService = jasmine.createSpyObj('agentService', ['isMobile', 'isPhone']);
|
|
mockCompiledTemplate = jasmine.createSpy('template');
|
|
testScope = {};
|
|
mockBody = jasmine.createSpyObj('body', ['append']);
|
|
mockElement = jasmine.createSpyObj('element', ['css', 'remove']);
|
|
|
|
mockDocument.find.andCallFake(function (tag) {
|
|
return tag === 'body' ? mockBody : undefined;
|
|
});
|
|
mockCompile.andReturn(mockCompiledTemplate);
|
|
mockCompiledTemplate.andReturn(mockElement);
|
|
mockRootScope.$new.andReturn(testScope);
|
|
|
|
service = new InfoService(
|
|
mockCompile,
|
|
mockDocument,
|
|
testWindow,
|
|
mockRootScope,
|
|
mockAgentService
|
|
);
|
|
});
|
|
|
|
it("creates elements and appends them to the body to display", function () {
|
|
service.display('', '', {}, [0, 0]);
|
|
expect(mockBody.append).toHaveBeenCalledWith(mockElement);
|
|
});
|
|
|
|
it("provides a function to remove displayed info bubbles", function () {
|
|
var fn = service.display('', '', {}, [0, 0]);
|
|
expect(mockElement.remove).not.toHaveBeenCalled();
|
|
fn();
|
|
expect(mockElement.remove).toHaveBeenCalled();
|
|
});
|
|
|
|
describe("depending on mouse position", function () {
|
|
// Positioning should vary based on quadrant in window,
|
|
// which is 1000 x 100 in this test case.
|
|
it("displays from the top-left in the top-left quadrant", function () {
|
|
service.display('', '', {}, [250, 25]);
|
|
expect(mockElement.css).toHaveBeenCalledWith(
|
|
'left',
|
|
(250 + InfoConstants.BUBBLE_OFFSET[0]) + 'px'
|
|
);
|
|
expect(mockElement.css).toHaveBeenCalledWith(
|
|
'top',
|
|
(25 + InfoConstants.BUBBLE_OFFSET[1]) + 'px'
|
|
);
|
|
});
|
|
|
|
it("displays from the top-right in the top-right quadrant", function () {
|
|
service.display('', '', {}, [700, 25]);
|
|
expect(mockElement.css).toHaveBeenCalledWith(
|
|
'right',
|
|
(300 + InfoConstants.BUBBLE_OFFSET[0]) + 'px'
|
|
);
|
|
expect(mockElement.css).toHaveBeenCalledWith(
|
|
'top',
|
|
(25 + InfoConstants.BUBBLE_OFFSET[1]) + 'px'
|
|
);
|
|
});
|
|
|
|
it("displays from the bottom-left in the bottom-left quadrant", function () {
|
|
service.display('', '', {}, [250, 70]);
|
|
expect(mockElement.css).toHaveBeenCalledWith(
|
|
'left',
|
|
(250 + InfoConstants.BUBBLE_OFFSET[0]) + 'px'
|
|
);
|
|
expect(mockElement.css).toHaveBeenCalledWith(
|
|
'bottom',
|
|
(30 + InfoConstants.BUBBLE_OFFSET[1]) + 'px'
|
|
);
|
|
});
|
|
|
|
it("displays from the bottom-right in the bottom-right quadrant", function () {
|
|
service.display('', '', {}, [800, 60]);
|
|
expect(mockElement.css).toHaveBeenCalledWith(
|
|
'right',
|
|
(200 + InfoConstants.BUBBLE_OFFSET[0]) + 'px'
|
|
);
|
|
expect(mockElement.css).toHaveBeenCalledWith(
|
|
'bottom',
|
|
(40 + InfoConstants.BUBBLE_OFFSET[1]) + 'px'
|
|
);
|
|
});
|
|
|
|
it("when on phone device, positioning is always on bottom", function () {
|
|
mockAgentService.isPhone.andReturn(true);
|
|
service = new InfoService(
|
|
mockCompile,
|
|
mockDocument,
|
|
testWindow,
|
|
mockRootScope,
|
|
mockAgentService
|
|
);
|
|
service.display('', '', {}, [0, 0]);
|
|
});
|
|
});
|
|
|
|
});
|
|
}
|
|
);
|