mongoose.jsは、コールバックを保存してエラーを飲み込みますか?

StackOverflow https://stackoverflow.com/questions/7801637

  •  22-10-2019
  •  | 
  •  

質問

問題の孤立した例は次のとおりです。

var assert = require('assert')
var mongoose = require('mongoose')
var Schema = mongoose.Schema
  , ObjectId = Schema.ObjectId;

mongoose.connect("mongodb://localhost/some_db");

var BlogPostSchema = new Schema({
    title     : String
  , body      : String
  , date      : Date
});

var BlogPost = mongoose.model('BlogPost', BlogPostSchema);

var bp = new BlogPost({title: 'blogpost 0'})
bp.save(function(err) {
  console.log("this will print 0")
  assert.equal(1, 1)
  console.log("0 ... no problem")
})

var bp1 = new BlogPost({title: 'blogpost 1'})
bp1.save(function(err) {
  console.log("this will print 1")
  assert.equal(1, 2)
  console.log("this will NOT print")
})

var bp2 = new BlogPost({title: 'blogpost 2'})
bp2.save(function(err) {
  console.log("this will print 2")
  throw "this error is swallowed"
  console.log("this will NOT print")
})

セーブコールバック内にスローされたエラーは、コンソールに出力を生成しません。実行はその行で一時停止しているようです。

なぜこれが起こるのですか?

おそらく約束を使用して、コールバックを書くより良い方法はありますか?

役に立ちましたか?

解決

接続オブジェクトを使用できます エラー イベント:

var connection = mongoose.createConnection('mongodb://127.0.0.1/test'),
    BlogPost = connection.model('BlogPost', BlogPostSchema);

connection.on("error", function(errorObject){
  console.log(errorObject);
  ...
});
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top