loopback/test/geo-point.test.js

69 lines
2.2 KiB
JavaScript

// Copyright IBM Corp. 2013,2018. All Rights Reserved.
// Node module: loopback
// This file is licensed under the MIT License.
// License text available at https://opensource.org/licenses/MIT
'use strict';
const assert = require('assert');
const loopback = require('../');
const GeoPoint = loopback.GeoPoint;
describe('GeoPoint', function() {
describe('geoPoint.distanceTo(geoPoint, options)', function() {
it('Get the distance to another `GeoPoint`', function() {
const here = new GeoPoint({lat: 10, lng: 10});
const there = new GeoPoint({lat: 5, lng: 5});
const distance = here.distanceTo(there, {type: 'meters'});
assert.equal(Math.floor(distance), 782777);
});
});
describe('GeoPoint.distanceBetween(a, b, options)', function() {
it('Get the distance between two points', function() {
const here = new GeoPoint({lat: 10, lng: 10});
const there = new GeoPoint({lat: 5, lng: 5});
const distance = GeoPoint.distanceBetween(here, there, {type: 'feet'});
assert.equal(Math.floor(distance), 2568169);
});
});
describe('GeoPoint()', function() {
it('Create from string', function() {
const point = new GeoPoint('1.234,5.678');
assert.equal(point.lat, 1.234);
assert.equal(point.lng, 5.678);
const point2 = new GeoPoint('1.222, 5.333');
assert.equal(point2.lat, 1.222);
assert.equal(point2.lng, 5.333);
const point3 = new GeoPoint('1.333, 5.111');
assert.equal(point3.lat, 1.333);
assert.equal(point3.lng, 5.111);
});
it('Serialize as string', function() {
const str = '1.234,5.678';
const point = new GeoPoint(str);
assert.equal(point.toString(), str);
});
it('Create from array', function() {
const point = new GeoPoint([5.555, 6.777]);
assert.equal(point.lat, 5.555);
assert.equal(point.lng, 6.777);
});
it('Create as Model property', function() {
const Model = loopback.createModel('geo-model', {
geo: {type: 'GeoPoint'},
});
const m = new Model({
geo: '1.222,3.444',
});
assert(m.geo instanceof GeoPoint);
assert.equal(m.geo.lat, 1.222);
assert.equal(m.geo.lng, 3.444);
});
});
});