import _ol_Feature_ from '../../../../src/ol/Feature.js'; import _ol_format_GPX_ from '../../../../src/ol/format/GPX.js'; import _ol_geom_LineString_ from '../../../../src/ol/geom/LineString.js'; import _ol_geom_MultiLineString_ from '../../../../src/ol/geom/MultiLineString.js'; import Point from '../../../../src/ol/geom/Point.js'; import _ol_geom_Polygon_ from '../../../../src/ol/geom/Polygon.js'; import {get as getProjection, transform} from '../../../../src/ol/proj.js'; import _ol_xml_ from '../../../../src/ol/xml.js'; describe('ol.format.GPX', function() { var format; beforeEach(function() { format = new _ol_format_GPX_(); }); describe('#readProjection', function() { it('returns the default projection from document', function() { var projection = format.readProjectionFromDocument(); expect(projection).to.eql(getProjection('EPSG:4326')); }); it('returns the default projection from node', function() { var projection = format.readProjectionFromNode(); expect(projection).to.eql(getProjection('EPSG:4326')); }); }); describe('rte', function() { it('can read an empty rte', function() { var text = '' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(_ol_geom_LineString_); expect(g.getCoordinates()).to.eql([]); expect(g.getLayout()).to.be('XY'); }); it('can read and write various rte attributes', function() { var text = '' + ' ' + ' Name' + ' Comment' + ' Description' + ' Source' + ' ' + ' Link text' + ' Link type' + ' ' + ' 1' + ' Type' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); expect(f.get('name')).to.be('Name'); expect(f.get('cmt')).to.be('Comment'); expect(f.get('desc')).to.be('Description'); expect(f.get('src')).to.be('Source'); expect(f.get('link')).to.be('http://example.com/'); expect(f.get('linkText')).to.be('Link text'); expect(f.get('linkType')).to.be('Link type'); expect(f.get('number')).to.be(1); expect(f.get('type')).to.be('Type'); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can read and write a rte with multiple rtepts', function() { var text = '' + ' ' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(_ol_geom_LineString_); expect(g.getCoordinates()).to.eql([[2, 1], [4, 3]]); expect(g.getLayout()).to.be('XY'); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can transform, read and write a rte', function() { var text = '' + ' ' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text, { featureProjection: 'EPSG:3857' }); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(_ol_geom_LineString_); var p1 = transform([2, 1], 'EPSG:4326', 'EPSG:3857'); var p2 = transform([6, 5], 'EPSG:4326', 'EPSG:3857'); expect(g.getCoordinates()).to.eql([p1, p2]); expect(g.getLayout()).to.be('XY'); var serialized = format.writeFeaturesNode(fs, { featureProjection: 'EPSG:3857' }); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('does not write rte attributes in rtepts', function() { var text = '' + ' ' + ' Name' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); }); describe('trk', function() { it('can read an empty trk', function() { var text = '' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(_ol_geom_MultiLineString_); expect(g.getCoordinates()).to.eql([]); expect(g.getLayout()).to.be('XY'); }); it('can read and write various trk attributes', function() { var text = '' + ' ' + ' Name' + ' Comment' + ' Description' + ' Source' + ' ' + ' Link text' + ' Link type' + ' ' + ' 1' + ' Type' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); expect(f.get('name')).to.be('Name'); expect(f.get('cmt')).to.be('Comment'); expect(f.get('desc')).to.be('Description'); expect(f.get('src')).to.be('Source'); expect(f.get('link')).to.be('http://example.com/'); expect(f.get('linkText')).to.be('Link text'); expect(f.get('linkType')).to.be('Link type'); expect(f.get('number')).to.be(1); expect(f.get('type')).to.be('Type'); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can read and write a trk with an empty trkseg', function() { var text = '' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(_ol_geom_MultiLineString_); expect(g.getCoordinates()).to.eql([[]]); expect(g.getLayout()).to.be('XY'); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can read/write a trk with a trkseg with multiple trkpts', function() { var text = '' + ' ' + ' ' + ' ' + ' 3' + ' ' + ' ' + ' ' + ' 7' + ' ' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(_ol_geom_MultiLineString_); expect(g.getCoordinates()).to.eql([ [[2, 1, 3, 1263115752], [6, 5, 7, 1263115812]] ]); expect(g.getLayout()).to.be('XYZM'); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can transform, read and write a trk with a trkseg', function() { var text = '' + ' ' + ' ' + ' ' + ' 3' + ' ' + ' ' + ' ' + ' 7' + ' ' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text, { featureProjection: 'EPSG:3857' }); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(_ol_geom_MultiLineString_); var p1 = transform([2, 1], 'EPSG:4326', 'EPSG:3857'); p1.push(3, 1263115752); var p2 = transform([6, 5], 'EPSG:4326', 'EPSG:3857'); p2.push(7, 1263115812); expect(g.getCoordinates()).to.eql([[p1, p2]]); expect(g.getLayout()).to.be('XYZM'); var serialized = format.writeFeaturesNode(fs, { featureProjection: 'EPSG:3857' }); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can read and write a trk with multiple trksegs', function() { var text = '' + ' ' + ' ' + ' ' + ' 3' + ' ' + ' ' + ' ' + ' 7' + ' ' + ' ' + ' ' + ' ' + ' ' + ' 10' + ' ' + ' ' + ' ' + ' 13' + ' ' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(_ol_geom_MultiLineString_); expect(g.getCoordinates()).to.eql([ [[2, 1, 3, 1263115752], [6, 5, 7, 1263115812]], [[9, 8, 10, 1263115872], [12, 11, 13, 1263115932]] ]); expect(g.getLayout()).to.be('XYZM'); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('does not write trk attributes in trkpts', function() { var text = '' + ' ' + ' Name' + ' ' + ' ' + ' 3' + ' ' + ' ' + ' ' + ' 7' + ' ' + ' ' + ' ' + ' ' + ' ' + ' 10' + ' ' + ' ' + ' ' + ' 13' + ' ' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); }); describe('wpt', function() { it('can read and write a wpt', function() { var text = '' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(Point); expect(g.getCoordinates()).to.eql([2, 1]); expect(g.getLayout()).to.be('XY'); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can transform, read and write a wpt', function() { var text = '' + ' ' + ''; var fs = format.readFeatures(text, { featureProjection: 'EPSG:3857' }); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(Point); var expectedPoint = transform([2, 1], 'EPSG:4326', 'EPSG:3857'); expect(g.getCoordinates()).to.eql(expectedPoint); expect(g.getLayout()).to.be('XY'); var serialized = format.writeFeaturesNode(fs, { featureProjection: 'EPSG:3857' }); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can read and write a wpt with ele', function() { var text = '' + ' ' + ' 3' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(Point); expect(g.getCoordinates()).to.eql([2, 1, 3]); expect(g.getLayout()).to.be('XYZ'); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can read and write a wpt with time', function() { var text = '' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(Point); expect(g.getCoordinates()).to.eql([2, 1, 1263115752]); expect(g.getLayout()).to.be('XYM'); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can read and write a wpt with ele and time', function() { var text = '' + ' ' + ' 3' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); var g = f.getGeometry(); expect(g).to.be.an(Point); expect(g.getCoordinates()).to.eql([2, 1, 3, 1263115752]); expect(g.getLayout()).to.be('XYZM'); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); it('can read and write various wpt attributes', function() { var text = '' + ' ' + ' 11' + ' 4' + ' Name' + ' Comment' + ' Description' + ' Source' + ' ' + ' Link text' + ' Link type' + ' ' + ' Symbol' + ' Type' + ' 2d' + ' 5' + ' 6' + ' 7' + ' 8' + ' 9' + ' 10' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var f = fs[0]; expect(f).to.be.an(_ol_Feature_); expect(f.get('magvar')).to.be(11); expect(f.get('geoidheight')).to.be(4); expect(f.get('name')).to.be('Name'); expect(f.get('cmt')).to.be('Comment'); expect(f.get('desc')).to.be('Description'); expect(f.get('src')).to.be('Source'); expect(f.get('link')).to.be('http://example.com/'); expect(f.get('linkText')).to.be('Link text'); expect(f.get('linkType')).to.be('Link type'); expect(f.get('sym')).to.be('Symbol'); expect(f.get('type')).to.be('Type'); expect(f.get('fix')).to.be('2d'); expect(f.get('hdop')).to.be(6); expect(f.get('vdop')).to.be(7); expect(f.get('pdop')).to.be(8); expect(f.get('ageofdgpsdata')).to.be(9); expect(f.get('dgpsid')).to.be(10); var serialized = format.writeFeaturesNode(fs); expect(serialized).to.xmleql(_ol_xml_.parse(text)); }); }); describe('XML namespace support', function() { beforeEach(function() { format = new _ol_format_GPX_(); }); it('can read features with a version 1.0 namespace', function() { var text = '' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(3); }); it('can read features with a version 1.1 namespace', function() { var text = '' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(3); }); it('can read features with no namespace', function() { var text = '' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(3); }); }); describe('extensions support', function() { beforeEach(function() { format = new _ol_format_GPX_({ readExtensions: function(feature, extensionsNode) { var nodes = extensionsNode.getElementsByTagName('id'); var id = nodes.item(0).textContent; feature.setId(id); } }); }); it('can process extensions from wpt', function() { var text = '' + ' ' + ' ' + ' feature-id' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var feature = fs[0]; expect(feature.getId()).to.be('feature-id'); }); it('can process extensions from rte', function() { var text = '' + ' ' + ' ' + ' bar' + ' feature-id' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var feature = fs[0]; expect(feature.getId()).to.be('feature-id'); }); it('can process extensions from trk, not trkpt', function() { var text = '' + ' ' + ' ' + ' feature-id' + ' ' + ' ' + ' ' + ' ' + ' another-feature-id' + ' ' + ' ' + ' ' + ' ' + ''; var fs = format.readFeatures(text); expect(fs).to.have.length(1); var feature = fs[0]; expect(feature.getId()).to.be('feature-id'); }); }); describe('write unsupported geometries', function() { beforeEach(function() { format = new _ol_format_GPX_(); }); it('does not fail', function() { var polygon = new _ol_geom_Polygon_( [[[0, 0], [2, 2], [4, 0], [0, 0]]]); var feature = new _ol_Feature_(polygon); var features = [feature]; var gpx = format.writeFeaturesNode(features); var expected = ''; expect(gpx).to.xmleql(_ol_xml_.parse(expected)); }); }); });