1*cc02d7e2SAndroid Build Coastguard Worker /* 2*cc02d7e2SAndroid Build Coastguard Worker * 3*cc02d7e2SAndroid Build Coastguard Worker * Copyright 2019 gRPC authors. 4*cc02d7e2SAndroid Build Coastguard Worker * 5*cc02d7e2SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 6*cc02d7e2SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 7*cc02d7e2SAndroid Build Coastguard Worker * You may obtain a copy of the License at 8*cc02d7e2SAndroid Build Coastguard Worker * 9*cc02d7e2SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 10*cc02d7e2SAndroid Build Coastguard Worker * 11*cc02d7e2SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 12*cc02d7e2SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 13*cc02d7e2SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*cc02d7e2SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 15*cc02d7e2SAndroid Build Coastguard Worker * limitations under the License. 16*cc02d7e2SAndroid Build Coastguard Worker * 17*cc02d7e2SAndroid Build Coastguard Worker */ 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/GRPCTypes.h> 22*cc02d7e2SAndroid Build Coastguard Worker 23*cc02d7e2SAndroid Build Coastguard Worker /** 24*cc02d7e2SAndroid Build Coastguard Worker * This is an abstract class that needs to be subclassed. See |+host|. 25*cc02d7e2SAndroid Build Coastguard Worker */ 26*cc02d7e2SAndroid Build Coastguard Worker @interface TestBase : XCTestCase 27*cc02d7e2SAndroid Build Coastguard Worker /** 28*cc02d7e2SAndroid Build Coastguard Worker * The test suite to run, checking if the current XCTestCase instance is the base class. 29*cc02d7e2SAndroid Build Coastguard Worker * If so, run no tests (disabled). Otherwise, proceed to normal execution. 30*cc02d7e2SAndroid Build Coastguard Worker */ 31*cc02d7e2SAndroid Build Coastguard Worker @property(class, readonly) XCTestSuite *defaultTestSuite; 32*cc02d7e2SAndroid Build Coastguard Worker 33*cc02d7e2SAndroid Build Coastguard Worker /** 34*cc02d7e2SAndroid Build Coastguard Worker * Host to send the RPCs to. The base implementation returns nil, which would make all tests to 35*cc02d7e2SAndroid Build Coastguard Worker * fail. 36*cc02d7e2SAndroid Build Coastguard Worker * Override in a subclass to perform these tests against a specific address. 37*cc02d7e2SAndroid Build Coastguard Worker */ 38*cc02d7e2SAndroid Build Coastguard Worker + (NSString *)host; 39*cc02d7e2SAndroid Build Coastguard Worker 40*cc02d7e2SAndroid Build Coastguard Worker /** 41*cc02d7e2SAndroid Build Coastguard Worker * Bytes of overhead of test proto responses due to encoding. This is used to exercise the behavior 42*cc02d7e2SAndroid Build Coastguard Worker * when responses are just above or below the max response size. For some reason, the local and 43*cc02d7e2SAndroid Build Coastguard Worker * remote servers enconde responses with different overhead (?), so this is defined per-subclass. 44*cc02d7e2SAndroid Build Coastguard Worker */ 45*cc02d7e2SAndroid Build Coastguard Worker - (int32_t)encodingOverhead; 46*cc02d7e2SAndroid Build Coastguard Worker 47*cc02d7e2SAndroid Build Coastguard Worker /* 48*cc02d7e2SAndroid Build Coastguard Worker * The transport to be used. The base implementation returns NULL. Subclasses should override to 49*cc02d7e2SAndroid Build Coastguard Worker * appropriate settings. 50*cc02d7e2SAndroid Build Coastguard Worker */ 51*cc02d7e2SAndroid Build Coastguard Worker + (GRPCTransportID)transport; 52*cc02d7e2SAndroid Build Coastguard Worker 53*cc02d7e2SAndroid Build Coastguard Worker /** 54*cc02d7e2SAndroid Build Coastguard Worker * The root certificates to be used. The base implementation returns nil. Subclasses should override 55*cc02d7e2SAndroid Build Coastguard Worker * to appropriate settings. 56*cc02d7e2SAndroid Build Coastguard Worker */ 57*cc02d7e2SAndroid Build Coastguard Worker + (NSString *)PEMRootCertificates; 58*cc02d7e2SAndroid Build Coastguard Worker 59*cc02d7e2SAndroid Build Coastguard Worker /** 60*cc02d7e2SAndroid Build Coastguard Worker * The host name to be used for TLS verification in the tests. 61*cc02d7e2SAndroid Build Coastguard Worker */ 62*cc02d7e2SAndroid Build Coastguard Worker + (NSString *)hostNameOverride; 63*cc02d7e2SAndroid Build Coastguard Worker 64*cc02d7e2SAndroid Build Coastguard Worker /** 65*cc02d7e2SAndroid Build Coastguard Worker * Indication of whether the test is connecting to a remote server. 66*cc02d7e2SAndroid Build Coastguard Worker */ 67*cc02d7e2SAndroid Build Coastguard Worker + (BOOL)isRemoteTest; 68*cc02d7e2SAndroid Build Coastguard Worker 69*cc02d7e2SAndroid Build Coastguard Worker @end 70