blob: dff2001cde7d095621e4169033804c65fe7fe463 [file] [log] [blame]
/*
*
* 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