Display output of `time` only if command after `time` was successful












4















I want the output of the time command to be shown only if the command, which has been passed to time was successful. Something like this:



( time wget -pq --delete-after https://www.example.com ) 2>&1 || echo fail


The problem is, that if wget fails, I still receive the output from time (which is somewhere logical, as it measures how long it took for the command to fail anyway). My goal is to save the output to a variable and either have 0m0.100s or fail in my variable. Does anyone has an idea how I could do this in a decent manner?










share|improve this question





























    4















    I want the output of the time command to be shown only if the command, which has been passed to time was successful. Something like this:



    ( time wget -pq --delete-after https://www.example.com ) 2>&1 || echo fail


    The problem is, that if wget fails, I still receive the output from time (which is somewhere logical, as it measures how long it took for the command to fail anyway). My goal is to save the output to a variable and either have 0m0.100s or fail in my variable. Does anyone has an idea how I could do this in a decent manner?










    share|improve this question



























      4












      4








      4


      1






      I want the output of the time command to be shown only if the command, which has been passed to time was successful. Something like this:



      ( time wget -pq --delete-after https://www.example.com ) 2>&1 || echo fail


      The problem is, that if wget fails, I still receive the output from time (which is somewhere logical, as it measures how long it took for the command to fail anyway). My goal is to save the output to a variable and either have 0m0.100s or fail in my variable. Does anyone has an idea how I could do this in a decent manner?










      share|improve this question
















      I want the output of the time command to be shown only if the command, which has been passed to time was successful. Something like this:



      ( time wget -pq --delete-after https://www.example.com ) 2>&1 || echo fail


      The problem is, that if wget fails, I still receive the output from time (which is somewhere logical, as it measures how long it took for the command to fail anyway). My goal is to save the output to a variable and either have 0m0.100s or fail in my variable. Does anyone has an idea how I could do this in a decent manner?







      command-line time return-status






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited 5 hours ago







      chevallier

















      asked 6 hours ago









      chevallierchevallier

      9511323




      9511323






















          1 Answer
          1






          active

          oldest

          votes


















          3














          You can do something like this:



          $ if var=$( { time true; } 2>&1 ); then echo "$var"; else echo fail; fi

          real 0m0.000s
          user 0m0.000s
          sys 0m0.000s




          $ if var=$( { time false; } 2>&1 ); then echo "$var"; else echo fail; fi
          fail





          share|improve this answer





















          • 2





            var=$( { time sleep 1; } 2>&1 ) should work with Bash, ksh and zsh (though time true doesn't print anything in my zsh, hmm)

            – ilkkachu
            5 hours ago











          Your Answer








          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "106"
          };
          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',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          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%2funix.stackexchange.com%2fquestions%2f499492%2fdisplay-output-of-time-only-if-command-after-time-was-successful%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          3














          You can do something like this:



          $ if var=$( { time true; } 2>&1 ); then echo "$var"; else echo fail; fi

          real 0m0.000s
          user 0m0.000s
          sys 0m0.000s




          $ if var=$( { time false; } 2>&1 ); then echo "$var"; else echo fail; fi
          fail





          share|improve this answer





















          • 2





            var=$( { time sleep 1; } 2>&1 ) should work with Bash, ksh and zsh (though time true doesn't print anything in my zsh, hmm)

            – ilkkachu
            5 hours ago
















          3














          You can do something like this:



          $ if var=$( { time true; } 2>&1 ); then echo "$var"; else echo fail; fi

          real 0m0.000s
          user 0m0.000s
          sys 0m0.000s




          $ if var=$( { time false; } 2>&1 ); then echo "$var"; else echo fail; fi
          fail





          share|improve this answer





















          • 2





            var=$( { time sleep 1; } 2>&1 ) should work with Bash, ksh and zsh (though time true doesn't print anything in my zsh, hmm)

            – ilkkachu
            5 hours ago














          3












          3








          3







          You can do something like this:



          $ if var=$( { time true; } 2>&1 ); then echo "$var"; else echo fail; fi

          real 0m0.000s
          user 0m0.000s
          sys 0m0.000s




          $ if var=$( { time false; } 2>&1 ); then echo "$var"; else echo fail; fi
          fail





          share|improve this answer















          You can do something like this:



          $ if var=$( { time true; } 2>&1 ); then echo "$var"; else echo fail; fi

          real 0m0.000s
          user 0m0.000s
          sys 0m0.000s




          $ if var=$( { time false; } 2>&1 ); then echo "$var"; else echo fail; fi
          fail






          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited 5 hours ago

























          answered 5 hours ago









          Jesse_bJesse_b

          12.6k23066




          12.6k23066








          • 2





            var=$( { time sleep 1; } 2>&1 ) should work with Bash, ksh and zsh (though time true doesn't print anything in my zsh, hmm)

            – ilkkachu
            5 hours ago














          • 2





            var=$( { time sleep 1; } 2>&1 ) should work with Bash, ksh and zsh (though time true doesn't print anything in my zsh, hmm)

            – ilkkachu
            5 hours ago








          2




          2





          var=$( { time sleep 1; } 2>&1 ) should work with Bash, ksh and zsh (though time true doesn't print anything in my zsh, hmm)

          – ilkkachu
          5 hours ago





          var=$( { time sleep 1; } 2>&1 ) should work with Bash, ksh and zsh (though time true doesn't print anything in my zsh, hmm)

          – ilkkachu
          5 hours ago


















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Unix & Linux Stack Exchange!


          • 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%2funix.stackexchange.com%2fquestions%2f499492%2fdisplay-output-of-time-only-if-command-after-time-was-successful%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

          what is the purpose of having a “thru cal” on RF PCB?

          What does Gandalf whisper to the Moth on the Orthanc in Isengard?

          magento2 creating a lot of catalogrule_product_temp tables