2014-11-22 17:36:30 +00:00
|
|
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* DragGestureSpec. Created by vwoeltje on 11/6/14.
|
|
|
|
*/
|
|
|
|
define(
|
2014-11-22 18:26:44 +00:00
|
|
|
["../../src/gestures/DragGesture", "../../src/gestures/GestureConstants"],
|
|
|
|
function (DragGesture, GestureConstants) {
|
2014-11-22 17:36:30 +00:00
|
|
|
"use strict";
|
|
|
|
|
2014-11-22 18:26:44 +00:00
|
|
|
var JQLITE_FUNCTIONS = [ "on", "off", "attr", "removeAttr" ],
|
|
|
|
LOG_FUNCTIONS = [ "error", "warn", "info", "debug"],
|
2015-03-19 19:34:52 +00:00
|
|
|
DND_FUNCTIONS = [ "setData", "getData", "removeData" ],
|
2014-11-22 18:26:44 +00:00
|
|
|
DOMAIN_OBJECT_METHODS = [ "getId", "getModel", "getCapability", "hasCapability", "useCapability"],
|
|
|
|
TEST_ID = "test-id";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
describe("The drag gesture", function () {
|
|
|
|
var mockLog,
|
2015-03-19 19:34:52 +00:00
|
|
|
mockDndService,
|
2014-11-22 18:26:44 +00:00
|
|
|
mockElement,
|
|
|
|
mockDomainObject,
|
|
|
|
mockDataTransfer,
|
2015-03-19 19:34:52 +00:00
|
|
|
handlers,
|
|
|
|
gesture;
|
2014-11-22 18:26:44 +00:00
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
mockLog = jasmine.createSpyObj("$log", LOG_FUNCTIONS);
|
2015-03-19 19:34:52 +00:00
|
|
|
mockDndService = jasmine.createSpyObj("dndService", DND_FUNCTIONS);
|
2014-11-22 18:26:44 +00:00
|
|
|
mockElement = jasmine.createSpyObj("element", JQLITE_FUNCTIONS);
|
|
|
|
mockDomainObject = jasmine.createSpyObj("domainObject", DOMAIN_OBJECT_METHODS);
|
|
|
|
mockDataTransfer = jasmine.createSpyObj("dataTransfer", ["setData"]);
|
|
|
|
|
|
|
|
mockDomainObject.getId.andReturn(TEST_ID);
|
|
|
|
mockDomainObject.getModel.andReturn({});
|
|
|
|
|
2015-03-19 19:34:52 +00:00
|
|
|
handlers = {};
|
|
|
|
|
|
|
|
gesture = new DragGesture(mockLog, mockDndService, mockElement, mockDomainObject);
|
|
|
|
|
|
|
|
// Look up all handlers registered by the gesture
|
|
|
|
mockElement.on.calls.forEach(function (call) {
|
|
|
|
handlers[call.args[0]] = call.args[1];
|
|
|
|
});
|
2014-11-22 18:26:44 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it("listens for dragstart on the element", function () {
|
2015-03-19 19:34:52 +00:00
|
|
|
expect(handlers.dragstart).toEqual(jasmine.any(Function));
|
2014-11-22 18:26:44 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it("marks an element as draggable", function () {
|
|
|
|
expect(mockElement.attr).toHaveBeenCalledWith("draggable", "true");
|
|
|
|
});
|
|
|
|
|
|
|
|
it("places data in a dataTransfer object", function () {
|
2015-03-19 19:34:52 +00:00
|
|
|
handlers.dragstart({ dataTransfer: mockDataTransfer });
|
2014-11-22 18:26:44 +00:00
|
|
|
expect(mockDataTransfer.setData).toHaveBeenCalledWith(
|
|
|
|
GestureConstants.MCT_DRAG_TYPE,
|
|
|
|
TEST_ID
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2015-03-19 19:34:52 +00:00
|
|
|
it("places domain object in the dnd service", function () {
|
|
|
|
handlers.dragstart({ dataTransfer: mockDataTransfer });
|
|
|
|
expect(mockDndService.setData).toHaveBeenCalledWith(
|
|
|
|
GestureConstants.MCT_DRAG_TYPE,
|
2015-03-19 19:39:13 +00:00
|
|
|
TEST_ID
|
|
|
|
);
|
|
|
|
expect(mockDndService.setData).toHaveBeenCalledWith(
|
|
|
|
GestureConstants.MCT_EXTENDED_DRAG_TYPE,
|
2015-03-19 19:34:52 +00:00
|
|
|
mockDomainObject
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("clears domain object from the dnd service on drag end", function () {
|
|
|
|
// Start dragging
|
|
|
|
handlers.dragstart({ dataTransfer: mockDataTransfer });
|
|
|
|
|
|
|
|
// Verify precondition
|
|
|
|
expect(mockDndService.removeData).not.toHaveBeenCalled();
|
|
|
|
|
|
|
|
// End the drag
|
|
|
|
handlers.dragend({ dataTransfer: mockDataTransfer });
|
2015-03-19 19:39:13 +00:00
|
|
|
|
|
|
|
// Should have removed the data that was attached
|
2015-03-19 19:34:52 +00:00
|
|
|
expect(mockDndService.removeData)
|
|
|
|
.toHaveBeenCalledWith(GestureConstants.MCT_DRAG_TYPE);
|
2015-03-19 19:39:13 +00:00
|
|
|
expect(mockDndService.removeData)
|
|
|
|
.toHaveBeenCalledWith(GestureConstants.MCT_EXTENDED_DRAG_TYPE);
|
2015-03-19 19:34:52 +00:00
|
|
|
});
|
|
|
|
|
2014-11-22 18:26:44 +00:00
|
|
|
it("logs a warning if dataTransfer cannot be set", function () {
|
|
|
|
// Verify precondition
|
|
|
|
expect(mockLog.warn).not.toHaveBeenCalled();
|
|
|
|
|
|
|
|
// Fire the gesture without a dataTransfer field
|
2015-03-19 19:34:52 +00:00
|
|
|
handlers.dragstart({});
|
2014-11-22 18:26:44 +00:00
|
|
|
|
|
|
|
// Should have logged a warning
|
|
|
|
expect(mockLog.warn).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("removes draggable attribute and listener when destroyed", function () {
|
|
|
|
// Verify preconditions
|
|
|
|
expect(mockElement.removeAttr).not.toHaveBeenCalled();
|
|
|
|
expect(mockElement.off).not.toHaveBeenCalled();
|
|
|
|
|
|
|
|
// Notify the gesture that its scope is being destroyed
|
|
|
|
gesture.destroy();
|
|
|
|
|
|
|
|
// Verify that attribute/listener were removed
|
|
|
|
expect(mockElement.removeAttr).toHaveBeenCalledWith("draggable");
|
2015-03-19 19:34:52 +00:00
|
|
|
expect(mockElement.off).toHaveBeenCalledWith("dragstart", handlers.dragstart);
|
2014-11-22 18:26:44 +00:00
|
|
|
});
|
2014-11-22 17:36:30 +00:00
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|