2014-12-05 23:39:07 +00:00
|
|
|
/*global define,describe,it,expect,beforeEach,jasmine*/
|
|
|
|
|
|
|
|
define(
|
|
|
|
["../src/LayoutController"],
|
|
|
|
function (LayoutController) {
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
describe("The Layout controller", function () {
|
2014-12-06 00:53:53 +00:00
|
|
|
var mockScope,
|
|
|
|
testModel,
|
|
|
|
testConfiguration,
|
|
|
|
controller;
|
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
mockScope = jasmine.createSpyObj(
|
|
|
|
"$scope",
|
2015-02-17 18:50:02 +00:00
|
|
|
[ "$watch", "$on", "commit" ]
|
2014-12-06 00:53:53 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
testModel = {
|
|
|
|
composition: [ "a", "b", "c" ]
|
|
|
|
};
|
|
|
|
|
|
|
|
testConfiguration = {
|
|
|
|
panels: {
|
|
|
|
a: {
|
|
|
|
position: [20, 10],
|
|
|
|
dimensions: [5, 5]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
mockScope.model = testModel;
|
|
|
|
mockScope.configuration = testConfiguration;
|
|
|
|
|
|
|
|
controller = new LayoutController(mockScope);
|
|
|
|
});
|
|
|
|
|
|
|
|
// Model changes will indicate that panel positions
|
|
|
|
// may have changed, for instance.
|
2015-01-27 18:22:50 +00:00
|
|
|
it("watches for changes to composition", function () {
|
2014-12-06 00:53:53 +00:00
|
|
|
expect(mockScope.$watch).toHaveBeenCalledWith(
|
2015-01-27 18:22:50 +00:00
|
|
|
"model.composition",
|
2014-12-06 00:53:53 +00:00
|
|
|
jasmine.any(Function)
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("provides styles for frames, from configuration", function () {
|
2015-01-27 18:22:50 +00:00
|
|
|
mockScope.$watch.mostRecentCall.args[1](testModel.composition);
|
2014-12-06 00:53:53 +00:00
|
|
|
expect(controller.getFrameStyle("a")).toEqual({
|
|
|
|
top: "320px",
|
|
|
|
left: "640px",
|
|
|
|
width: "160px",
|
|
|
|
height: "160px"
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("provides default styles for frames", function () {
|
|
|
|
var styleB, styleC;
|
|
|
|
|
|
|
|
// b and c do not have configured positions
|
2015-01-27 18:22:50 +00:00
|
|
|
mockScope.$watch.mostRecentCall.args[1](testModel.composition);
|
2014-12-06 00:53:53 +00:00
|
|
|
|
|
|
|
styleB = controller.getFrameStyle("b");
|
|
|
|
styleC = controller.getFrameStyle("c");
|
|
|
|
|
|
|
|
// Should have a position, but we don't care what
|
|
|
|
expect(styleB.left).toBeDefined();
|
|
|
|
expect(styleB.top).toBeDefined();
|
|
|
|
expect(styleC.left).toBeDefined();
|
|
|
|
expect(styleC.top).toBeDefined();
|
|
|
|
|
|
|
|
// Should have ensured some difference in position
|
|
|
|
expect(styleB).not.toEqual(styleC);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("allows panels to be dragged", function () {
|
|
|
|
// Populate scope
|
2015-01-27 18:22:50 +00:00
|
|
|
mockScope.$watch.mostRecentCall.args[1](testModel.composition);
|
2014-12-06 00:53:53 +00:00
|
|
|
|
|
|
|
// Verify precondtion
|
|
|
|
expect(testConfiguration.panels.b).not.toBeDefined();
|
|
|
|
|
|
|
|
// Do a drag
|
|
|
|
controller.startDrag("b", [1, 1], [0, 0]);
|
|
|
|
controller.continueDrag([100, 100]);
|
|
|
|
controller.endDrag();
|
|
|
|
|
|
|
|
// We do not look closely at the details here;
|
|
|
|
// that is tested in LayoutDragSpec. Just make sure
|
|
|
|
// that a configuration for b has been defined.
|
|
|
|
expect(testConfiguration.panels.b).toBeDefined();
|
|
|
|
});
|
2014-12-06 17:45:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
it("invokes commit after drag", function () {
|
|
|
|
// Populate scope
|
2015-01-27 18:22:50 +00:00
|
|
|
mockScope.$watch.mostRecentCall.args[1](testModel.composition);
|
2014-12-06 17:45:41 +00:00
|
|
|
|
|
|
|
// Do a drag
|
|
|
|
controller.startDrag("b", [1, 1], [0, 0]);
|
|
|
|
controller.continueDrag([100, 100]);
|
|
|
|
controller.endDrag();
|
|
|
|
|
|
|
|
// Should have triggered commit (provided by
|
|
|
|
// EditRepresenter) with some message.
|
|
|
|
expect(mockScope.commit)
|
|
|
|
.toHaveBeenCalledWith(jasmine.any(String));
|
|
|
|
});
|
2015-02-17 18:50:02 +00:00
|
|
|
|
|
|
|
it("listens for drop events", function () {
|
|
|
|
// Layout should position panels according to
|
|
|
|
// where the user dropped them, so it needs to
|
|
|
|
// listen for drop events.
|
|
|
|
expect(mockScope.$on).toHaveBeenCalledWith(
|
|
|
|
'mctDrop',
|
|
|
|
jasmine.any(Function)
|
|
|
|
);
|
|
|
|
|
|
|
|
// Verify precondition
|
|
|
|
expect(testConfiguration.panels.d).not.toBeDefined();
|
|
|
|
|
|
|
|
// Notify that a drop occurred
|
|
|
|
testModel.composition.push('d');
|
|
|
|
mockScope.$on.mostRecentCall.args[1](
|
|
|
|
{},
|
|
|
|
'd',
|
|
|
|
{ x: 300, y: 100 }
|
|
|
|
);
|
|
|
|
expect(testConfiguration.panels.d).toBeDefined();
|
|
|
|
|
|
|
|
// Should have triggered commit (provided by
|
|
|
|
// EditRepresenter) with some message.
|
|
|
|
expect(mockScope.commit)
|
|
|
|
.toHaveBeenCalledWith(jasmine.any(String));
|
|
|
|
});
|
2014-12-05 23:39:07 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|