Shivam Dave 73079e109c [Gestures] Tests
Set up MCTPlot test for the
touch gesture evetns, however
stopped short of utils call.
2015-09-04 15:27:02 -07:00

122 lines
4.7 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,xit,beforeEach,waitsFor,jasmine*/
define(
["../../src/directives/MCTPlot"],
function (MCTPlot) {
"use strict";
describe("The MCT Pinch directive", function () {
var mockScope,
mockElement,
mockCanvas,
mockTouch,
mockTouchEvent,
mockTouchPair,
mockBounds,
mockBoundsEvent,
mockTarget,
mockUtils,
mockMidpoint,
mockDistance,
mctPlot;
beforeEach(function () {
mockScope = jasmine.createSpyObj("$scope", [
"axes", "viewport", "rectangles", "mouseCoordinates",
"$broadcast", "displayableRange", "displayableDomain",
"$emit", "$on", "$watchCollection" ]);
mockElement = jasmine.createSpyObj("$element", [ "find" ]);
mockCanvas = jasmine.createSpyObj("canvas", [ "on", "off", "removeClass", "addClass" ]);
mockBoundsEvent = jasmine.createSpyObj("event", [ "touches", "changedTouches", "preventDefault", "target" ]);
mockTarget = jasmine.createSpyObj("event.target", ["getBoundingClientRect"]);
mockMidpoint = jasmine.createSpyObj("touch.midpoint", ["clientX", "clientY"]);
mockTouchEvent = jasmine.createSpyObj("event",
[ "clientX", "clientY" ]);
mockDistance = jasmine.createSpy("touch.distance");
mockUtils = jasmine.createSpyObj("utils", [ "elementPositionAsPlotPosition" ]);
mockTouchPair = [mockTouchEvent, mockTouchEvent];
mockBoundsEvent.target = mockTarget;
mockBounds = mockTarget.getBoundingClientRect();
mockElement.find.andReturn(mockCanvas);
mctPlot = new MCTPlot();
mctPlot.link(mockScope, mockElement);
});
it("Start Pinch", function() {
//console.log(mockScope.$on.calls[0]);
mockTouch = {
touches: mockTouchPair,
bounds: mockBounds,
midpoint: mockMidpoint,
distance: mockDistance
};
//mockScope.$on.calls[0].args[1]("event", mockTouch);
});
it("Change Pinch", function() {
mockTouch = {
touches: mockTouchPair,
bounds: mockBounds,
midpoint: mockMidpoint,
distance: mockDistance
};
//console.log(mockScope.$on.calls[1]);
//mockScope.$on.calls[1].args[1]();
});
it("Start Pan", function() {
mockTouch = {
touch: [mockTouchEvent],
bounds: mockBounds
};
//console.log(mockScope.$on.calls[2]);
//mockScope.$on.calls[2].args[1]();
});
it("Change Pan", function() {
mockTouch = {
touch: [mockTouchEvent],
bounds: mockBounds
};
//console.log(mockScope.$on.calls[3]);
//mockScope.$on.calls[3].args[1]();
});
it("Touch End", function() {
//console.log(mockScope.$on.calls[4]);
//mockScope.$on.calls[4].args[1]();
});
});
}
);