0

次のコードによって 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 で終了しました」というメッセージで処理が停止します。

4

0 に答える 0