Calling (and catching) multiple promises











up vote
0
down vote

favorite












I am trying to run below code (modified from this link):



let cnt = 1;

var prom = () => new Promise(
function (resolve, reject) {
try {
console.log('enter promise ' + cnt);
if (Math.random() < 0.5) throw new Error('error in promise ' + cnt);
resolve('done in promise ' + cnt);
}
catch (e) {
reject(e);
}
finally{
cnt++;
}
}
);

prom()
.then(prom())
.then(function (fulfilled) {
console.log('all done: ' + fulfilled);
})
.catch(function (error) {
console.log(error.message);
});


Basically I am trying to achieve a catch-all behaviour, i.e. if either promise fails, catch and stop processing. However can't achieve. What am I missing?










share|improve this question






















  • What is happening? Are you getting an error? What error?
    – iagowp
    Nov 21 at 22:54










  • Do not pass a promise to then(). Pass a callback function instead, e.g. .then(prom).
    – Bergi
    Nov 21 at 22:57










  • this looks like the issue; can you make it an answer?
    – paul simmons
    Nov 21 at 22:58










  • Which example exactly from the linked page did you use, and what and why did you modify?
    – Bergi
    Nov 21 at 22:59

















up vote
0
down vote

favorite












I am trying to run below code (modified from this link):



let cnt = 1;

var prom = () => new Promise(
function (resolve, reject) {
try {
console.log('enter promise ' + cnt);
if (Math.random() < 0.5) throw new Error('error in promise ' + cnt);
resolve('done in promise ' + cnt);
}
catch (e) {
reject(e);
}
finally{
cnt++;
}
}
);

prom()
.then(prom())
.then(function (fulfilled) {
console.log('all done: ' + fulfilled);
})
.catch(function (error) {
console.log(error.message);
});


Basically I am trying to achieve a catch-all behaviour, i.e. if either promise fails, catch and stop processing. However can't achieve. What am I missing?










share|improve this question






















  • What is happening? Are you getting an error? What error?
    – iagowp
    Nov 21 at 22:54










  • Do not pass a promise to then(). Pass a callback function instead, e.g. .then(prom).
    – Bergi
    Nov 21 at 22:57










  • this looks like the issue; can you make it an answer?
    – paul simmons
    Nov 21 at 22:58










  • Which example exactly from the linked page did you use, and what and why did you modify?
    – Bergi
    Nov 21 at 22:59















up vote
0
down vote

favorite









up vote
0
down vote

favorite











I am trying to run below code (modified from this link):



let cnt = 1;

var prom = () => new Promise(
function (resolve, reject) {
try {
console.log('enter promise ' + cnt);
if (Math.random() < 0.5) throw new Error('error in promise ' + cnt);
resolve('done in promise ' + cnt);
}
catch (e) {
reject(e);
}
finally{
cnt++;
}
}
);

prom()
.then(prom())
.then(function (fulfilled) {
console.log('all done: ' + fulfilled);
})
.catch(function (error) {
console.log(error.message);
});


Basically I am trying to achieve a catch-all behaviour, i.e. if either promise fails, catch and stop processing. However can't achieve. What am I missing?










share|improve this question













I am trying to run below code (modified from this link):



let cnt = 1;

var prom = () => new Promise(
function (resolve, reject) {
try {
console.log('enter promise ' + cnt);
if (Math.random() < 0.5) throw new Error('error in promise ' + cnt);
resolve('done in promise ' + cnt);
}
catch (e) {
reject(e);
}
finally{
cnt++;
}
}
);

prom()
.then(prom())
.then(function (fulfilled) {
console.log('all done: ' + fulfilled);
})
.catch(function (error) {
console.log(error.message);
});


Basically I am trying to achieve a catch-all behaviour, i.e. if either promise fails, catch and stop processing. However can't achieve. What am I missing?







node.js promise






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 21 at 22:47









paul simmons

2,453104672




2,453104672












  • What is happening? Are you getting an error? What error?
    – iagowp
    Nov 21 at 22:54










  • Do not pass a promise to then(). Pass a callback function instead, e.g. .then(prom).
    – Bergi
    Nov 21 at 22:57










  • this looks like the issue; can you make it an answer?
    – paul simmons
    Nov 21 at 22:58










  • Which example exactly from the linked page did you use, and what and why did you modify?
    – Bergi
    Nov 21 at 22:59




















  • What is happening? Are you getting an error? What error?
    – iagowp
    Nov 21 at 22:54










  • Do not pass a promise to then(). Pass a callback function instead, e.g. .then(prom).
    – Bergi
    Nov 21 at 22:57










  • this looks like the issue; can you make it an answer?
    – paul simmons
    Nov 21 at 22:58










  • Which example exactly from the linked page did you use, and what and why did you modify?
    – Bergi
    Nov 21 at 22:59


















What is happening? Are you getting an error? What error?
– iagowp
Nov 21 at 22:54




What is happening? Are you getting an error? What error?
– iagowp
Nov 21 at 22:54












Do not pass a promise to then(). Pass a callback function instead, e.g. .then(prom).
– Bergi
Nov 21 at 22:57




Do not pass a promise to then(). Pass a callback function instead, e.g. .then(prom).
– Bergi
Nov 21 at 22:57












this looks like the issue; can you make it an answer?
– paul simmons
Nov 21 at 22:58




this looks like the issue; can you make it an answer?
– paul simmons
Nov 21 at 22:58












Which example exactly from the linked page did you use, and what and why did you modify?
– Bergi
Nov 21 at 22:59






Which example exactly from the linked page did you use, and what and why did you modify?
– Bergi
Nov 21 at 22:59














2 Answers
2






active

oldest

votes

















up vote
0
down vote



accepted










.then() takes a callback as an argument and you gave it the returned Promise itself.



Use .then(prom) instead.






share|improve this answer




























    up vote
    0
    down vote













    Use Promise.all



    return Promise.all([
    prom(),
    prom()
    ])
    .then(([fullfilled1, fulfilled2]) => {
    console.log('all done: ' + fulfilled1 + ' ' + fulfilled2);
    })
    .catch(err => {
    console.log(error.message);
    });


    If one fails, everyone fails.






    share|improve this answer





















      Your Answer






      StackExchange.ifUsing("editor", function () {
      StackExchange.using("externalEditor", function () {
      StackExchange.using("snippets", function () {
      StackExchange.snippets.init();
      });
      });
      }, "code-snippets");

      StackExchange.ready(function() {
      var channelOptions = {
      tags: "".split(" "),
      id: "1"
      };
      initTagRenderer("".split(" "), "".split(" "), channelOptions);

      StackExchange.using("externalEditor", function() {
      // Have to fire editor after snippets, if snippets enabled
      if (StackExchange.settings.snippets.snippetsEnabled) {
      StackExchange.using("snippets", function() {
      createEditor();
      });
      }
      else {
      createEditor();
      }
      });

      function createEditor() {
      StackExchange.prepareEditor({
      heartbeatType: 'answer',
      convertImagesToLinks: true,
      noModals: true,
      showLowRepImageUploadWarning: true,
      reputationToPostImages: 10,
      bindNavPrevention: true,
      postfix: "",
      imageUploader: {
      brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
      contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
      allowUrls: true
      },
      onDemand: true,
      discardSelector: ".discard-answer"
      ,immediatelyShowMarkdownHelp:true
      });


      }
      });














      draft saved

      draft discarded


















      StackExchange.ready(
      function () {
      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53421498%2fcalling-and-catching-multiple-promises%23new-answer', 'question_page');
      }
      );

      Post as a guest















      Required, but never shown

























      2 Answers
      2






      active

      oldest

      votes








      2 Answers
      2






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes








      up vote
      0
      down vote



      accepted










      .then() takes a callback as an argument and you gave it the returned Promise itself.



      Use .then(prom) instead.






      share|improve this answer

























        up vote
        0
        down vote



        accepted










        .then() takes a callback as an argument and you gave it the returned Promise itself.



        Use .then(prom) instead.






        share|improve this answer























          up vote
          0
          down vote



          accepted







          up vote
          0
          down vote



          accepted






          .then() takes a callback as an argument and you gave it the returned Promise itself.



          Use .then(prom) instead.






          share|improve this answer












          .then() takes a callback as an argument and you gave it the returned Promise itself.



          Use .then(prom) instead.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 21 at 23:04









          Sebastian Speitel

          4,0622425




          4,0622425
























              up vote
              0
              down vote













              Use Promise.all



              return Promise.all([
              prom(),
              prom()
              ])
              .then(([fullfilled1, fulfilled2]) => {
              console.log('all done: ' + fulfilled1 + ' ' + fulfilled2);
              })
              .catch(err => {
              console.log(error.message);
              });


              If one fails, everyone fails.






              share|improve this answer

























                up vote
                0
                down vote













                Use Promise.all



                return Promise.all([
                prom(),
                prom()
                ])
                .then(([fullfilled1, fulfilled2]) => {
                console.log('all done: ' + fulfilled1 + ' ' + fulfilled2);
                })
                .catch(err => {
                console.log(error.message);
                });


                If one fails, everyone fails.






                share|improve this answer























                  up vote
                  0
                  down vote










                  up vote
                  0
                  down vote









                  Use Promise.all



                  return Promise.all([
                  prom(),
                  prom()
                  ])
                  .then(([fullfilled1, fulfilled2]) => {
                  console.log('all done: ' + fulfilled1 + ' ' + fulfilled2);
                  })
                  .catch(err => {
                  console.log(error.message);
                  });


                  If one fails, everyone fails.






                  share|improve this answer












                  Use Promise.all



                  return Promise.all([
                  prom(),
                  prom()
                  ])
                  .then(([fullfilled1, fulfilled2]) => {
                  console.log('all done: ' + fulfilled1 + ' ' + fulfilled2);
                  })
                  .catch(err => {
                  console.log(error.message);
                  });


                  If one fails, everyone fails.







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 21 at 23:37









                  dvsoukup

                  1,012923




                  1,012923






























                      draft saved

                      draft discarded




















































                      Thanks for contributing an answer to Stack Overflow!


                      • Please be sure to answer the question. Provide details and share your research!

                      But avoid



                      • Asking for help, clarification, or responding to other answers.

                      • Making statements based on opinion; back them up with references or personal experience.


                      To learn more, see our tips on writing great answers.





                      Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                      Please pay close attention to the following guidance:


                      • Please be sure to answer the question. Provide details and share your research!

                      But avoid



                      • Asking for help, clarification, or responding to other answers.

                      • Making statements based on opinion; back them up with references or personal experience.


                      To learn more, see our tips on writing great answers.




                      draft saved


                      draft discarded














                      StackExchange.ready(
                      function () {
                      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53421498%2fcalling-and-catching-multiple-promises%23new-answer', 'question_page');
                      }
                      );

                      Post as a guest















                      Required, but never shown





















































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown

































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown







                      Popular posts from this blog

                      Contact image not getting when fetch all contact list from iPhone by CNContact

                      count number of partitions of a set with n elements into k subsets

                      A CLEAN and SIMPLE way to add appendices to Table of Contents and bookmarks