Я использую Node версию 7.6.0, чтобы опробовать встроенную функцию async и ждать.Функция Async никогда не возвращает
Я пытаюсь понять, почему мой асинхронный вызов просто висит никогда не решает.
модуль NLP:
const rest = require('unirest')
const Redis = require('ioredis')
const redis = new Redis()
const Promise = require('bluebird')
const nlp = {}
nlp.queryCache = function(text) {
return new Promise(function(resolve, reject) {
redis.get(text, (err, result) => {
if (err) {
console.log("Error querying Redis: ", err)
reject(new Error("Error querying Redis: ", err))
} else {
if (result) {
let cache = JSON.parse(result)
console.log("Found cache in Redis: ", cache)
resolve(cache)
} else {
resolve(null)
}
}
})
})
}
nlp.queryService = function(text) {
console.log("Querying NLP Service...")
return new Promise(function(resolve, reject) {
rest.get('http://localhost:9119?q=' + text)
.end((response) => {
redis.set(text, JSON.stringify(text))
resolve(response.body)
})
})
}
nlp.query = async function(text) {
try {
console.log("LET'S TRY REDIS FIRST")
let cache = await nlp.queryCache(text)
if (cache) {
return cache
} else {
let result = await nlp.queryService(text)
console.log("Done Querying NLP service: ", result)
return result
}
} catch (e) {
console.log("Problem querying: ", e)
}
}
module.exports = nlp
Модуль потребителя:
const modeMenu = require('../ui/service_mode')
const nlp = require('../nlp')
const sess = require('../session')
const onGreetings = async function(req, res, next) {
let state = sess.getState(req.from.id)
if (state === 'GREET') {
let log = {
middleware: "onGreetings"
}
console.log(log)
let result = await nlp.query(req.text)
console.log("XXXXXXXX: ", result)
res.send({reply_id: req.from.id, message: msg})
} else {
console.log("This query is not not normal text from user, calling next()")
next()
}
};
module.exports = onGreetings;
Я не могу получить код, чтобы перейти к следующей строке:
console.log("XXXXXXXX: ", result)
Я могу видеть, что запрос был успешным в модуле НЛП
Edit: Added console.log statement to response body
Вы пытались поставить «асинхронный» на все функции, которые вы пытаетесь «подождать»? И поэтому постарайтесь добавить «ожидание» перед «новым обещанием». – Gilsdav
@ Gilsdav - вы не «ожидаете нового обещания» - асинхронный/ждущий синтаксический сахар для Promises –
какой из других сообщений console.log отображается? Ваша логика кажется звуковой –