当我将NSInvocation的返回值设置为NSString时,调用者正在接收NSCFString。
在我的情况下,我嘲笑从单元测试包含的文件中拉出一个包路径:
[[[_bundlePartial stub] andDo:^(NSInvocation *invocation) {
NSString* resourceName = [invocation getArgumentAtIndexAsObject:2];
NSString* type = [invocation getArgumentAtIndexAsObject:3];
NSString* path = [[NSBundle bundleForClass:self.class] pathForResource:resourceName ofType:type];
if (!path)
{
path = [_bundleOriginal pathForResource:resourceName ofType:type];
}
[invocation setReturnValue:(void*)path];
}] pathForResource:OCMOCK_ANY ofType:OCMOCK_ANY];
我称之为:
NSString* jsonPathInBundle = [[NSBundle mainBundle] pathForResource:self.fileName ofType:self.fileExtension];
不幸的是我回来了一个NSCFString。这是有道理的,因为我的NSString由NSCFString支持,但是当我丢失桥时,我不能再在对象上调用NSString实例方法。有没有办法可以将值作为NSString返回?
答案 0 :(得分:7)
在检查了OCMock代码之后,我发现了我的问题。实际上是一个错字,但它的微妙,我不认为值得删除这个问题。
变化:
[invocation setReturnValue:(void*)path];
要:
[invocation setReturnValue:&path];
我最初的写作方式破坏了一层抽象,因为NSString被视为一个地址,而不是使用它的实际地址。