mongoose-elasticsearch-xp
mongoose-elasticsearch-xp copied to clipboard
Mongoose deprecation warning for Query.prototype.stream()
data:image/s3,"s3://crabby-images/0ce71/0ce71e7b138dc52ef9442d7408cfb98ffe7c02af" alt="screen shot 2018-03-19 at 11 05 38 am"
Which version of mongoose do you use?
With >5.0.0 this message should disappear code: https://github.com/jbdemonte/mongoose-elasticsearch-xp/blob/master/lib/index.js#L341
Oh, that seems to be the problem. I'm currently using mongoose 4.9.0 because of which that depreciation warning might have come up.
I'll change the version and update it here
@nodkz Can you please help me out on what to use as a replacement for .on()
i.e. previously, we have been using Model.on('es-bulk-error', function( err ){ console.log('Error : ', err) }) which is showing another warning,
UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 2): TypeError: Cannot read property 'on' of undefined
data:image/s3,"s3://crabby-images/eec92/eec92ed93a9d8c5fe4d6b15269668b16b5f5581f" alt="screen shot 2018-03-19 at 1 07 36 pm"
Provide detailed console output for your rejection.
For this, you need to add following code to your app:
process.on('unhandledRejection', error => {
console.log('unhandledRejection');
console.dir(error);
});
This is what it shows on type error,
TypeError: Cannot read property 'on' of undefined
at utils.run (/app/node_modules/mongoose-elasticsearch-xp/lib/index.js:377:12)
at new Promise (<anonymous>)
at Object.module.exports.run (/app/node_modules/mongoose-elasticsearch-xp/lib/utils.js:30:12)
at Function.synchronize [as esSynchronize] (/app/node_modules/mongoose-elasticsearch-xp/lib/index.js:327:16)
at Object.<anonymous> (/app/src/models/product.js:81:22) // Here I have the esSynchronize() method
at Module._compile (module.js:643:30)
at Object.Module._extensions..js (module.js:654:10)
at Module.load (module.js:556:32)
at tryModuleLoad (module.js:499:12)
at Function.Module._load (module.js:491:3)
at Module.require (module.js:587:17)
at require (internal/module.js:11:18)
at Object.<anonymous> (/app/src/repository/product.js:2:34)
at Module._compile (module.js:643:30)
at Object.Module._extensions..js (module.js:654:10)
at Module.load (module.js:556:32)
data:image/s3,"s3://crabby-images/82bfd/82bfdc6804267ad8df7b00722ed37a14cdf0a999" alt="screen shot 2018-03-19 at 1 23 27 pm"
It may be a problem with wrong bulker
option which you provide for mongoose-elasticsearch-xp
:
https://github.com/jbdemonte/mongoose-elasticsearch-xp/blob/master/lib/index.js#L343
Yeah, I thought the same, this is actually my models.py
'use strict'
const Joi = require('joi')
const Mongoose = require('mongoose')
const Joigoose = require('joigoose')(Mongoose)
const MongoosasticXP = require('mongoose-elasticsearch-xp')
let SampleJoi = Joi.object().keys({
//...
//...
// Some schema
})
let mongooseSampleSchema = Joigoose.convert(SampleJoi)
let mongooseSampleMiddlewareSchema = new Mongoose.Schema(mongooseSampleSchema)
//
// Some config for elasticsearch
//
let SampleDb = Mongoose.model('Sample', mongooseSampleMiddlewareSchema)
SampleDb.on('es-bulk-error', function (err) {
console.log(err)
throw Error(err)
})
SampleDb.esSynchronize().then(function (response) { // Here is where the error is being shown in my code.... i.e. where the error propagation starts
console.log('Indexed all documents!')
})
module.exports = {
SampleJoi,
SampleDb: SampleDb
}