forked from naturalatlas/node-gdal
-
Notifications
You must be signed in to change notification settings - Fork 0
/
open_shp.test.js
79 lines (71 loc) · 2.22 KB
/
open_shp.test.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
var gdal = require('../lib/gdal.js');
var path = require('path');
var assert = require('chai').assert;
describe('Open', function() {
afterEach(gc);
describe('ESRI Shapefile', function() {
var filename, ds;
it('should not throw', function() {
filename = path.join(__dirname, 'data/shp/sample.shp');
ds = gdal.open(filename);
});
it('should be able to read layer count', function() {
assert.equal(ds.layers.count(), 1);
});
describe('layer', function() {
var layer;
before(function() { layer = ds.layers.get(0); });
it('should have all fields defined', function() {
assert.equal(layer.fields.count(), 8);
assert.deepEqual(layer.fields.getNames(), [
'path',
'name',
'type',
'long_name',
'fips_num',
'fips',
'state_fips',
'state_abbr'
]);
});
describe('field properties', function() {
var integerDs, integerLayer;
before(function() {
integerDs = gdal.open(path.join(__dirname, 'data/shp/sample_int64.shp'));
integerLayer = integerDs.layers.get(0);
});
it('should evaluate datatypes', function() {
var version_major = Number(gdal.version.split('.')[0]);
assert.equal(integerLayer.fields.get(0).type, 'string');
assert.equal(integerLayer.fields.get(3).type, version_major >= 2 ? 'integer64' : 'integer');
assert.equal(integerLayer.fields.get(5).type, 'real');
assert.equal(integerLayer.fields.get(10).type, 'date');
});
});
describe('features', function() {
it('should be readable', function() {
assert.equal(layer.features.count(), 23);
var feature = layer.features.get(0);
var fields = feature.fields.toObject();
assert.deepEqual(fields, {
'fips': 'US56029',
'fips_num': '56029',
'long_name': 'Park County',
'name': 'Park',
'path': 'US.WY.PARK',
'state_abbr': 'WY',
'state_fips': '56',
'type': 'County'
});
});
});
describe('integer64 fields', function() {
it('should be readable', function() {
var integerDs = gdal.open(path.join(__dirname, 'data/shp/sample_int64.shp'));
var integerLayer = integerDs.layers.get(0);
assert.equal(integerLayer.features.get(0).fields.get(3), 1);
});
});
});
});
});