| /* |
| * |
| * Copyright 2019 gRPC authors. |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| * |
| */ |
| |
| #import <XCTest/XCTest.h> |
| |
| #import <GRPCClient/GRPCTypes.h> |
| |
| /** |
| * This is an abstract class that needs to be subclassed. See |+host|. |
| */ |
| @interface TestBase : XCTestCase |
| /** |
| * The test suite to run, checking if the current XCTestCase instance is the base class. |
| * If so, run no tests (disabled). Otherwise, proceed to normal execution. |
| */ |
| @property(class, readonly) XCTestSuite *defaultTestSuite; |
| |
| /** |
| * Host to send the RPCs to. The base implementation returns nil, which would make all tests to |
| * fail. |
| * Override in a subclass to perform these tests against a specific address. |
| */ |
| + (NSString *)host; |
| |
| /** |
| * Bytes of overhead of test proto responses due to encoding. This is used to exercise the behavior |
| * when responses are just above or below the max response size. For some reason, the local and |
| * remote servers enconde responses with different overhead (?), so this is defined per-subclass. |
| */ |
| - (int32_t)encodingOverhead; |
| |
| /* |
| * The transport to be used. The base implementation returns NULL. Subclasses should override to |
| * appropriate settings. |
| */ |
| + (GRPCTransportID)transport; |
| |
| /** |
| * The root certificates to be used. The base implementation returns nil. Subclasses should override |
| * to appropriate settings. |
| */ |
| + (NSString *)PEMRootCertificates; |
| |
| /** |
| * The host name to be used for TLS verification in the tests. |
| */ |
| + (NSString *)hostNameOverride; |
| |
| /** |
| * Indication of whether the test is connecting to a remote server. |
| */ |
| + (BOOL)isRemoteTest; |
| |
| @end |