xref: /aosp_15_r20/external/grpc-grpc/src/objective-c/tests/Common/TestUtils.m (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
1*cc02d7e2SAndroid Build Coastguard Worker/**
2*cc02d7e2SAndroid Build Coastguard Worker * Copyright 2022 gRPC authors.
3*cc02d7e2SAndroid Build Coastguard Worker *
4*cc02d7e2SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
5*cc02d7e2SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
6*cc02d7e2SAndroid Build Coastguard Worker * You may obtain a copy of the License at
7*cc02d7e2SAndroid Build Coastguard Worker *
8*cc02d7e2SAndroid Build Coastguard Worker *     http://www.apache.org/licenses/LICENSE-2.0
9*cc02d7e2SAndroid Build Coastguard Worker *
10*cc02d7e2SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
11*cc02d7e2SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
12*cc02d7e2SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*cc02d7e2SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
14*cc02d7e2SAndroid Build Coastguard Worker * limitations under the License.
15*cc02d7e2SAndroid Build Coastguard Worker */
16*cc02d7e2SAndroid Build Coastguard Worker
17*cc02d7e2SAndroid Build Coastguard Worker#import "TestUtils.h"
18*cc02d7e2SAndroid Build Coastguard Worker
19*cc02d7e2SAndroid Build Coastguard Worker#import <XCTest/XCTest.h>
20*cc02d7e2SAndroid Build Coastguard Worker
21*cc02d7e2SAndroid Build Coastguard Worker#import <GRPCClient/GRPCCall+ChannelArg.h>
22*cc02d7e2SAndroid Build Coastguard Worker#import <GRPCClient/GRPCCall+Tests.h>
23*cc02d7e2SAndroid Build Coastguard Worker
24*cc02d7e2SAndroid Build Coastguard Worker// Utility macro to stringize preprocessor defines
25*cc02d7e2SAndroid Build Coastguard Worker#define NSStringize_helper(x) #x
26*cc02d7e2SAndroid Build Coastguard Worker#define NSStringize(x) @NSStringize_helper(x)
27*cc02d7e2SAndroid Build Coastguard Worker
28*cc02d7e2SAndroid Build Coastguard Worker// Default test flake repeat counts
29*cc02d7e2SAndroid Build Coastguard Workerstatic const NSUInteger kGRPCDefaultTestFlakeRepeats = 1;
30*cc02d7e2SAndroid Build Coastguard Worker
31*cc02d7e2SAndroid Build Coastguard Worker// Default interop local test timeout.
32*cc02d7e2SAndroid Build Coastguard Workerconst NSTimeInterval GRPCInteropTestTimeoutDefault = 15.0;
33*cc02d7e2SAndroid Build Coastguard Worker
34*cc02d7e2SAndroid Build Coastguard WorkerNSString *GRPCGetLocalInteropTestServerAddressPlainText() {
35*cc02d7e2SAndroid Build Coastguard Worker  static NSString *address;
36*cc02d7e2SAndroid Build Coastguard Worker  static dispatch_once_t onceToken;
37*cc02d7e2SAndroid Build Coastguard Worker  dispatch_once(&onceToken, ^{
38*cc02d7e2SAndroid Build Coastguard Worker    address =
39*cc02d7e2SAndroid Build Coastguard Worker        [NSProcessInfo processInfo].environment[@"HOST_PORT_LOCAL"] ?: NSStringize(HOST_PORT_LOCAL);
40*cc02d7e2SAndroid Build Coastguard Worker  });
41*cc02d7e2SAndroid Build Coastguard Worker  return address;
42*cc02d7e2SAndroid Build Coastguard Worker}
43*cc02d7e2SAndroid Build Coastguard Worker
44*cc02d7e2SAndroid Build Coastguard WorkerNSString *GRPCGetLocalInteropTestServerAddressSSL() {
45*cc02d7e2SAndroid Build Coastguard Worker  static NSString *address;
46*cc02d7e2SAndroid Build Coastguard Worker  static dispatch_once_t onceToken;
47*cc02d7e2SAndroid Build Coastguard Worker  dispatch_once(&onceToken, ^{
48*cc02d7e2SAndroid Build Coastguard Worker    address = [NSProcessInfo processInfo].environment[@"HOST_PORT_LOCALSSL"]
49*cc02d7e2SAndroid Build Coastguard Worker                  ?: NSStringize(HOST_PORT_LOCALSSL);
50*cc02d7e2SAndroid Build Coastguard Worker  });
51*cc02d7e2SAndroid Build Coastguard Worker  return address;
52*cc02d7e2SAndroid Build Coastguard Worker}
53*cc02d7e2SAndroid Build Coastguard Worker
54*cc02d7e2SAndroid Build Coastguard WorkerNSString *GRPCGetRemoteInteropTestServerAddress() {
55*cc02d7e2SAndroid Build Coastguard Worker  static NSString *address;
56*cc02d7e2SAndroid Build Coastguard Worker  static dispatch_once_t onceToken;
57*cc02d7e2SAndroid Build Coastguard Worker  dispatch_once(&onceToken, ^{
58*cc02d7e2SAndroid Build Coastguard Worker    address = [NSProcessInfo processInfo].environment[@"HOST_PORT_REMOTE"]
59*cc02d7e2SAndroid Build Coastguard Worker                  ?: NSStringize(HOST_PORT_REMOTE);
60*cc02d7e2SAndroid Build Coastguard Worker  });
61*cc02d7e2SAndroid Build Coastguard Worker  return address;
62*cc02d7e2SAndroid Build Coastguard Worker}
63*cc02d7e2SAndroid Build Coastguard Worker
64*cc02d7e2SAndroid Build Coastguard Worker// Helper function to retrieve falke repeat from env variable settings.
65*cc02d7e2SAndroid Build Coastguard Workerstatic NSUInteger GRPCGetTestFlakeRepeats() {
66*cc02d7e2SAndroid Build Coastguard Worker  static NSUInteger repeats = kGRPCDefaultTestFlakeRepeats;
67*cc02d7e2SAndroid Build Coastguard Worker  static dispatch_once_t onceToken;
68*cc02d7e2SAndroid Build Coastguard Worker  dispatch_once(&onceToken, ^{
69*cc02d7e2SAndroid Build Coastguard Worker    NSString *repeatStr = [NSProcessInfo processInfo].environment[@"FLAKE_TEST_REPEATS"];
70*cc02d7e2SAndroid Build Coastguard Worker    if (repeatStr != nil) {
71*cc02d7e2SAndroid Build Coastguard Worker      repeats = [repeatStr integerValue];
72*cc02d7e2SAndroid Build Coastguard Worker    }
73*cc02d7e2SAndroid Build Coastguard Worker  });
74*cc02d7e2SAndroid Build Coastguard Worker  return repeats;
75*cc02d7e2SAndroid Build Coastguard Worker}
76*cc02d7e2SAndroid Build Coastguard Worker
77*cc02d7e2SAndroid Build Coastguard Workervoid GRPCResetCallConnections() {
78*cc02d7e2SAndroid Build Coastguard Worker#pragma clang diagnostic push
79*cc02d7e2SAndroid Build Coastguard Worker#pragma clang diagnostic ignored "-Wdeprecated-declarations"
80*cc02d7e2SAndroid Build Coastguard Worker  [GRPCCall closeOpenConnections];
81*cc02d7e2SAndroid Build Coastguard Worker#pragma clang diagnostic pop
82*cc02d7e2SAndroid Build Coastguard Worker}
83*cc02d7e2SAndroid Build Coastguard Worker
84*cc02d7e2SAndroid Build Coastguard Workervoid GRPCPrintInteropTestServerDebugInfo() {
85*cc02d7e2SAndroid Build Coastguard Worker  NSLog(@"local interop env: %@  macro: %@",
86*cc02d7e2SAndroid Build Coastguard Worker        [NSProcessInfo processInfo].environment[@"HOST_PORT_LOCAL"], NSStringize(HOST_PORT_LOCAL));
87*cc02d7e2SAndroid Build Coastguard Worker  NSLog(@"local interop ssl env: %@  macro: %@",
88*cc02d7e2SAndroid Build Coastguard Worker        [NSProcessInfo processInfo].environment[@"HOST_PORT_LOCALSSL"],
89*cc02d7e2SAndroid Build Coastguard Worker        NSStringize(HOST_PORT_LOCALSSL));
90*cc02d7e2SAndroid Build Coastguard Worker  NSLog(@"remote interop env: %@  macro: %@",
91*cc02d7e2SAndroid Build Coastguard Worker        [NSProcessInfo processInfo].environment[@"HOST_PORT_REMOTE"],
92*cc02d7e2SAndroid Build Coastguard Worker        NSStringize(HOST_PORT_REMOTE));
93*cc02d7e2SAndroid Build Coastguard Worker}
94*cc02d7e2SAndroid Build Coastguard Worker
95*cc02d7e2SAndroid Build Coastguard WorkerBOOL GRPCTestRunWithFlakeRepeats(XCTestCase *testCase, GRPCTestRunBlock testBlock) {
96*cc02d7e2SAndroid Build Coastguard Worker  NSInteger repeats = GRPCGetTestFlakeRepeats();
97*cc02d7e2SAndroid Build Coastguard Worker  NSInteger runs = 0;
98*cc02d7e2SAndroid Build Coastguard Worker
99*cc02d7e2SAndroid Build Coastguard Worker  while (runs < repeats) {
100*cc02d7e2SAndroid Build Coastguard Worker    GRPCResetCallConnections();
101*cc02d7e2SAndroid Build Coastguard Worker
102*cc02d7e2SAndroid Build Coastguard Worker    const BOOL isLastRun = (runs == repeats - 1);
103*cc02d7e2SAndroid Build Coastguard Worker    __block XCTWaiterResult result;
104*cc02d7e2SAndroid Build Coastguard Worker    __block BOOL assertionSuccess = YES;
105*cc02d7e2SAndroid Build Coastguard Worker
106*cc02d7e2SAndroid Build Coastguard Worker    GRPCTestWaiter waiterBlock =
107*cc02d7e2SAndroid Build Coastguard Worker        ^(NSArray<XCTestExpectation *> *expectations, NSTimeInterval timeout) {
108*cc02d7e2SAndroid Build Coastguard Worker          if (isLastRun) {
109*cc02d7e2SAndroid Build Coastguard Worker            XCTWaiter *waiter = [[XCTWaiter alloc] initWithDelegate:testCase];
110*cc02d7e2SAndroid Build Coastguard Worker            result = [waiter waitForExpectations:expectations timeout:timeout];
111*cc02d7e2SAndroid Build Coastguard Worker          } else {
112*cc02d7e2SAndroid Build Coastguard Worker            result = [XCTWaiter waitForExpectations:expectations timeout:timeout];
113*cc02d7e2SAndroid Build Coastguard Worker          }
114*cc02d7e2SAndroid Build Coastguard Worker        };
115*cc02d7e2SAndroid Build Coastguard Worker
116*cc02d7e2SAndroid Build Coastguard Worker    GRPCTestAssert assertBlock = ^(BOOL expressionValue, NSString *message) {
117*cc02d7e2SAndroid Build Coastguard Worker      BOOL result = !!(expressionValue);
118*cc02d7e2SAndroid Build Coastguard Worker      assertionSuccess = assertionSuccess && result;
119*cc02d7e2SAndroid Build Coastguard Worker      if (isLastRun && !result) {
120*cc02d7e2SAndroid Build Coastguard Worker        _XCTPrimitiveFail(testCase, @"%@", message);
121*cc02d7e2SAndroid Build Coastguard Worker      }
122*cc02d7e2SAndroid Build Coastguard Worker    };
123*cc02d7e2SAndroid Build Coastguard Worker
124*cc02d7e2SAndroid Build Coastguard Worker    testBlock(waiterBlock, assertBlock);
125*cc02d7e2SAndroid Build Coastguard Worker
126*cc02d7e2SAndroid Build Coastguard Worker    if (result == XCTWaiterResultCompleted && assertionSuccess) {
127*cc02d7e2SAndroid Build Coastguard Worker      return YES;
128*cc02d7e2SAndroid Build Coastguard Worker    }
129*cc02d7e2SAndroid Build Coastguard Worker
130*cc02d7e2SAndroid Build Coastguard Worker    if (!isLastRun) {
131*cc02d7e2SAndroid Build Coastguard Worker      NSLog(@"test attempt %@ failed, will retry.", NSStringize(runs));
132*cc02d7e2SAndroid Build Coastguard Worker    }
133*cc02d7e2SAndroid Build Coastguard Worker    runs += 1;
134*cc02d7e2SAndroid Build Coastguard Worker  }
135*cc02d7e2SAndroid Build Coastguard Worker
136*cc02d7e2SAndroid Build Coastguard Worker  return NO;
137*cc02d7e2SAndroid Build Coastguard Worker}
138