|
|
@ -16,10 +16,21 @@ |
|
|
|
|
|
|
|
|
|
|
|
#import "TestUtils.h" |
|
|
|
#import "TestUtils.h" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#import <XCTest/XCTest.h> |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#import <GRPCClient/GRPCCall+ChannelArg.h> |
|
|
|
|
|
|
|
#import <GRPCClient/GRPCCall+Tests.h> |
|
|
|
|
|
|
|
|
|
|
|
// Utility macro to stringize preprocessor defines |
|
|
|
// Utility macro to stringize preprocessor defines |
|
|
|
#define NSStringize_helper(x) #x |
|
|
|
#define NSStringize_helper(x) #x |
|
|
|
#define NSStringize(x) @NSStringize_helper(x) |
|
|
|
#define NSStringize(x) @NSStringize_helper(x) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Default test flake repeat counts |
|
|
|
|
|
|
|
static const NSUInteger kGRPCDefaultTestFlakeRepeats = 2; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Default interop local test timeout. |
|
|
|
|
|
|
|
const NSTimeInterval GRPCInteropTestTimeoutDefault = 3.0; |
|
|
|
|
|
|
|
|
|
|
|
NSString *GRPCGetLocalInteropTestServerAddressPlainText() { |
|
|
|
NSString *GRPCGetLocalInteropTestServerAddressPlainText() { |
|
|
|
static NSString *address; |
|
|
|
static NSString *address; |
|
|
|
static dispatch_once_t onceToken; |
|
|
|
static dispatch_once_t onceToken; |
|
|
@ -50,6 +61,26 @@ NSString *GRPCGetRemoteInteropTestServerAddress() { |
|
|
|
return address; |
|
|
|
return address; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Helper function to retrieve falke repeat from env variable settings. |
|
|
|
|
|
|
|
static NSUInteger GRPCGetTestFlakeRepeats() { |
|
|
|
|
|
|
|
static NSUInteger repeats = kGRPCDefaultTestFlakeRepeats; |
|
|
|
|
|
|
|
static dispatch_once_t onceToken; |
|
|
|
|
|
|
|
dispatch_once(&onceToken, ^{ |
|
|
|
|
|
|
|
NSString *repeatStr = [NSProcessInfo processInfo].environment[@"FLAKE_TEST_REPEATS"]; |
|
|
|
|
|
|
|
if (repeatStr != nil) { |
|
|
|
|
|
|
|
repeats = [repeatStr integerValue]; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
return repeats; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void GRPCResetCallConnections() { |
|
|
|
|
|
|
|
#pragma clang diagnostic push |
|
|
|
|
|
|
|
#pragma clang diagnostic ignored "-Wdeprecated-declarations" |
|
|
|
|
|
|
|
[GRPCCall closeOpenConnections]; |
|
|
|
|
|
|
|
#pragma clang diagnostic pop |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void GRPCPrintInteropTestServerDebugInfo() { |
|
|
|
void GRPCPrintInteropTestServerDebugInfo() { |
|
|
|
NSLog(@"local interop env: %@ macro: %@", |
|
|
|
NSLog(@"local interop env: %@ macro: %@", |
|
|
|
[NSProcessInfo processInfo].environment[@"HOST_PORT_LOCAL"], NSStringize(HOST_PORT_LOCAL)); |
|
|
|
[NSProcessInfo processInfo].environment[@"HOST_PORT_LOCAL"], NSStringize(HOST_PORT_LOCAL)); |
|
|
@ -60,3 +91,30 @@ void GRPCPrintInteropTestServerDebugInfo() { |
|
|
|
[NSProcessInfo processInfo].environment[@"HOST_PORT_REMOTE"], |
|
|
|
[NSProcessInfo processInfo].environment[@"HOST_PORT_REMOTE"], |
|
|
|
NSStringize(HOST_PORT_REMOTE)); |
|
|
|
NSStringize(HOST_PORT_REMOTE)); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOL GRPCTestRunWithFlakeRepeats(GRPCTestRunBlock testBlock) { |
|
|
|
|
|
|
|
NSInteger repeats = GRPCGetTestFlakeRepeats(); |
|
|
|
|
|
|
|
NSInteger runs = 0; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
while (runs < repeats) { |
|
|
|
|
|
|
|
__block XCTWaiterResult result; |
|
|
|
|
|
|
|
GRPCResetCallConnections(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
testBlock(^(XCTestCase *testCase, NSArray<XCTestExpectation *> *expectations, |
|
|
|
|
|
|
|
NSTimeInterval timeout) { |
|
|
|
|
|
|
|
if (runs < repeats - 1) { |
|
|
|
|
|
|
|
result = [XCTWaiter waitForExpectations:expectations timeout:timeout]; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
XCTWaiter *waiter = [[XCTWaiter alloc] initWithDelegate:testCase]; |
|
|
|
|
|
|
|
result = [waiter waitForExpectations:expectations timeout:timeout]; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (result == XCTWaiterResultCompleted) { |
|
|
|
|
|
|
|
return YES; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
runs += 1; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return NO; |
|
|
|
|
|
|
|
} |
|
|
|