-
Notifications
You must be signed in to change notification settings - Fork 74
/
coastline.js
88 lines (70 loc) · 3.82 KB
/
coastline.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
var assert = require('assert'),
http = require('http'),
xml2js = require('xml2js'),
fs = require('fs'),
httpMocks = require('node-mocks-http'),
osmtogeojson = require('osmtogeojson'),
DOMParser = new require('@xmldom/xmldom').DOMParser
parser = new DOMParser();
var server = require('../TranslationServer.js');
describe('TranslationServer', function () {
this.timeout(5000);
// Strings used to build OSM XML features
var startNode = '<osm version="0.6" upload="true" generator="hootenanny">\
<node id="-13" lat="0.68270797876" lon="18.45141400736" >';
var startWay = '<osm version="0.6" upload="true" generator="hootenanny">\
<node id="-10" lat="0.68307256979" lon="18.45073925651" /> <node id="-13" lat="0.68270797876" lon="18.45141400736" />\
<way id="-19" >\
<nd ref="-10" /> <nd ref="-13" />';
var startArea = '<osm version="0.6" upload="true" generator="hootenanny">\
<node id="-10" lat="0.68307256979" lon="18.45073925651" /> <node id="-11" lat="0.68341620728" lon="18.45091527847" />\
<node id="-12" lat="0.68306209303" lon="18.45157116983" /> <node id="-13" lat="0.68270797876" lon="18.45141400736" />\
<way id="-19" >\
<nd ref="-10" /> <nd ref="-11" /> <nd ref="-12" /> <nd ref="-13" /> <nd ref="-10" />';
var endNode = '</node></osm>';
var endWay = '</way></osm>'; // NOTE: This is also for Areas as well
var schemas = [
'TDSv71',
'TDSv70',
'TDSv61',
'TDSv40',
'MGCP',
'GGDMv30'
];
schemas.forEach(schema => {
var fcode_key = (schema === 'MGCP') ? 'FCODE' : 'F_CODE';
it('should translate Coastline (BA010) from ' + schema + ' -> osm -> ' + schema, function() {
var data = startWay + '<tag k="' + fcode_key + '" v="BA010"/>' + endWay;
var osm_xml = server.handleInputs({osm: data, method: 'POST', translation: schema, path: '/translateFrom'});
// console.log(osm_xml);
xml2js.parseString(osm_xml, function(err, result) {
if (err) console.error(err);
assert.equal(result.osm.way[0].tag[0].$.k, "natural")
assert.equal(result.osm.way[0].tag[0].$.v, "coastline")
});
var trans_xml = server.handleInputs({osm: osm_xml, method: 'POST', translation: schema, path: '/translateTo'});
// console.log(tds_xml);
var xml = parser.parseFromString(trans_xml);
assert.equal(xml.getElementsByTagName("osm")[0].getAttribute("schema"), schema);
var tags = osmtogeojson(xml).features[0].properties;
assert.equal(tags[fcode_key], 'BA010');
});
it('should persist Land Water Boundary (BA010) FCODE and SLT=6 (mangrove) from ' + schema + ' -> osm -> ' + schema, function() {
var data = startWay + '<tag k="' + fcode_key + '" v="BA010"/><tag k="SLT" v="6" />' + endWay;
var osm_xml = server.handleInputs({osm: data, method: 'POST', translation: schema, path: '/translateFrom'});
// console.log(osm_xml);
xml2js.parseString(osm_xml, function(err, result) {
if (err) console.error(err);
assert.equal(result.osm.way[0].tag[0].$.k, 'shoreline:type')
assert.equal(result.osm.way[0].tag[0].$.v, 'mangrove')
assert.equal(result.osm.way[0].tag[1].$.k, 'natural')
assert.equal(result.osm.way[0].tag[1].$.v, 'coastline')
})
var trans_xml = server.handleInputs({osm: osm_xml, method: 'POST', translation: schema, path: '/translateTo'})
var xml = parser.parseFromString(trans_xml);
var tags = osmtogeojson(xml).features[0].properties;
assert.equal(tags[fcode_key], 'BA010');
assert.equal(tags['SLT'], '6');
});
});
});