goog.provide('ol.test.format.GML'); describe('ol.format.GML', function() { var format; beforeEach(function() { format = new ol.format.GML(); }); describe('#readGeometry', function() { describe('point', function() { it('can read a point geometry', function() { var text = '' + ' 1 2' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.Point); expect(g.getCoordinates()).to.eql([1, 2, 0]); }); }); describe('linestring', function() { it('can read a linestring geometry', function() { var text = '' + ' 1 2 3 4' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.LineString); expect(g.getCoordinates()).to.eql([[1, 2, 0], [3, 4, 0]]); }); }); describe('linestring 3D', function() { it('can read a linestring 3D geometry', function() { var text = '' + ' 1 2 3 4 5 6' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.LineString); expect(g.getCoordinates()).to.eql([[1, 2, 3], [4, 5, 6]]); }); }); describe('polygon', function() { it('can read a polygon geometry', function() { var text = '' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ' 2 3 2 5 4 5 2 3' + ' ' + ' ' + ' ' + ' ' + ' 3 4 3 6 5 6 3 4' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.Polygon); expect(g.getCoordinates()).to.eql([[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]], [[2, 3, 0], [2, 5, 0], [4, 5, 0], [2, 3, 0]], [[3, 4, 0], [3, 6, 0], [5, 6, 0], [3, 4, 0]]]); }); }); describe('surface', function() { it('can read a surface geometry', function() { var text = '' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ' 2 3 2 5 4 5 2 3' + ' ' + ' ' + ' ' + ' ' + ' 3 4 3 6 5 6 3 4' + ' ' + ' ' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.Polygon); expect(g.getCoordinates()).to.eql([[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]], [[2, 3, 0], [2, 5, 0], [4, 5, 0], [2, 3, 0]], [[3, 4, 0], [3, 6, 0], [5, 6, 0], [3, 4, 0]]]); }); }); describe('curve', function() { it('can read a curve geometry', function() { var text = '' + ' ' + ' ' + ' 1 2 3 4' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.LineString); expect(g.getCoordinates()).to.eql([[1, 2, 0], [3, 4, 0]]); }); }); describe('envelope', function() { it('can read an envelope geometry', function() { var text = '' + ' 1 2' + ' 3 4' + ''; var g = format.readGeometry(text); expect(g).to.eql([1, 2, 3, 4]); }); }); describe('multipoint', function() { it('can read a singular multipoint geometry', function() { var text = '' + ' ' + ' ' + ' 1 2' + ' ' + ' ' + ' ' + ' ' + ' 2 3' + ' ' + ' ' + ' ' + ' ' + ' 3 4' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiPoint); expect(g.getCoordinates()).to.eql([[1, 2, 0], [2, 3, 0], [3, 4, 0]]); }); it('can read a plural multipoint geometry', function() { var text = '' + ' ' + ' ' + ' 1 2' + ' ' + ' ' + ' 2 3' + ' ' + ' ' + ' 3 4' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiPoint); expect(g.getCoordinates()).to.eql([[1, 2, 0], [2, 3, 0], [3, 4, 0]]); }); }); describe('multilinestring', function() { it('can read a singular multilinestring geometry', function() { var text = '' + ' ' + ' ' + ' 1 2 2 3' + ' ' + ' ' + ' ' + ' ' + ' 3 4 4 5' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiLineString); expect(g.getCoordinates()).to.eql( [[[1, 2, 0], [2, 3, 0]], [[3, 4, 0], [4, 5, 0]]]); }); it('can read a plural multilinestring geometry', function() { var text = '' + ' ' + ' ' + ' 1 2 2 3' + ' ' + ' ' + ' 3 4 4 5' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiLineString); expect(g.getCoordinates()).to.eql( [[[1, 2, 0], [2, 3, 0]], [[3, 4, 0], [4, 5, 0]]]); }); }); describe('multipolygon', function() { it('can read a singular multipolygon geometry', function() { var text = '' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ' 2 3 2 5 4 5 2 3' + ' ' + ' ' + ' ' + ' ' + ' 3 4 3 6 5 6 3 4' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiPolygon); expect(g.getCoordinates()).to.eql([ [[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]], [[2, 3, 0], [2, 5, 0], [4, 5, 0], [2, 3, 0]], [[3, 4, 0], [3, 6, 0], [5, 6, 0], [3, 4, 0]]], [[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]]]]); }); it('can read a plural multipolygon geometry', function() { var text = '' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ' 2 3 2 5 4 5 2 3' + ' ' + ' ' + ' ' + ' ' + ' 3 4 3 6 5 6 3 4' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiPolygon); expect(g.getCoordinates()).to.eql([ [[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]], [[2, 3, 0], [2, 5, 0], [4, 5, 0], [2, 3, 0]], [[3, 4, 0], [3, 6, 0], [5, 6, 0], [3, 4, 0]]], [[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]]]]); }); }); describe('multicurve', function() { it('can read a singular multicurve-linestring geometry', function() { var text = '' + ' ' + ' ' + ' 1 2 2 3' + ' ' + ' ' + ' ' + ' ' + ' 3 4 4 5' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiLineString); expect(g.getCoordinates()).to.eql( [[[1, 2, 0], [2, 3, 0]], [[3, 4, 0], [4, 5, 0]]]); }); it('can read a singular multicurve-curve geometry', function() { var text = '' + ' ' + ' ' + ' ' + ' ' + ' 1 2 2 3' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' 3 4 4 5' + ' ' + ' ' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiLineString); expect(g.getCoordinates()).to.eql( [[[1, 2, 0], [2, 3, 0]], [[3, 4, 0], [4, 5, 0]]]); }); }); describe('multisurface', function() { it('can read a singular multisurface geometry', function() { var text = '' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ' 2 3 2 5 4 5 2 3' + ' ' + ' ' + ' ' + ' ' + ' 3 4 3 6 5 6 3 4' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiPolygon); expect(g.getCoordinates()).to.eql([ [[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]], [[2, 3, 0], [2, 5, 0], [4, 5, 0], [2, 3, 0]], [[3, 4, 0], [3, 6, 0], [5, 6, 0], [3, 4, 0]]], [[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]]]]); }); it('can read a plural multisurface geometry', function() { var text = '' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ' 2 3 2 5 4 5 2 3' + ' ' + ' ' + ' ' + ' ' + ' 3 4 3 6 5 6 3 4' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiPolygon); expect(g.getCoordinates()).to.eql([ [[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]], [[2, 3, 0], [2, 5, 0], [4, 5, 0], [2, 3, 0]], [[3, 4, 0], [3, 6, 0], [5, 6, 0], [3, 4, 0]]], [[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]]]]); }); it('can read a multisurface-surface geometry', function() { var text = '' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ' 2 3 2 5 4 5 2 3' + ' ' + ' ' + ' ' + ' ' + ' 3 4 3 6 5 6 3 4' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ' 1 2 3 2 3 4 1 2' + ' ' + ' ' + ' ' + ' ' + ' ' + ' ' + ''; var g = format.readGeometry(text); expect(g).to.be.an(ol.geom.MultiPolygon); expect(g.getCoordinates()).to.eql([ [[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]], [[2, 3, 0], [2, 5, 0], [4, 5, 0], [2, 3, 0]], [[3, 4, 0], [3, 6, 0], [5, 6, 0], [3, 4, 0]]], [[[1, 2, 0], [3, 2, 0], [3, 4, 0], [1, 2, 0]]]]); }); }); }); }); goog.require('ol.format.GML'); goog.require('ol.geom.LineString'); goog.require('ol.geom.MultiPoint'); goog.require('ol.geom.MultiLineString'); goog.require('ol.geom.MultiPolygon'); goog.require('ol.geom.Point'); goog.require('ol.geom.Polygon');