Track points
This commit is contained in:
parent
b0f767721a
commit
16ca39a160
|
@ -2,6 +2,7 @@ import { initDb } from '.';
|
||||||
import uri from '../lib/ids';
|
import uri from '../lib/ids';
|
||||||
import { getFamily } from './lib';
|
import { getFamily } from './lib';
|
||||||
import { putNewTrk } from './trk';
|
import { putNewTrk } from './trk';
|
||||||
|
import { putNewTrkpt } from './trkpt';
|
||||||
import { putNewTrkseg } from './trkseg';
|
import { putNewTrkseg } from './trkseg';
|
||||||
|
|
||||||
declare global {
|
declare global {
|
||||||
|
@ -134,6 +135,46 @@ Object {
|
||||||
],
|
],
|
||||||
"total_rows": 6,
|
"total_rows": 6,
|
||||||
}
|
}
|
||||||
|
`);
|
||||||
|
});
|
||||||
|
test('returns four rows after a gpx and a track point have been inserted.', async () => {
|
||||||
|
await putNewTrkpt();
|
||||||
|
const allDocs: any = await getFamily(uri('gpx', { gpx: '0' }));
|
||||||
|
expect(allDocs).toMatchInlineSnapshot(`
|
||||||
|
Object {
|
||||||
|
"offset": 0,
|
||||||
|
"rows": Array [
|
||||||
|
Object {
|
||||||
|
"id": "gpx/0",
|
||||||
|
"key": "gpx/0",
|
||||||
|
"value": Object {
|
||||||
|
"rev": "1-98d42c99fcf471a500b0506a60e77559",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Object {
|
||||||
|
"id": "gpx/0/2trk/00000",
|
||||||
|
"key": "gpx/0/2trk/00000",
|
||||||
|
"value": Object {
|
||||||
|
"rev": "1-1e197ef8965a436730f80cabaaaa6f70",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Object {
|
||||||
|
"id": "gpx/0/2trk/00000/00000",
|
||||||
|
"key": "gpx/0/2trk/00000/00000",
|
||||||
|
"value": Object {
|
||||||
|
"rev": "1-33cb714b4d5553cc20fc7a753c63cf51",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Object {
|
||||||
|
"id": "gpx/0/2trk/00000/00000/00000",
|
||||||
|
"key": "gpx/0/2trk/00000/00000/00000",
|
||||||
|
"value": Object {
|
||||||
|
"rev": "1-c88eea2fc5a5637322a3f3357b49618f",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
"total_rows": 7,
|
||||||
|
}
|
||||||
`);
|
`);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -29,5 +29,5 @@ export const putNewTrk = async (id?: IdTrk | IdGpx) => {
|
||||||
},
|
},
|
||||||
emptyTrk
|
emptyTrk
|
||||||
);
|
);
|
||||||
return finalId;
|
return finalId as IdTrk;
|
||||||
};
|
};
|
||||||
|
|
|
@ -0,0 +1,79 @@
|
||||||
|
import { putNewTrkpt } from './trkpt';
|
||||||
|
|
||||||
|
declare global {
|
||||||
|
var db: any;
|
||||||
|
var dbReady: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
const originalDb = globalThis.db;
|
||||||
|
const originalDateNow = globalThis.Date.now;
|
||||||
|
|
||||||
|
describe('The trkpt module', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
globalThis.db = { put: jest.fn() };
|
||||||
|
globalThis.Date.now = () => 0;
|
||||||
|
});
|
||||||
|
afterEach(() => {
|
||||||
|
globalThis.db = originalDb;
|
||||||
|
globalThis.Date.now = originalDateNow;
|
||||||
|
});
|
||||||
|
test('db.put() a new trkpt when required', async () => {
|
||||||
|
putNewTrkpt({
|
||||||
|
gpx: 'gpxId',
|
||||||
|
trk: 'trkid',
|
||||||
|
trkseg: 'trksegid',
|
||||||
|
trkpt: 'trkptid',
|
||||||
|
});
|
||||||
|
await expect(globalThis.db.put).toBeCalledWith({
|
||||||
|
_id: 'gpx/gpxId/2trk/trkid/trksegid/trkptid',
|
||||||
|
_rev: undefined,
|
||||||
|
doc: {
|
||||||
|
$: { lat: 0, lon: 0 },
|
||||||
|
ageofdgpsdata: undefined,
|
||||||
|
cmt: undefined,
|
||||||
|
desc: undefined,
|
||||||
|
dgpsid: undefined,
|
||||||
|
ele: undefined,
|
||||||
|
extensions: {
|
||||||
|
'dyo:accuracy': undefined,
|
||||||
|
'dyo:batterylevel': undefined,
|
||||||
|
'dyo:course': undefined,
|
||||||
|
'dyo:speed': undefined,
|
||||||
|
'dyo:useragent': undefined,
|
||||||
|
},
|
||||||
|
fix: undefined,
|
||||||
|
geoidheight: undefined,
|
||||||
|
hdop: undefined,
|
||||||
|
link: undefined,
|
||||||
|
magvar: undefined,
|
||||||
|
name: undefined,
|
||||||
|
pdop: undefined,
|
||||||
|
sat: undefined,
|
||||||
|
src: undefined,
|
||||||
|
sym: undefined,
|
||||||
|
time: undefined,
|
||||||
|
type: undefined,
|
||||||
|
vdop: undefined,
|
||||||
|
},
|
||||||
|
type: 'trkpt',
|
||||||
|
});
|
||||||
|
});
|
||||||
|
test('db.put() generates an id for the trk if needed', async () => {
|
||||||
|
const id = await putNewTrkpt({ gpx: 'gpxId' });
|
||||||
|
expect(id).toEqual({
|
||||||
|
gpx: 'gpxId',
|
||||||
|
trk: '00000',
|
||||||
|
trkseg: '00000',
|
||||||
|
trkpt: '00000',
|
||||||
|
});
|
||||||
|
});
|
||||||
|
test('db.put() generates ids for both gpx and trk if needed', async () => {
|
||||||
|
const id = await putNewTrkpt();
|
||||||
|
expect(id).toEqual({
|
||||||
|
gpx: '0',
|
||||||
|
trk: '00000',
|
||||||
|
trkseg: '00000',
|
||||||
|
trkpt: '00000',
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,50 @@
|
||||||
|
import getUri from '../lib/ids';
|
||||||
|
import { put } from './lib';
|
||||||
|
import { putNewTrkseg } from './trkseg';
|
||||||
|
|
||||||
|
const emptyTrkpt: Wpt = {
|
||||||
|
$: { lat: 0, lon: 0 },
|
||||||
|
ele: undefined,
|
||||||
|
time: undefined,
|
||||||
|
magvar: undefined,
|
||||||
|
geoidheight: undefined,
|
||||||
|
name: undefined,
|
||||||
|
cmt: undefined,
|
||||||
|
desc: undefined,
|
||||||
|
src: undefined,
|
||||||
|
link: undefined,
|
||||||
|
sym: undefined,
|
||||||
|
type: undefined,
|
||||||
|
fix: undefined,
|
||||||
|
sat: undefined,
|
||||||
|
hdop: undefined,
|
||||||
|
vdop: undefined,
|
||||||
|
pdop: undefined,
|
||||||
|
ageofdgpsdata: undefined,
|
||||||
|
dgpsid: undefined,
|
||||||
|
extensions: {
|
||||||
|
'dyo:speed': undefined,
|
||||||
|
'dyo:course': undefined,
|
||||||
|
'dyo:accuracy': undefined,
|
||||||
|
'dyo:batterylevel': undefined,
|
||||||
|
'dyo:useragent': undefined,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
export const putNewTrkpt = async (id?: IdTrk | IdGpx | IdTrkseg | IdTrkpt) => {
|
||||||
|
let finalId = { ...id };
|
||||||
|
if (!('trkpt' in finalId)) {
|
||||||
|
const trksegId = await putNewTrkseg(id);
|
||||||
|
finalId = { ...trksegId, trkpt: '00000' };
|
||||||
|
}
|
||||||
|
const uri = getUri('trkpt', finalId);
|
||||||
|
await put(
|
||||||
|
uri,
|
||||||
|
'trkpt',
|
||||||
|
(trkpt) => {
|
||||||
|
return trkpt;
|
||||||
|
},
|
||||||
|
emptyTrkpt
|
||||||
|
);
|
||||||
|
return finalId;
|
||||||
|
};
|
|
@ -22,5 +22,5 @@ export const putNewTrkseg = async (id?: IdTrk | IdGpx | IdTrkseg) => {
|
||||||
},
|
},
|
||||||
emptyTrkseg
|
emptyTrkseg
|
||||||
);
|
);
|
||||||
return finalId;
|
return finalId as IdTrkseg;
|
||||||
};
|
};
|
||||||
|
|
|
@ -31,7 +31,13 @@ interface Metadata {
|
||||||
extensions?: Extensions;
|
extensions?: Extensions;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface Extensions {}
|
interface Extensions {
|
||||||
|
'dyo:speed'?: number;
|
||||||
|
'dyo:course'?: number;
|
||||||
|
'dyo:accuracy'?: number;
|
||||||
|
'dyo:batterylevel'?: number;
|
||||||
|
'dyo:useragent'?: string;
|
||||||
|
}
|
||||||
|
|
||||||
interface Trk {
|
interface Trk {
|
||||||
name?: string;
|
name?: string;
|
||||||
|
@ -56,6 +62,34 @@ interface Link_ {
|
||||||
}
|
}
|
||||||
|
|
||||||
interface Trkseg {
|
interface Trkseg {
|
||||||
trkpt: any[];
|
trkpt?: Wpt[];
|
||||||
extensions?: Extensions;
|
extensions?: Extensions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
interface Wpt {
|
||||||
|
$: Trkpt_;
|
||||||
|
ele?: number;
|
||||||
|
time?: string;
|
||||||
|
magvar?: number;
|
||||||
|
geoidheight?: number;
|
||||||
|
name?: string;
|
||||||
|
cmt?: string;
|
||||||
|
desc?: string;
|
||||||
|
src?: string;
|
||||||
|
link?: Link;
|
||||||
|
sym?: string;
|
||||||
|
type?: string;
|
||||||
|
fix?: string;
|
||||||
|
sat?: number;
|
||||||
|
hdop?: number;
|
||||||
|
vdop?: number;
|
||||||
|
pdop?: number;
|
||||||
|
ageofdgpsdata?: number;
|
||||||
|
dgpsid?: number;
|
||||||
|
extensions: Extensions;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Trkpt_ {
|
||||||
|
lat: number;
|
||||||
|
lon: number;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue