我尝试存根此AFNetworking方法并测试错误情况:
- (void)setCompletionBlockWithSuccess:(void (^)(AFHTTPRequestOperation *operation, id responseObject))success
failure:(void (^)(AFHTTPRequestOperation *operation, NSError *error))failure;
我的测试方法如下:
it(@"should return error when remote api fails", ^{
id mock = OCMClassMock([AFHTTPRequestOperation class]);
OCMStub([mock setCompletionBlockWithSuccess:[OCMArg any] failure:[OCMArg any]]).andDo(^(NSInvocation *invocation) {
void (^failureBlock)(AFHTTPRequestOperation *operation, NSError *error) = nil;
[invocation getArgument:&failureBlock atIndex:3];
NSDictionary *details = @{ NSLocalizedDescriptionKey : [OCMArg any] };
NSError *err = [NSError errorWithDomain:@"Some Domain" code:401 userInfo:details];
failureBlock(nil, err);
});
[API getWeeklyEvents].catch(^(NSError *err) {
error = [err copy];
});
expect(error).will.beTruthy();
});
[API getWeeklyEvents]
方法也使用PromiseKit。这可能是一个问题吗?
我尝试使用this但它不起作用并使用旧的OCMock语法。
答案 0 :(得分:1)
因此,您已经使用实际调用失败处理程序的块来存储setCompletionBlockWithSuccess:failure:
方法。就OCMock而言,这意味着在其他人调用setCompletionBlockWithSuccess:failure
之前不会发生任何事情。
现在该方法是一个实例方法,必须在mock上调用。唯一被调用的方法是getWeekEvents
。我不确定如何调用set方法,因为它需要对mock的引用。
老实说,我认为你必须重新设计你的测试。