次のコードによって Mongoosesave
が失敗するのはなぜですか? 削除するとvalidate: utils.uuid.isValid
(ブール値を返す)、プロセスは完了します:
var accountSchema = new mongoose.Schema({
_id : { type: String, default: utils.uuid.init, validate: utils.uuid.isValid },
n : { type: String }, // Display Name
ac : { type: Date },
au : { type: Date },
ad : { type: Date },
am : { type: String }
});
validate
また、フィールドのプロパティを削除して、pre('validate', cb)
またはpre('save', cb)
呼び出しで値を設定しようとすると、同じ結果になります。
accountSchema.pre('validate', function(next) {
var now = new Date(),
memberId = this.am;
console.log('In Account validate (member : ' + memberId + ')');
if (this.isNew) { this.ac = now; console.log('Item is new.'); }
else if (this.isModified()) { this.au = now; console.log('Item is modified.'); }
else { return next();
console.log('Canceling Account validate.');
}
console.log(JSON.stringify(this));
console.log('Completed Account validate.');
next();
});
何もクラッシュしません。Webstorm では、「プロセスは終了コード 139 で終了しました」というメッセージで処理が停止します。