diff --git a/lib/jellyfishService.js b/lib/jellyfishService.js index fa962a92..bc37dfa5 100644 --- a/lib/jellyfishService.js +++ b/lib/jellyfishService.js @@ -372,13 +372,14 @@ function createServer(serverConfig, mongoClient, seagullClient, userApiClient, g }, function(userId, cb) { getPrivatePair(userId, function(err, privatePair) { - cb(err, privatePair ? privatePair.id : null); + cb(err, userId, privatePair ? privatePair.id : null); }); }, - function(groupId, cb) { + function(userId, groupId, cb) { async.mapSeries( array, function(obj, cb) { + obj._userId = userId; obj._groupId = groupId; dataBroker.addDatum(obj, function(err){ if (err != null) { diff --git a/lib/schema/schema.js b/lib/schema/schema.js index 67bbba01..d9abea71 100644 --- a/lib/schema/schema.js +++ b/lib/schema/schema.js @@ -220,8 +220,8 @@ exports.isArrayWithValueSchema = function(schema){ }; }; -exports.requireXOR = function(datum, field1, field2) { - if ((datum[field1] == null && datum[field2] == null) || (datum[field1] != null && datum[field2] != null)) { +exports.requireXOR = function(datum, field1, field2) { + if ((datum[field1] == null && datum[field2] == null) || (datum[field1] != null && datum[field2] != null)) { throw except.IAE('should contain either %s or %s', field1, field2); } return true; @@ -384,6 +384,9 @@ exports.makeHandler = function(key, spec) { a thing from transformers, 'cause it's nice when things line up like that. */ function decepticon(datum, cb) { + if (datum._userId == null) { + return cb(new Error('_userId must be set on a datum')); + } if (datum._groupId == null) { return cb(new Error('_groupId must be set on a datum')); } @@ -501,4 +504,4 @@ exports.makeId = function(datum) { } return exports.generateId(datum, idFields); -}; \ No newline at end of file +}; diff --git a/lib/streamDAO.js b/lib/streamDAO.js index 407daf54..b35cf529 100644 --- a/lib/streamDAO.js +++ b/lib/streamDAO.js @@ -154,6 +154,7 @@ module.exports = function(mongoClient){ var self = this; pre.hasProperty(datum, 'id'); + pre.hasProperty(datum, '_userId'); pre.hasProperty(datum, '_groupId'); datum = _.clone(datum); @@ -180,6 +181,7 @@ module.exports = function(mongoClient){ }, updateDatum: function(datum, cb) { pre.hasProperty(datum, 'id'); + pre.hasProperty(datum, '_userId'); pre.hasProperty(datum, '_groupId'); updateDatumInternal(datum, 0, cb); }, diff --git a/test/api/basal/output.json b/test/api/basal/output.json index afe12326..eaa5259f 100644 --- a/test/api/basal/output.json +++ b/test/api/basal/output.json @@ -11,6 +11,7 @@ "duration": 21600000, "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "kmm427pfbrc6rugtmbuli8j4q61u17uk", "_version": 0, @@ -29,6 +30,7 @@ "duration": 21600000, "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "cjou7vscvp8ogv34d6vejootulqfn3jd", "_version": 0, @@ -47,6 +49,7 @@ "duration": 10800000, "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "cjou7vscvp8ogv34d6vejootulqfn3jd", "_version": 1, @@ -78,6 +81,7 @@ "deviceId": "tools", "uploadId": "tools" }, + "_userId": "abcd", "_groupId": "1234", "rate": 1, "id": "tn33bjb0241j9qh4jg9vdnf1g6k1g9r8", @@ -109,6 +113,7 @@ "deviceId": "tools", "uploadId": "tools" }, + "_userId": "abcd", "_groupId": "1234", "rate": 1, "id": "tn33bjb0241j9qh4jg9vdnf1g6k1g9r8", @@ -141,6 +146,7 @@ "deviceId": "tools", "uploadId": "tools" }, + "_userId": "abcd", "_groupId": "1234", "rate": 0.5, "id": "ga58m84ggkscldj30lehrg74n313skcj", @@ -160,6 +166,7 @@ "duration": 21600000, "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "lsqqotp92j1d25d3d3ac53dsh6rgjg94", "_version": 0, @@ -178,6 +185,7 @@ "duration": 14400000, "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "lsqqotp92j1d25d3d3ac53dsh6rgjg94", "_version": 1, @@ -202,10 +210,11 @@ "duration": 18000000, "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "kftn188l8rjuvma3qkd3iqg34t0plajp", "_version": 0, "_active": true, "_schemaVersion": 0 } -] \ No newline at end of file +] diff --git a/test/api/bolusAndWizard/output.json b/test/api/bolusAndWizard/output.json index 13e3d7aa..c6503ee6 100644 --- a/test/api/bolusAndWizard/output.json +++ b/test/api/bolusAndWizard/output.json @@ -9,6 +9,7 @@ "normal": 2.5, "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "oi4effqrtdsk8g353dcstbeg06pip5kp", "_version": 0, @@ -25,6 +26,7 @@ "normal": 1.5, "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "oi4effqrtdsk8g353dcstbeg06pip5kp", "_version": 1, @@ -42,6 +44,7 @@ "normal": 3.5, "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "hvnk1ngku6sqcpgav3t08f0m8lmhk6hv", "_version": 0, @@ -69,10 +72,11 @@ "deviceId": "tools", "uploadId": "tools", "bolus": "hvnk1ngku6sqcpgav3t08f0m8lmhk6hv", + "_userId": "abcd", "_groupId": "1234", "id": "vnputuqq0jtfhvi8tm7jinum5s24kkdq", "_version": 0, "_active": true, "_schemaVersion": 0 } -] \ No newline at end of file +] diff --git a/test/api/cbg/output.json b/test/api/cbg/output.json index 9f168921..73bd9513 100644 --- a/test/api/cbg/output.json +++ b/test/api/cbg/output.json @@ -9,6 +9,7 @@ "units": "mmol/L", "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "eb12p6h892pmd0hhccpt2r17muc407o0", "_version": 0, @@ -25,6 +26,7 @@ "units": "mmol/L", "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "ha2ogn1kenqqhseed504sqnanhnclg5s", "_version": 0, @@ -42,6 +44,7 @@ "units": "mmol/L", "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "i922lobl3kron3t81pjap31anopkspvb", "_version": 0, @@ -55,10 +58,11 @@ "units": "mmol/L", "deviceId": "DexHealthKit_Dexcom:com.dexcom.Share2:3.0.4.17", "uploadId": "upid_HealthKit_org.tidepool.blipnotes:1.1:242_2016-03-10T10:25:55-06:00", + "_userId": "abcd", "_groupId": "1234", "id": "nsikjhfaprplpq78hc7di2lu5qpt1e3k", "_version": 0, "_active": true, "_schemaVersion": 0 } -] \ No newline at end of file +] diff --git a/test/api/cgmSettings/output.json b/test/api/cgmSettings/output.json index bcfa7c8a..f16516a9 100644 --- a/test/api/cgmSettings/output.json +++ b/test/api/cgmSettings/output.json @@ -33,10 +33,11 @@ "rate": 0.16652243973136602 } }, + "_userId": "abcd", "_groupId": "1234", "id": "grop2783hkosd5lbv4sr9047a74vggch", "_version": 0, "_active": true, "_schemaVersion": 0 } -] \ No newline at end of file +] diff --git a/test/api/deviceEvent/output.json b/test/api/deviceEvent/output.json index e076a5ae..5d205773 100644 --- a/test/api/deviceEvent/output.json +++ b/test/api/deviceEvent/output.json @@ -10,6 +10,7 @@ "timezoneOffset": 0, "conversionOffset": 0, "status": "qdmhpmdd2v5v8uuv6otmqp7sjqlmb1cr", + "_userId": "abcd", "_groupId": "1234", "id": "64h7169livcae35c10d32ai721ugse79", "_version": 0, @@ -26,6 +27,7 @@ "timezoneOffset": 0, "conversionOffset": 0, "status": "qdmhpmdd2v5v8uuv6otmqp7sjqlmb1cr", + "_userId": "abcd", "_groupId": "1234", "id": "f4t0qjh45tgjep3vjsm2cn0isqg5u6ie", "_version": 0, @@ -45,6 +47,7 @@ "time": "2014-07-28T00:07:10.000Z", "timezoneOffset": 0, "conversionOffset": 0, + "_userId": "abcd", "_groupId": "1234", "annotations": [ { @@ -70,6 +73,7 @@ "time": "2014-07-28T00:07:10.000Z", "timezoneOffset": 0, "conversionOffset": 0, + "_userId": "abcd", "_groupId": "1234", "id": "qdmhpmdd2v5v8uuv6otmqp7sjqlmb1cr", "_version": 1, @@ -88,6 +92,7 @@ "time": "2014-07-28T00:12:03.000Z", "timezoneOffset": 0, "conversionOffset": 0, + "_userId": "abcd", "_groupId": "1234", "id": "ep1kqd57okpgke6c0g7al5j1f80cqg5m", "_version": 0, @@ -112,10 +117,11 @@ "conversionOffset": 0, "deviceId": "Paradigm Revel - 723", "uploadId": "test", + "_userId": "abcd", "_groupId": "1234", "id": "j80h9aqiioe8d8e41sh4ujf7ek28rppi", "_version": 0, "_active": true, "_schemaVersion": 0 } -] \ No newline at end of file +] diff --git a/test/api/ingestionApiTest.js b/test/api/ingestionApiTest.js index b10acdf9..b0f71996 100644 --- a/test/api/ingestionApiTest.js +++ b/test/api/ingestionApiTest.js @@ -1,15 +1,15 @@ /* * == BSD2 LICENSE == * Copyright (c) 2014, Tidepool Project - * + * * This program is free software; you can redistribute it and/or modify it under * the terms of the associated License, which is identical to the BSD 2-Clause * License as published by the Open Source Initiative at opensource.org. - * + * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the License for more details. - * + * * You should have received a copy of the License along with this program; if * not, you can obtain one from Tidepool Project at tidepool.org. * == BSD2 LICENSE == @@ -32,6 +32,7 @@ var mongoClient = require('../../lib/mongo/mongoClient.js')( var streamDAO = require('../../lib/streamDAO.js')(mongoClient); var dataBroker = require('../../lib/dataBroker.js')(streamDAO); +var userId = "abcd"; var groupId = "1234"; describe('ingestion API', function () { @@ -55,6 +56,7 @@ describe('ingestion API', function () { async.mapSeries( input, function(e, cb){ + e._userId = userId; e._groupId = groupId; dataBroker.addDatum(e, cb); }, @@ -66,7 +68,7 @@ describe('ingestion API', function () { mongoClient.withCollection('deviceData', done, function(coll, cb){ coll.find().sort({"time": 1, "id": 1, "_version": 1}).toArray(function(err, results){ expect(results.map(function(e){ return _.omit(e, 'createdTime', 'modifiedTime', "_id", '_archivedTime'); })) - .deep.equals(output.map(function(e){ e._groupId = groupId; return e; })); + .deep.equals(output.map(function(e){ e._userId = userId; e._groupId = groupId; return e; })); cb(err); }); }); @@ -80,6 +82,7 @@ describe('ingestion API', function () { async.mapSeries( badInput, function(e, cb){ + e._userId = userId; e._groupId = groupId; dataBroker.addDatum(e, cb); }, diff --git a/test/api/ketones/output.json b/test/api/ketones/output.json index a791f74a..0874d2b1 100644 --- a/test/api/ketones/output.json +++ b/test/api/ketones/output.json @@ -9,6 +9,7 @@ "units": "mmol/L", "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "si9lrlao50l4qi0hcc8bc5siaaq1se4a", "_version": 0, @@ -24,10 +25,11 @@ "value": "moderate", "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "d3o9aav2c4b1tc8purlb493ff82c4q8p", "_version": 0, "_active": true, "_schemaVersion": 0 } -] \ No newline at end of file +] diff --git a/test/api/pumpSettings/output.json b/test/api/pumpSettings/output.json index 3358bcfd..435a32f8 100644 --- a/test/api/pumpSettings/output.json +++ b/test/api/pumpSettings/output.json @@ -66,10 +66,11 @@ "start": 18000000 } ], + "_userId": "abcd", "_groupId": "1234", "id": "254a6gvhik3oucn5p5fblabem9rckbvg", "_version": 0, "_active": true, "_schemaVersion": 0 } -] \ No newline at end of file +] diff --git a/test/api/smbg/output.json b/test/api/smbg/output.json index d0541db6..3feb895c 100644 --- a/test/api/smbg/output.json +++ b/test/api/smbg/output.json @@ -10,6 +10,7 @@ "units": "mmol/L", "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "e2ihon9nqcro96c4uugb4ftdnr07nqok", "_version": 0, @@ -26,6 +27,7 @@ "units": "mmol/L", "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "c14eds071pp5gsirfmgmsclbcahs8th0", "_version": 0, @@ -42,6 +44,7 @@ "units": "mmol/L", "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "rk2htms97m7hipdu5lrso7ufd3pedm6n", "_version": 0, @@ -58,10 +61,11 @@ "units": "mmol/L", "deviceId": "tools", "uploadId": "tools", + "_userId": "abcd", "_groupId": "1234", "id": "urrkdln86rl4vhqckps6gnupg5njqk6n", "_version": 0, "_active": true, "_schemaVersion": 0 } -] \ No newline at end of file +] diff --git a/test/api/upload/output.json b/test/api/upload/output.json index aa012326..3701e87b 100644 --- a/test/api/upload/output.json +++ b/test/api/upload/output.json @@ -20,10 +20,11 @@ "deviceId": "multiple", "deviceSerialNumber": "multiple", "timeProcessing": "utc-bootstrapping", + "_userId": "abcd", "_groupId": "1234", "id": "7h3jc5jj5nl3bcu1gvs4j4k442pup1ef", "_version": 0, "_schemaVersion": 0, "_active": true } -] \ No newline at end of file +] diff --git a/test/schema/basalTest.js b/test/schema/basalTest.js index ccca802a..487d6674 100644 --- a/test/schema/basalTest.js +++ b/test/schema/basalTest.js @@ -44,6 +44,7 @@ describe('schema/basal.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; @@ -114,6 +115,7 @@ describe('schema/basal.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g', previous: previousMatches }; @@ -353,6 +355,7 @@ describe('schema/basal.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g', previous: previousMatches, suppressed: previousCutShort @@ -544,6 +547,7 @@ describe('schema/basal.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g', previous: previousMatches, suppressed: previousCutShort diff --git a/test/schema/bloodKetoneTest.js b/test/schema/bloodKetoneTest.js index 2b3b515c..00696969 100644 --- a/test/schema/bloodKetoneTest.js +++ b/test/schema/bloodKetoneTest.js @@ -33,6 +33,7 @@ var goodObject = { deviceId: 'test', uploadId: 'test', value: 1.12, + _userId: 'u', _groupId: 'g', units: 'mmol/L' }; @@ -52,4 +53,4 @@ describe('schema/bloodKetone.js', function(){ }); helper.testCommonFields(goodObject); -}); \ No newline at end of file +}); diff --git a/test/schema/bolusTest.js b/test/schema/bolusTest.js index 998f973a..50fbbf34 100644 --- a/test/schema/bolusTest.js +++ b/test/schema/bolusTest.js @@ -43,6 +43,7 @@ describe('schema/bolus.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; @@ -72,6 +73,7 @@ describe('schema/bolus.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; var objId = schema.makeId(goodObject); @@ -143,6 +145,7 @@ describe('schema/bolus.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; var objId = schema.makeId(goodObject); @@ -256,6 +259,7 @@ describe('schema/bolus.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; var objId = schema.makeId(goodObject); diff --git a/test/schema/cbgTest.js b/test/schema/cbgTest.js index 18bd7c1b..32bc6282 100644 --- a/test/schema/cbgTest.js +++ b/test/schema/cbgTest.js @@ -35,6 +35,7 @@ var goodObject = { value: 1.12, isig: 24.37, units: 'mg/dL', + _userId: 'u', _groupId: 'g' }; @@ -59,4 +60,4 @@ describe('schema/cbg.js', function(){ }); helper.testCommonFields(goodObject); -}); \ No newline at end of file +}); diff --git a/test/schema/cgmSettingsTest.js b/test/schema/cgmSettingsTest.js index 81d6e110..1799e4d6 100644 --- a/test/schema/cgmSettingsTest.js +++ b/test/schema/cgmSettingsTest.js @@ -58,6 +58,7 @@ var goodObject = { "rate": 0.16652243973136602 } }, + _userId: 'u', _groupId: 'g' }; @@ -141,4 +142,4 @@ describe('schema/cgmSettings.js', function () { }); helper.testCommonFields(goodObject); -}); \ No newline at end of file +}); diff --git a/test/schema/deviceEventTest.js b/test/schema/deviceEventTest.js index 11ea203e..11d9369f 100644 --- a/test/schema/deviceEventTest.js +++ b/test/schema/deviceEventTest.js @@ -43,6 +43,7 @@ describe('schema/deviceEvent.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; @@ -91,6 +92,7 @@ describe('schema/deviceEvent.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; @@ -105,6 +107,7 @@ describe('schema/deviceEvent.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; @@ -119,6 +122,7 @@ describe('schema/deviceEvent.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; @@ -283,6 +287,7 @@ describe('schema/deviceEvent.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; @@ -315,6 +320,7 @@ describe('schema/deviceEvent.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }}), 'status'); }); @@ -333,6 +339,7 @@ describe('schema/deviceEvent.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; @@ -349,6 +356,7 @@ describe('schema/deviceEvent.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }}), 'status'); }); @@ -367,6 +375,7 @@ describe('schema/deviceEvent.js', function(){ conversionOffset: 0, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; @@ -402,6 +411,7 @@ describe('schema/deviceEvent.js', function(){ conversionOffset: 120000, deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g' }; diff --git a/test/schema/foodTest.js b/test/schema/foodTest.js index b2a5be3b..99431551 100644 --- a/test/schema/foodTest.js +++ b/test/schema/foodTest.js @@ -1,15 +1,15 @@ /* * == BSD2 LICENSE == * Copyright (c) 2014, Tidepool Project - * + * * This program is free software; you can redistribute it and/or modify it under * the terms of the associated License, which is identical to the BSD 2-Clause * License as published by the Open Source Initiative at opensource.org. - * + * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the License for more details. - * + * * You should have received a copy of the License along with this program; if * not, you can obtain one from Tidepool Project at tidepool.org. * == BSD2 LICENSE == @@ -32,6 +32,7 @@ var goodObject = { deviceId: 'test', uploadId: 'test', carbs: 73, + _userId: 'u', _groupId: 'g' }; @@ -43,4 +44,4 @@ describe('schema/food.js', function(){ }); helper.testCommonFields(goodObject); -}); \ No newline at end of file +}); diff --git a/test/schema/grabbagTest.js b/test/schema/grabbagTest.js index ae799ae2..629ca519 100644 --- a/test/schema/grabbagTest.js +++ b/test/schema/grabbagTest.js @@ -1,15 +1,15 @@ /* * == BSD2 LICENSE == * Copyright (c) 2014, Tidepool Project - * + * * This program is free software; you can redistribute it and/or modify it under * the terms of the associated License, which is identical to the BSD 2-Clause * License as published by the Open Source Initiative at opensource.org. - * + * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the License for more details. - * + * * You should have received a copy of the License along with this program; if * not, you can obtain one from Tidepool Project at tidepool.org. * == BSD2 LICENSE == @@ -34,6 +34,7 @@ var goodObject = { uploadId: 'test', value: 1.12, isig: 24.37, + _userId: 'u', _groupId: 'g' }; @@ -44,4 +45,4 @@ describe('schema/grabbag.js', function(){ }); helper.testCommonFields(goodObject); -}); \ No newline at end of file +}); diff --git a/test/schema/noteTest.js b/test/schema/noteTest.js index 0f03ba1c..39f3aca0 100644 --- a/test/schema/noteTest.js +++ b/test/schema/noteTest.js @@ -1,15 +1,15 @@ /* * == BSD2 LICENSE == * Copyright (c) 2014, Tidepool Project - * + * * This program is free software; you can redistribute it and/or modify it under * the terms of the associated License, which is identical to the BSD 2-Clause * License as published by the Open Source Initiative at opensource.org. - * + * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the License for more details. - * + * * You should have received a copy of the License along with this program; if * not, you can obtain one from Tidepool Project at tidepool.org. * == BSD2 LICENSE == @@ -38,6 +38,7 @@ var goodObject = { displayTime: '2014-01-01T07:00:00.000Z', deviceId: 'test', uploadId: 'test', + _userId: 'u', _groupId: 'g', shortText: '1234', text: 'Howdy ho, this is a note', @@ -51,6 +52,7 @@ var reference = { deviceId: 'test', uploadId: 'test', value: 1.12, + _userId: 'u', _groupId: 'g' }; @@ -119,4 +121,4 @@ describe('schema/note.js', function(){ }); helper.testCommonFields(goodObject); -}); \ No newline at end of file +}); diff --git a/test/schema/pumpSettingsTest.js b/test/schema/pumpSettingsTest.js index 2b89dcf6..63190f4b 100644 --- a/test/schema/pumpSettingsTest.js +++ b/test/schema/pumpSettingsTest.js @@ -59,6 +59,7 @@ var goodObject = { { "low": 5.5, "high": 6.7, "start": 0 }, { "low": 5, "high": 6.1, "start": 18000000 } ], + _userId: 'u', _groupId: 'g' }; @@ -201,7 +202,7 @@ describe('schema/pumpSettings.js', function () { it('still converts units in multiple schedules', function(done) { var multiConvert = _.cloneDeep(multiIS); multiConvert.units.bg = 'mg/dL'; - multiConvert.insulinSensitivities = { + multiConvert.insulinSensitivities = { "weekday": [ { "amount": 35, "start": 0 }, { "amount": 35, "start": 18000000 } ], "weekend": [ { "amount": 50, "start": 0 }, @@ -239,7 +240,7 @@ describe('schema/pumpSettings.js', function () { it('still converts units with multiple schedules', function(done) { var multiConvert = _.cloneDeep(multiBgTargets); multiConvert.units.bg = 'mg/dL'; - multiConvert.bgTargets = { + multiConvert.bgTargets = { "weekday": [ { target: 90, start: 0 }, { target: 100, start: 10800000 } @@ -415,4 +416,4 @@ describe('schema/pumpSettings.js', function () { }); helper.testCommonFields(goodObject); -}); \ No newline at end of file +}); diff --git a/test/schema/smbgTest.js b/test/schema/smbgTest.js index 85fe6ee3..843c4c47 100644 --- a/test/schema/smbgTest.js +++ b/test/schema/smbgTest.js @@ -36,6 +36,7 @@ var goodObject = { uploadId: 'test', value: 1.12, units: 'mg/dL', + _userId: 'u', _groupId: 'g' }; diff --git a/test/schema/uploadTest.js b/test/schema/uploadTest.js index 02213040..c3c22821 100644 --- a/test/schema/uploadTest.js +++ b/test/schema/uploadTest.js @@ -39,6 +39,7 @@ var goodObject = { deviceTags: ['insulin-pump'], deviceId: '123-my-upload-id', timeProcessing: 'utc-bootstrapping', + _userId: 'u', _groupId: 'g' }; @@ -57,6 +58,7 @@ var badTidepoolUploaderObject = { deviceSerialNumber: '12345', deviceTags: ['insulin-pump'], deviceId: '123-my-upload-id', + _userId: 'u', _groupId: 'g' }; @@ -140,4 +142,4 @@ describe('schema/upload.js', function(){ helper.expectRejection(obj, 'timeProcessing', done); }); }); -}); \ No newline at end of file +}); diff --git a/test/schema/urineKetoneTest.js b/test/schema/urineKetoneTest.js index 673aacd2..86e51c1e 100644 --- a/test/schema/urineKetoneTest.js +++ b/test/schema/urineKetoneTest.js @@ -33,6 +33,7 @@ var goodObject = { deviceId: 'test', uploadId: 'test', value: 'small', + _userId: 'u', _groupId: 'g' }; @@ -45,4 +46,4 @@ describe('schema/urineKetone.js', function(){ }); helper.testCommonFields(goodObject); -}); \ No newline at end of file +}); diff --git a/test/schema/wizardTest.js b/test/schema/wizardTest.js index 039d1859..51ed9b46 100644 --- a/test/schema/wizardTest.js +++ b/test/schema/wizardTest.js @@ -51,6 +51,7 @@ var goodObject = { deviceId: 'test' }, units: 'mg/dL', + _userId: 'u', _groupId: 'g' }; @@ -259,4 +260,4 @@ describe('schema/wizard.js', function(){ }); helper.testCommonFields(goodObject); -}); \ No newline at end of file +}); diff --git a/test/streamDAOTest.js b/test/streamDAOTest.js index 0a1342e3..cbbeecef 100644 --- a/test/streamDAOTest.js +++ b/test/streamDAOTest.js @@ -1,15 +1,15 @@ /* * == BSD2 LICENSE == * Copyright (c) 2014, Tidepool Project - * + * * This program is free software; you can redistribute it and/or modify it under * the terms of the associated License, which is identical to the BSD 2-Clause * License as published by the Open Source Initiative at opensource.org. - * + * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the License for more details. - * + * * You should have received a copy of the License along with this program; if * not, you can obtain one from Tidepool Project at tidepool.org. * == BSD2 LICENSE == @@ -56,7 +56,7 @@ describe('streamDAO', function(){ describe('insert', function(){ it('should be able to find a value that is there', function(done){ var now = Date.now(); - streamDAO.insertDatum({id: 'abcd', v: 1, _groupId: 'g'}, function(err){ + streamDAO.insertDatum({id: 'abcd', v: 1, _userId: 'u', _groupId: 'g'}, function(err){ if (err != null) { return done(err); } @@ -65,7 +65,7 @@ describe('streamDAO', function(){ expect(datum).to.exist; expect(new Date(datum.createdTime).valueOf()).that.is.within(now, Date.now()); expect(_.omit(datum, 'createdTime', '_id')).to.deep.equals( - { id: 'abcd', v: 1, _groupId: 'g', _version: 0, _schemaVersion: 0, _active: true } + { id: 'abcd', v: 1, _userId: 'u', _groupId: 'g', _version: 0, _schemaVersion: 0, _active: true } ); done(err); @@ -78,7 +78,7 @@ describe('streamDAO', function(){ var createdTime = ''; beforeEach(function(done){ - streamDAO.insertDatum({id: 'abcd', v: 1, f: 'a', _groupId: 'g'}, function(err){ + streamDAO.insertDatum({id: 'abcd', v: 1, f: 'a', _userId: 'u', _groupId: 'g'}, function(err){ if (err != null) { return done(err); } @@ -91,7 +91,7 @@ describe('streamDAO', function(){ }); it('cannot update a value that does not exist', function(done){ - streamDAO.updateDatum({id: 'abcde', f: 'a', v: 2828, _groupId: 'g'}, function(err){ + streamDAO.updateDatum({id: 'abcde', f: 'a', v: 2828, _userId: 'u', _groupId: 'g'}, function(err){ expect(err).to.exist; streamDAO.getDatum('abcde', 'g', function(err, datum){ @@ -103,7 +103,7 @@ describe('streamDAO', function(){ it('should be able to update a value that is there', function(done){ var now = Date.now(); - streamDAO.updateDatum({id: 'abcd', f: 'a', v: 2828, _groupId: 'g', createdTime: createdTime}, function(err){ + streamDAO.updateDatum({id: 'abcd', f: 'a', v: 2828, _userId: 'u', _groupId: 'g', createdTime: createdTime}, function(err){ if (err != null) { return done(err); } @@ -112,7 +112,7 @@ describe('streamDAO', function(){ expect(datum).to.exist; expect(new Date(datum.modifiedTime).valueOf()).that.is.within(now, Date.now()); expect(_.omit(datum, 'modifiedTime', '_archivedTime', '_id')).to.deep.equals( - { id: 'abcd', f: 'a', v: 2828, _groupId: 'g', createdTime: createdTime, _version: 1, _active: true } + { id: 'abcd', f: 'a', v: 2828, _userId: 'u', _groupId: 'g', createdTime: createdTime, _version: 1, _active: true } ); var overwrittenId = datum._id + '_0'; @@ -121,7 +121,7 @@ describe('streamDAO', function(){ expect(elements).to.have.length(1); expect(elements[0]._archivedTime).that.is.within(now, Date.now()); expect(_.omit(elements[0], '_archivedTime')).to.deep.equals( - { _id: overwrittenId, id: 'abcd', f: 'a', _groupId: 'g', v: 1, createdTime: createdTime, _version: 0, _schemaVersion: 0, _active: false } + { _id: overwrittenId, id: 'abcd', f: 'a', _userId: 'u', _groupId: 'g', v: 1, createdTime: createdTime, _version: 0, _schemaVersion: 0, _active: false } ); done(err); @@ -159,16 +159,16 @@ describe('streamDAO', function(){ } var expectedId = misc.generateId(['abcd', 'g']); - streamDAO.updateDatum({id: 'abcd', f: 'a', v: 2828, _groupId: 'g'}, theCallback); - streamDAO.updateDatum({id: 'abcd', f: 'a', v: 2829, _groupId: 'g'}, theCallback); + streamDAO.updateDatum({id: 'abcd', f: 'a', v: 2828, _userId: 'u', _groupId: 'g'}, theCallback); + streamDAO.updateDatum({id: 'abcd', f: 'a', v: 2829, _userId: 'u', _groupId: 'g'}, theCallback); }); }); describe('getDatumBefore', function(){ var events = [ - { id: 'ab', time: '2014-01-01T00:00:00.000Z', type: 'none', deviceId: 'a', source: 's', _groupId: 'g', val: 0 }, - { id: 'abc', time: '2014-01-01T01:00:00.000Z', type: 'none', deviceId: 'a', source: 's', _groupId: 'g', val: 1 }, - { id: 'abcd', time: '2014-01-01T02:00:00.000Z', type: 'none', deviceId: 'a', source: 's', _groupId: 'g', val: 2 } + { id: 'ab', time: '2014-01-01T00:00:00.000Z', type: 'none', deviceId: 'a', source: 's', _userId: 'u', _groupId: 'g', val: 0 }, + { id: 'abc', time: '2014-01-01T01:00:00.000Z', type: 'none', deviceId: 'a', source: 's', _userId: 'u', _groupId: 'g', val: 1 }, + { id: 'abcd', time: '2014-01-01T02:00:00.000Z', type: 'none', deviceId: 'a', source: 's', _userId: 'u', _groupId: 'g', val: 2 } ]; beforeEach(function(done){ @@ -177,7 +177,7 @@ describe('streamDAO', function(){ it('returns null if nothing before', function(done){ streamDAO.getDatumBefore( - { time: '2014-01-01T00:00:00.000Z', type: 'none', deviceId: 'a', source: 's', _groupId: 'g' }, + { time: '2014-01-01T00:00:00.000Z', type: 'none', deviceId: 'a', source: 's', _userId: 'u', _groupId: 'g' }, function(err, datum){ expect(datum).to.equal.null; done(err); @@ -186,7 +186,7 @@ describe('streamDAO', function(){ }); describe('find previous', function(){ - var matchingEvent = { time: '2014-01-01T01:30:00.000Z', type: 'none', deviceId: 'a', source: 's', _groupId: 'g' }; + var matchingEvent = { time: '2014-01-01T01:30:00.000Z', type: 'none', deviceId: 'a', source: 's', _userId: 'u', _groupId: 'g' }; it('returns the previous event', function(done){ streamDAO.getDatumBefore(