Проблема с обещанием NightmareJS в обещании - PullRequest
0 голосов
/ 02 апреля 2019

Я пытаюсь получить доступ к различным ссылкам на странице с помощью Nightmare, но второе обещание, похоже, отклонено (даже если это не так, а также с «.evaluate» вместо «.exists»).

Вот моя функция:

async function getDatas(index) {
  count = 0
    await nightmare
    .goto('https://xxx/login')
    .wait('#username')
    .insert('#username', login)
    .insert('#password', password)
    .click('#main-container div div div div div form button')
    .wait('.card-title')
    .run(() => {console.log("Waiting for main-container")})
    .wait('#main-container')
    .run(() => {console.log("Waiting 3s")})
    .wait(3500)
    .evaluate(function () {
      return Array.from(document.querySelectorAll('td a')).map(element => element.href);
    })
    .then(async (innerTexts) => {
      console.log("on charge liste projets");

      await innerTexts.forEach(async function(obj){
        console.log("On est dans le projet", obj)
        await nightmare
          .goto(obj)
          .wait(1100)
          .exists('.highlight')
          // .evaluate(function() {
            // return Array.from(document.querySelectorAll('a')).map(element => element.href);
          // })
          .then((re) => {
            console.error(re)
            console.log("It exists for", obj)
          })


          /* ********* Here is the triggered catch, but it shouldn't be ***** */
          .catch(re => {
            console.error("It doesn't exist for", re)
          })
      })
    })
    .then(() => {
      nightmare.end()
    })
    .catch(error => {
      nightmare.end()
    })
}
(полный код: https://pastebin.com/wZxRvizk)

Я был там весь день, я действительно не понимаю, почему обещание отклоняется.

Вывод:

on charge liste projets
On est dans le projet https://sup-sub.cri.epita.fr/projects/20/
On est dans le projet https://sup-sub.cri.epita.fr/projects/21/
It doesn't exist for { Error: navigation error
    at unserializeError (C:\temp\SupSub\linkedin-email-extractor\node_modules\nightmare\lib\ipc.js:162:13)
    at EventEmitter.<anonymous> (C:\temp\SupSub\linkedin-email-extractor\node_modules\nightmare\lib\ipc.js:89:13)
    at Object.onceWrapper (events.js:277:13)
    at EventEmitter.emit (events.js:189:13)
    at ChildProcess.<anonymous> (C:\temp\SupSub\linkedin-email-extractor\node_modules\nightmare\lib\ipc.js:49:10)
    at ChildProcess.emit (events.js:189:13)
    at emit (internal/child_process.js:820:12)
    at process._tickCallback (internal/process/next_tick.js:63:19)
  code: -3,
  details: 'ERR_ABORTED',
  url: 'https://xxx/projects/20/' }

1 Ответ

0 голосов
/ 05 апреля 2019

Как сказал Берги в комментарии, не используйте forEach.используйте for..of для просмотра списка URL.

for(let obj of innerTexts){
  await nightmare.goto(obj).wait(1100) // rest of your code
}
...