xref: /aosp_15_r20/external/grpc-grpc/src/objective-c/tests/Common/TestBase.h (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
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