/GYHttpMock

Library for replacing part/all HTTP response based on Nocilla.

Primary LanguageObjective-CMIT LicenseMIT

GYHttpMock

Library for replacing part/all HTTP response based on Nocilla.

Features

  • Support NSURLConnection, NSURLSession.
  • Support replacing totally or partly HTTP response
  • Match requests with regular expressions.
  • Support json file for response

Installation with CocoaPods

To integrate GYHttpMock into your Xcode project using CocoaPods, specify it in your Podfile:

pod 'GYHttpMock'

Then, run the following command:

$ pod install

Usage

mocking a request before the real request anywhere.

Mock a simple request

It will return the default response, which is a 200 and an empty body.

mockRequest(@"GET", @"http://www.google.com");

Mock requests with regular expressions

mockRequest(@"GET", @"(.*?)google.com(.*?)".regex);

Mock a request with updating response partly

mockRequest(@"POST", @"http://www.google.com").
isUpdatePartResponseBody(YES).
withBody(@"{\"name\":\"abc\"}".regex);
andReturn(200).
withBody(@"{\"key\":\"value\"}");

Mock a request with json file response

mockRequest(@"POST", @"http://www.google.com").
isUpdatePartResponseBody(YES).
withBody(@"{\"name\":\"abc\"}".regex);
andReturn(200).
withBody(@"google.json");
Examle for update part response
orginal response:
{"data":{"id":"abc","location":"GZ"}}

updatedBody: google.json
{"data":{"time":"today"}}

final resoponse:
{"data":{"id":"abc","location":"GZ","time":"today"}}

All together

mockRequest(@"POST", @"http://www.google.com").
withHeaders(@{@"Accept": @"application/json"}).
withBody(@"\"name\":\"foo\"".regex).
isUpdatePartResponseBody(YES).
andReturn(200).
withHeaders(@{@"Content-Type": @"application/json"}).
withBody(@"google.json");

Add log

[GYHttpMock sharedInstance].logBlock = ^(NSString *logStr) {
    NSLOG(@"%@", logStr);
};

License

GYHttpMock is released under the MIT license. See LICENSE for details.