Skip to content

Commit

Permalink
fix: $pull bug
Browse files Browse the repository at this point in the history
  • Loading branch information
fduplessisduplessis committed Jul 5, 2017
1 parent 55cd409 commit ec3217d
Show file tree
Hide file tree
Showing 2 changed files with 104 additions and 0 deletions.
2 changes: 2 additions & 0 deletions lib/utils/Omnom.ts
Original file line number Diff line number Diff line change
Expand Up @@ -224,6 +224,8 @@ export class Omnom {

if (this.changes.$pullAll && this.changes.$pullAll[path]) {
this.changes.$pullAll[path].push(value);
if (_.keys(this.changes.$pull).length === 0)
delete this.changes.$pull;
return;
}

Expand Down
102 changes: 102 additions & 0 deletions test/issues/pull.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
import * as Iridium from "../../iridium";
import * as chai from "chai";

interface EventType
{
type: string;
time: Date;
};

interface TestDocument {
_id?: string;

stuff?: {
[name: string]: {
[tracker: number]: EventType[];
}
};
}


@Iridium.Collection("test")
@Iridium.Transform(doc => {
if (doc.metadata && typeof doc.metadata === "string")
doc.metadata = JSON.parse(doc.metadata);
return doc;
}, doc => {
if (doc.metadata && typeof doc.metadata === "object")
doc.metadata = JSON.stringify(doc.metadata);
return doc
})
class Test extends Iridium.Instance<TestDocument, Test> implements TestDocument {
@Iridium.ObjectID
_id: string;

@Iridium.Property({
$propertyType: {
$propertyType: [{
type: String,
time: Date,
position: {
$type: {
type: /^Point$/,
coordinates: [Number, 2, 2]
},
$required: false
},
data: {
$type: Object,
$required: false
}
}]
}
})
stuff: {
[name: string]: {
[event: number]: EventType[];
}
};
}

describe("issues", () => {
let core = new Iridium.Core({ database: "test" });
before(() => core.connect());
after(() => core.close());

describe("pull", () => {
let model = new Iridium.Model<TestDocument, Test>(core, Test);

it("save should not throw $pull is empty", () => {
return model.remove().then(() => model.insert({
stuff: {
bomber: {
123456: [
{ time: new Date("2016-06-08T13:27:18.000Z"), type: "absolute" },
{ time: new Date("2016-06-08T14:03:12.000Z"), type: "relative" },
{ time: new Date("2016-06-08T12:06:14.000Z"), type: "counted" },
{ time: new Date("2016-06-08T12:10:14.000Z"), type: "counted" },
{ time: new Date("2016-06-08T12:11:30.000Z"), type: "counted" },
{ time: new Date("2016-06-08T12:14:32.000Z"), type: "counted" },
{ time: new Date("2016-06-08T12:16:00.000Z"), type: "counted" },
{ time: new Date("2016-06-08T12:18:18.000Z"), type: "counted" }
]
}
}
})).then(test => {
test.stuff = {
bomber: {
123456: [
{ time: new Date("2016-06-08T13:27:18.000Z"), type: "absolute"},
{ time: new Date("2016-06-08T13:03:24.000Z"), type: "counted"},
{ time: new Date("2016-06-08T13:07:58.000Z"), type: "counted"},
{ time: new Date("2016-06-08T13:10:02.000Z"), type: "counted"},
{ time: new Date("2016-06-08T13:12:32.000Z"), type: "counted"}
]
}
}
console.log("test ran");
return test.save();
});
});
});
});

0 comments on commit ec3217d

Please sign in to comment.