Add tests for geometry applyTransform method

This commit is contained in:
Tim Schaub
2014-05-02 09:58:23 -06:00
parent 4f9968d106
commit a4f1efbddb
2 changed files with 74 additions and 0 deletions

View File

@@ -192,6 +192,44 @@ describe('ol.geom.MultiPoint', function() {
});
describe('#applyTransform()', function() {
var multi, transform;
beforeEach(function() {
multi = new ol.geom.MultiPoint([[1, 2], [3, 4]]);
transform = sinon.spy();
});
it('calls a transform function', function() {
multi.applyTransform(transform);
expect(transform.calledOnce).to.be(true);
var args = transform.firstCall.args;
expect(args).to.have.length(3);
expect(args[0]).to.be(multi.getFlatCoordinates()); // input coords
expect(args[1]).to.be(multi.getFlatCoordinates()); // output coords
expect(args[2]).to.be(2); // dimension
});
it('allows for modification of coordinates', function() {
var mod = function(input, output, dimension) {
var copy = input.slice();
for (var i = 0, ii = copy.length; i < ii; i += dimension) {
output[i] = copy[i + 1];
output[i + 1] = copy[i];
}
};
multi.applyTransform(mod);
expect(multi.getCoordinates()).to.eql([[2, 1], [4, 3]]);
});
it('returns undefined', function() {
var got = multi.applyTransform(transform);
expect(got).to.be(undefined);
});
});
});

View File

@@ -106,6 +106,42 @@ describe('ol.geom.Point', function() {
});
describe('#applyTransform()', function() {
var point, transform;
beforeEach(function() {
point = new ol.geom.Point([1, 2]);
transform = sinon.spy();
});
it('calls a transform function', function() {
point.applyTransform(transform);
expect(transform.calledOnce).to.be(true);
var args = transform.firstCall.args;
expect(args).to.have.length(3);
expect(args[0]).to.be(point.getFlatCoordinates()); // input coords
expect(args[1]).to.be(point.getFlatCoordinates()); // output coords
expect(args[2]).to.be(2); // dimension
});
it('allows for modification of coordinates', function() {
var mod = function(input, output, dimension) {
var copy = input.slice();
output[1] = copy[0];
output[0] = copy[1];
};
point.applyTransform(mod);
expect(point.getCoordinates()).to.eql([2, 1]);
});
it('returns undefined', function() {
var got = point.applyTransform(transform);
expect(got).to.be(undefined);
});
});
});