How to confirm one of many HttpCalloutMock has been used












4















If I load multiple HttpCalloutMock's when settings up a test:



Test.setMock(HttpCalloutMock.class, MockFactory.create());


And I am using a MultiRequestMock implementation:



public without sharing class MultiRequestMock implements HttpCalloutMock {

Map<String, HttpCalloutMock> requests;

public MultiRequestMock(Map<String, HttpCalloutMock> requests) {
this.requests = requests;
}

public HTTPResponse respond(HTTPRequest req) {

HttpCalloutMock mock = requests.get(req.getEndpoint());

if (mock != null) {
return mock.respond(req);
}

throw new CustomException('Mock for end point not found: ' + req.getEndpoint());
}

public void addRequestMock(String url, HttpCalloutMock mock) {
requests.put(url, mock);
}
}


And I don't persist the results from the callout.



Is there anyway to check that eachany of the HttpCalloutMock have been used?










share|improve this question





























    4















    If I load multiple HttpCalloutMock's when settings up a test:



    Test.setMock(HttpCalloutMock.class, MockFactory.create());


    And I am using a MultiRequestMock implementation:



    public without sharing class MultiRequestMock implements HttpCalloutMock {

    Map<String, HttpCalloutMock> requests;

    public MultiRequestMock(Map<String, HttpCalloutMock> requests) {
    this.requests = requests;
    }

    public HTTPResponse respond(HTTPRequest req) {

    HttpCalloutMock mock = requests.get(req.getEndpoint());

    if (mock != null) {
    return mock.respond(req);
    }

    throw new CustomException('Mock for end point not found: ' + req.getEndpoint());
    }

    public void addRequestMock(String url, HttpCalloutMock mock) {
    requests.put(url, mock);
    }
    }


    And I don't persist the results from the callout.



    Is there anyway to check that eachany of the HttpCalloutMock have been used?










    share|improve this question



























      4












      4








      4


      2






      If I load multiple HttpCalloutMock's when settings up a test:



      Test.setMock(HttpCalloutMock.class, MockFactory.create());


      And I am using a MultiRequestMock implementation:



      public without sharing class MultiRequestMock implements HttpCalloutMock {

      Map<String, HttpCalloutMock> requests;

      public MultiRequestMock(Map<String, HttpCalloutMock> requests) {
      this.requests = requests;
      }

      public HTTPResponse respond(HTTPRequest req) {

      HttpCalloutMock mock = requests.get(req.getEndpoint());

      if (mock != null) {
      return mock.respond(req);
      }

      throw new CustomException('Mock for end point not found: ' + req.getEndpoint());
      }

      public void addRequestMock(String url, HttpCalloutMock mock) {
      requests.put(url, mock);
      }
      }


      And I don't persist the results from the callout.



      Is there anyway to check that eachany of the HttpCalloutMock have been used?










      share|improve this question
















      If I load multiple HttpCalloutMock's when settings up a test:



      Test.setMock(HttpCalloutMock.class, MockFactory.create());


      And I am using a MultiRequestMock implementation:



      public without sharing class MultiRequestMock implements HttpCalloutMock {

      Map<String, HttpCalloutMock> requests;

      public MultiRequestMock(Map<String, HttpCalloutMock> requests) {
      this.requests = requests;
      }

      public HTTPResponse respond(HTTPRequest req) {

      HttpCalloutMock mock = requests.get(req.getEndpoint());

      if (mock != null) {
      return mock.respond(req);
      }

      throw new CustomException('Mock for end point not found: ' + req.getEndpoint());
      }

      public void addRequestMock(String url, HttpCalloutMock mock) {
      requests.put(url, mock);
      }
      }


      And I don't persist the results from the callout.



      Is there anyway to check that eachany of the HttpCalloutMock have been used?







      apex unit-test httpcalloutmock






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited yesterday







      Robs

















      asked yesterday









      RobsRobs

      2,221535




      2,221535






















          1 Answer
          1






          active

          oldest

          votes


















          3














          Declare a variable in your mock class, and set its value in the respond method. if that variable is true at the end of your test , it means mock was used and callout was done.



          global class CalloutMock1 implements HttpCalloutMock {

          global boolean isCalled = false;
          global HTTPResponse respond(HTTPRequest req) {
          isCalled = true;
          // Create a fake response.
          // Set response values, and
          // return response.
          }
          }


          Test Class:



          CalloutMock1 cm1= new CalloutMock1();
          Test.setMock(HttpCalloutMock.class, cm1);

          //Call your code.


          System.assert(cm1.isCalled);




          Edit :Based on your updated code:



          public without sharing class MultiRequestMock implements HttpCalloutMock {

          public Map<String, HttpCalloutMock> requests;
          public Set<String> usedEndpoints = new Set<String>();

          public MultiRequestMock(Map<String, HttpCalloutMock> requests) {
          this.requests = requests;
          }

          public HTTPResponse respond(HTTPRequest req) {

          HttpCalloutMock mock = requests.get(req.getEndpoint());
          usedEndpoints.add(req.getEndpoint());

          if (mock != null) {
          return mock.respond(req);
          }

          throw new CustomException('Mock for end point not found: ' + req.getEndpoint());
          }

          public void addRequestMock(String url, HttpCalloutMock mock) {
          requests.put(url, mock);
          }
          }


          Test Class :



          MultiRequestMock  mm = new MultiRequestMock (new Map<String, HttpCalloutMock>());
          mm.addRequestMock();//

          //Do your callouts

          //Then Assert here

          System.assert(mm.usedEndpoints.contains('Your endpoint') , 'Your Endpoint not called'); //Your endpoint called
          System.assert(mm.usedEndpoints.size() == mm.requests.size() , 'Not all mocks were consumed');





          share|improve this answer


























          • Thanks. I've updated my question to expand on my HttpCalloutMock implementation

            – Robs
            yesterday






          • 1





            Hi @Robs provided pseudo code, for the same.

            – Pranay Jaiswal
            yesterday











          Your Answer








          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "459"
          };
          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%2fsalesforce.stackexchange.com%2fquestions%2f254061%2fhow-to-confirm-one-of-many-httpcalloutmock-has-been-used%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














          Declare a variable in your mock class, and set its value in the respond method. if that variable is true at the end of your test , it means mock was used and callout was done.



          global class CalloutMock1 implements HttpCalloutMock {

          global boolean isCalled = false;
          global HTTPResponse respond(HTTPRequest req) {
          isCalled = true;
          // Create a fake response.
          // Set response values, and
          // return response.
          }
          }


          Test Class:



          CalloutMock1 cm1= new CalloutMock1();
          Test.setMock(HttpCalloutMock.class, cm1);

          //Call your code.


          System.assert(cm1.isCalled);




          Edit :Based on your updated code:



          public without sharing class MultiRequestMock implements HttpCalloutMock {

          public Map<String, HttpCalloutMock> requests;
          public Set<String> usedEndpoints = new Set<String>();

          public MultiRequestMock(Map<String, HttpCalloutMock> requests) {
          this.requests = requests;
          }

          public HTTPResponse respond(HTTPRequest req) {

          HttpCalloutMock mock = requests.get(req.getEndpoint());
          usedEndpoints.add(req.getEndpoint());

          if (mock != null) {
          return mock.respond(req);
          }

          throw new CustomException('Mock for end point not found: ' + req.getEndpoint());
          }

          public void addRequestMock(String url, HttpCalloutMock mock) {
          requests.put(url, mock);
          }
          }


          Test Class :



          MultiRequestMock  mm = new MultiRequestMock (new Map<String, HttpCalloutMock>());
          mm.addRequestMock();//

          //Do your callouts

          //Then Assert here

          System.assert(mm.usedEndpoints.contains('Your endpoint') , 'Your Endpoint not called'); //Your endpoint called
          System.assert(mm.usedEndpoints.size() == mm.requests.size() , 'Not all mocks were consumed');





          share|improve this answer


























          • Thanks. I've updated my question to expand on my HttpCalloutMock implementation

            – Robs
            yesterday






          • 1





            Hi @Robs provided pseudo code, for the same.

            – Pranay Jaiswal
            yesterday
















          3














          Declare a variable in your mock class, and set its value in the respond method. if that variable is true at the end of your test , it means mock was used and callout was done.



          global class CalloutMock1 implements HttpCalloutMock {

          global boolean isCalled = false;
          global HTTPResponse respond(HTTPRequest req) {
          isCalled = true;
          // Create a fake response.
          // Set response values, and
          // return response.
          }
          }


          Test Class:



          CalloutMock1 cm1= new CalloutMock1();
          Test.setMock(HttpCalloutMock.class, cm1);

          //Call your code.


          System.assert(cm1.isCalled);




          Edit :Based on your updated code:



          public without sharing class MultiRequestMock implements HttpCalloutMock {

          public Map<String, HttpCalloutMock> requests;
          public Set<String> usedEndpoints = new Set<String>();

          public MultiRequestMock(Map<String, HttpCalloutMock> requests) {
          this.requests = requests;
          }

          public HTTPResponse respond(HTTPRequest req) {

          HttpCalloutMock mock = requests.get(req.getEndpoint());
          usedEndpoints.add(req.getEndpoint());

          if (mock != null) {
          return mock.respond(req);
          }

          throw new CustomException('Mock for end point not found: ' + req.getEndpoint());
          }

          public void addRequestMock(String url, HttpCalloutMock mock) {
          requests.put(url, mock);
          }
          }


          Test Class :



          MultiRequestMock  mm = new MultiRequestMock (new Map<String, HttpCalloutMock>());
          mm.addRequestMock();//

          //Do your callouts

          //Then Assert here

          System.assert(mm.usedEndpoints.contains('Your endpoint') , 'Your Endpoint not called'); //Your endpoint called
          System.assert(mm.usedEndpoints.size() == mm.requests.size() , 'Not all mocks were consumed');





          share|improve this answer


























          • Thanks. I've updated my question to expand on my HttpCalloutMock implementation

            – Robs
            yesterday






          • 1





            Hi @Robs provided pseudo code, for the same.

            – Pranay Jaiswal
            yesterday














          3












          3








          3







          Declare a variable in your mock class, and set its value in the respond method. if that variable is true at the end of your test , it means mock was used and callout was done.



          global class CalloutMock1 implements HttpCalloutMock {

          global boolean isCalled = false;
          global HTTPResponse respond(HTTPRequest req) {
          isCalled = true;
          // Create a fake response.
          // Set response values, and
          // return response.
          }
          }


          Test Class:



          CalloutMock1 cm1= new CalloutMock1();
          Test.setMock(HttpCalloutMock.class, cm1);

          //Call your code.


          System.assert(cm1.isCalled);




          Edit :Based on your updated code:



          public without sharing class MultiRequestMock implements HttpCalloutMock {

          public Map<String, HttpCalloutMock> requests;
          public Set<String> usedEndpoints = new Set<String>();

          public MultiRequestMock(Map<String, HttpCalloutMock> requests) {
          this.requests = requests;
          }

          public HTTPResponse respond(HTTPRequest req) {

          HttpCalloutMock mock = requests.get(req.getEndpoint());
          usedEndpoints.add(req.getEndpoint());

          if (mock != null) {
          return mock.respond(req);
          }

          throw new CustomException('Mock for end point not found: ' + req.getEndpoint());
          }

          public void addRequestMock(String url, HttpCalloutMock mock) {
          requests.put(url, mock);
          }
          }


          Test Class :



          MultiRequestMock  mm = new MultiRequestMock (new Map<String, HttpCalloutMock>());
          mm.addRequestMock();//

          //Do your callouts

          //Then Assert here

          System.assert(mm.usedEndpoints.contains('Your endpoint') , 'Your Endpoint not called'); //Your endpoint called
          System.assert(mm.usedEndpoints.size() == mm.requests.size() , 'Not all mocks were consumed');





          share|improve this answer















          Declare a variable in your mock class, and set its value in the respond method. if that variable is true at the end of your test , it means mock was used and callout was done.



          global class CalloutMock1 implements HttpCalloutMock {

          global boolean isCalled = false;
          global HTTPResponse respond(HTTPRequest req) {
          isCalled = true;
          // Create a fake response.
          // Set response values, and
          // return response.
          }
          }


          Test Class:



          CalloutMock1 cm1= new CalloutMock1();
          Test.setMock(HttpCalloutMock.class, cm1);

          //Call your code.


          System.assert(cm1.isCalled);




          Edit :Based on your updated code:



          public without sharing class MultiRequestMock implements HttpCalloutMock {

          public Map<String, HttpCalloutMock> requests;
          public Set<String> usedEndpoints = new Set<String>();

          public MultiRequestMock(Map<String, HttpCalloutMock> requests) {
          this.requests = requests;
          }

          public HTTPResponse respond(HTTPRequest req) {

          HttpCalloutMock mock = requests.get(req.getEndpoint());
          usedEndpoints.add(req.getEndpoint());

          if (mock != null) {
          return mock.respond(req);
          }

          throw new CustomException('Mock for end point not found: ' + req.getEndpoint());
          }

          public void addRequestMock(String url, HttpCalloutMock mock) {
          requests.put(url, mock);
          }
          }


          Test Class :



          MultiRequestMock  mm = new MultiRequestMock (new Map<String, HttpCalloutMock>());
          mm.addRequestMock();//

          //Do your callouts

          //Then Assert here

          System.assert(mm.usedEndpoints.contains('Your endpoint') , 'Your Endpoint not called'); //Your endpoint called
          System.assert(mm.usedEndpoints.size() == mm.requests.size() , 'Not all mocks were consumed');






          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited yesterday

























          answered yesterday









          Pranay JaiswalPranay Jaiswal

          17.8k42855




          17.8k42855













          • Thanks. I've updated my question to expand on my HttpCalloutMock implementation

            – Robs
            yesterday






          • 1





            Hi @Robs provided pseudo code, for the same.

            – Pranay Jaiswal
            yesterday



















          • Thanks. I've updated my question to expand on my HttpCalloutMock implementation

            – Robs
            yesterday






          • 1





            Hi @Robs provided pseudo code, for the same.

            – Pranay Jaiswal
            yesterday

















          Thanks. I've updated my question to expand on my HttpCalloutMock implementation

          – Robs
          yesterday





          Thanks. I've updated my question to expand on my HttpCalloutMock implementation

          – Robs
          yesterday




          1




          1





          Hi @Robs provided pseudo code, for the same.

          – Pranay Jaiswal
          yesterday





          Hi @Robs provided pseudo code, for the same.

          – Pranay Jaiswal
          yesterday


















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Salesforce 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%2fsalesforce.stackexchange.com%2fquestions%2f254061%2fhow-to-confirm-one-of-many-httpcalloutmock-has-been-used%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

          Plaza Victoria

          Puebla de Zaragoza

          Musa