Skip to content

Commit

Permalink
Made treatRawData tests pass
Browse files Browse the repository at this point in the history
  • Loading branch information
louischatriot committed Dec 8, 2013
1 parent 099584d commit 34a3ba2
Show file tree
Hide file tree
Showing 6 changed files with 36 additions and 18 deletions.
7 changes: 5 additions & 2 deletions lib/datastore.js
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ function Datastore (options) {
// binary is always well-balanced
this.indexes = {};
this.indexes._id = new Index({ fieldName: '_id', unique: true });

if (this.autoload) { this.loadDatabase(); }
}

Expand Down Expand Up @@ -111,7 +111,10 @@ Datastore.prototype.ensureIndex = function (options, cb) {
return callback(e);
}

return callback(null);
this.persistence.persistNewState([{ $$indexCreated: options }], function (err) {
if (err) { return callback(err); }
return callback(null);
});
};


Expand Down
2 changes: 1 addition & 1 deletion lib/model.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ var dateToJSON = function () { return { $$date: this.getTime() }; }
* But you really need to want it to trigger such behaviour, even when warned not to use '$' at the beginning of the field names...
*/
function checkKey (k, v) {
if (k[0] === '$' && !(k === '$$date' && typeof v === 'number') && !(k === '$$deleted' && v === true)) {
if (k[0] === '$' && !(k === '$$date' && typeof v === 'number') && !(k === '$$deleted' && v === true) && !(k === '$$indexCreated')) {
throw 'Field names cannot begin with the $ character';
}

Expand Down
24 changes: 19 additions & 5 deletions lib/persistence.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ var fs = require('fs')
, async = require('async')
, mkdirp = require('mkdirp')
, customUtils = require('./customUtils')
, Index = require('./indexes')
;


Expand Down Expand Up @@ -193,8 +194,10 @@ Persistence.prototype.persistNewState = function (newDocs, cb) {
Persistence.treatRawData = function (rawData) {
var data = rawData.split('\n')
, dataById = {}
, res = []
, i;
, tdata = []
, i
, indexes = {}
;

for (i = 0; i < data.length; i += 1) {
var doc;
Expand All @@ -207,16 +210,18 @@ Persistence.treatRawData = function (rawData) {
} else {
dataById[doc._id] = doc;
}
} else if (doc.$$indexCreated && doc.$$indexCreated.fieldName != undefined) {
indexes[doc.$$indexCreated.fieldName] = doc.$$indexCreated;
}
} catch (e) {
}
}

Object.keys(dataById).forEach(function (k) {
res.push(dataById[k]);
tdata.push(dataById[k]);
});

return res;
return { data: tdata, indexes: indexes };
};


Expand Down Expand Up @@ -246,6 +251,9 @@ Persistence.prototype.ensureDatafileIntegrity = function (callback) {

/**
* Load the database
* 1) Create all indexes
* 2) Insert all data
* 3) Compact the database
* This means pulling data out of the data file or creating it if it doesn't exist
* Also, all data is persisted right away, which has the effect of compacting the database file
* This operation is very quick at startup for a big collection (60ms for ~10k docs)
Expand All @@ -269,8 +277,14 @@ Persistence.prototype.loadDatabase = function (cb) {
if (err) { return cb(err); }
var treatedData = Persistence.treatRawData(rawData);

// Recreate all indexes in the datafile
Object.keys(treatedData.indexes).forEach(function (key) {
self.db.indexes[key] = new Index(treatedData.indexes[key]);
});

// Fill cached database (i.e. all indexes) with data
try {
self.db.resetIndexes(treatedData);
self.db.resetIndexes(treatedData.data);
} catch (e) {
self.db.resetIndexes(); // Rollback any index which didn't fail
return cb(e);
Expand Down
6 changes: 3 additions & 3 deletions test/db.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -2009,15 +2009,15 @@ describe('Database', function () {
}); // ==== End of 'Removing indexes upon document update' ==== //


describe.only('Persisting indexes', function () {
describe.skip('Persisting indexes', function () {

it('If the persistIndexes options is used, indexes are persisted to a separate file and recreated upon reload', function (done) {
var persDb = "workspace/persistIndexes.db"
, db
;

if (fs.existsSync(persDb)) { fs.writeFileSync(persDb, '', 'utf8'); }
db = new Datastore({ filename: persDb, autoload: true, persistIndexes: true });
db = new Datastore({ filename: persDb, autoload: true });

Object.keys(db.indexes).length.should.equal(1);
Object.keys(db.indexes)[0].should.equal("_id");
Expand All @@ -2035,7 +2035,7 @@ describe('Database', function () {
db.indexes.planet.getAll().length.should.equal(2);

// After a reload the indexes are recreated
db = new Datastore({ filename: persDb, persistIndexes: true });
db = new Datastore({ filename: persDb });
db.loadDatabase(function (err) {
assert.isNull(err);
Object.keys(db.indexes).length.should.equal(2);
Expand Down
3 changes: 2 additions & 1 deletion test/model.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -112,11 +112,12 @@ describe('Model', function () {
c.test[2].again.should.equal('yes');
});

it('Reject field names beginning with a $ sign or containing a dot, except the two edge cases', function () {
it('Reject field names beginning with a $ sign or containing a dot, except the three edge cases', function () {
var a1 = { $something: 'totest' }
, a2 = { "with.dot": 'totest' }
, e1 = { $$date: 4321 }
, e2 = { $$deleted: true }
, e3 = { $$indexCreated: "indexName" }
, b;

// Normal cases
Expand Down
12 changes: 6 additions & 6 deletions test/persistence.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ describe('Persistence', function () {
, rawData = model.serialize({ _id: "1", a: 2, ages: [1, 5, 12] }) + '\n' +
model.serialize({ _id: "2", hello: 'world' }) + '\n' +
model.serialize({ _id: "3", nested: { today: now } })
, treatedData = Persistence.treatRawData(rawData)
, treatedData = Persistence.treatRawData(rawData).data
;

treatedData.sort(function (a, b) { return a._id - b._id; });
Expand All @@ -61,7 +61,7 @@ describe('Persistence', function () {
, rawData = model.serialize({ _id: "1", a: 2, ages: [1, 5, 12] }) + '\n' +
'garbage\n' +
model.serialize({ _id: "3", nested: { today: now } })
, treatedData = Persistence.treatRawData(rawData)
, treatedData = Persistence.treatRawData(rawData).data
;

treatedData.sort(function (a, b) { return a._id - b._id; });
Expand All @@ -75,7 +75,7 @@ describe('Persistence', function () {
, rawData = model.serialize({ _id: "1", a: 2, ages: [1, 5, 12] }) + '\n' +
model.serialize({ _id: "2", hello: 'world' }) + '\n' +
model.serialize({ nested: { today: now } })
, treatedData = Persistence.treatRawData(rawData)
, treatedData = Persistence.treatRawData(rawData).data
;

treatedData.sort(function (a, b) { return a._id - b._id; });
Expand All @@ -89,7 +89,7 @@ describe('Persistence', function () {
, rawData = model.serialize({ _id: "1", a: 2, ages: [1, 5, 12] }) + '\n' +
model.serialize({ _id: "2", hello: 'world' }) + '\n' +
model.serialize({ _id: "1", nested: { today: now } })
, treatedData = Persistence.treatRawData(rawData)
, treatedData = Persistence.treatRawData(rawData).data
;

treatedData.sort(function (a, b) { return a._id - b._id; });
Expand All @@ -104,7 +104,7 @@ describe('Persistence', function () {
model.serialize({ _id: "2", hello: 'world' }) + '\n' +
model.serialize({ _id: "1", $$deleted: true }) + '\n' +
model.serialize({ _id: "3", today: now })
, treatedData = Persistence.treatRawData(rawData)
, treatedData = Persistence.treatRawData(rawData).data
;

treatedData.sort(function (a, b) { return a._id - b._id; });
Expand All @@ -118,7 +118,7 @@ describe('Persistence', function () {
, rawData = model.serialize({ _id: "1", a: 2, ages: [1, 5, 12] }) + '\n' +
model.serialize({ _id: "2", $$deleted: true }) + '\n' +
model.serialize({ _id: "3", today: now })
, treatedData = Persistence.treatRawData(rawData)
, treatedData = Persistence.treatRawData(rawData).data
;

treatedData.sort(function (a, b) { return a._id - b._id; });
Expand Down

0 comments on commit 34a3ba2

Please sign in to comment.