1

我正在尝试测试Diary依赖于Network.

所以Diary代码:

- (PMKPromise *)saveAndUploadToServer:(DiaryItem *)item
{
    return [self save:item].then(^{
        return [self upload:item]; << See UPDATE //I put breakpoint here, it is never called
    });
}

- (PMKPromise *)save:(DiaryItem *)item
{
    return [PMKPromise new:^(PMKPromiseFulfiller fulfill, PMKPromiseRejecter reject) {
        [self.entryCreationManagedContext performBlock:^{
            BOOL success;
            NSError *saveError = nil;

            item.status = @(UploadingStatus);
            success = [self.entryCreationManagedContext save:&saveError];

            if (success) {
                fulfill(item.objectID);
            }
            else {
                reject(saveError);
            }
        }];
    }];
}

- (PMKPromise*)upload:(DiaryItem*)item
{
    return [self.network POST:self.diaryUrl parameters:[item dictionary]].then(^{
         return [self reportUploadAnalytics];
    });
}

和测试:

- (void)testFailedUploadingReportsAnalytics
{
    XCTestExpectation *expectation = [self expectationWithDescription:@"Operations completed"];

    [self uploadToServerAndReturnCallback].finally(^{
        [expectation fulfill];
    });

    [self waitForExpectationsWithTimeout:5 handler:^(NSError *error) {
        assertThat(error, is(nilValue()));

        //check that mock called
    }];
}

在这个Network测试中是模拟的。但是我看到的承诺链没有被执行。它卡住了。可能是因为then:在主线程上调用了块并且XCTest正在暂停它。但同时它可能应该在 5 秒后继续。可能是什么问题?

更新

看起来这与我最初的假设无关。如果我替换[self.entryCreationManagedContext save:&saveError]YES然后调试到达断点。

更新 2

托管上下文的这种特殊保存看起来像问题。它正在触发有关同步另一个托管上下文的通知。我们正在发现那里还有什么。

4

1 回答 1

0

它最终出现在不同的问题中,并且与 PromiseKit 没有任何关系。

我们发现使用的内存量越来越大。这NSManagedObjectContextDidSaveNotification导致不同商店协调员陷入僵局。修复该测试后,测试开始按预期工作。

于 2015-01-16T12:50:55.183 回答