aboutsummaryrefslogtreecommitdiffhomepage
path: root/Firestore/Example/Tests/SpecTests/FSTSpecTests.h
blob: 3a3dbb2c86a354c4890d654b417d0c07c5b94fe7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/*
 * Copyright 2017 Google
 *
 * 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 <Foundation/Foundation.h>
#import <XCTest/XCTest.h>

@protocol FSTPersistence;

NS_ASSUME_NONNULL_BEGIN

/**
 * FSTSpecTests run a set of portable event specifications from JSON spec files against a
 * special isolated version of the Firestore client that allows precise control over when events
 * are delivered. This allows us to test client behavior in a very reliable, deterministic way,
 * including edge cases that would be difficult to reliably reproduce in a full integration test.
 *
 * Both events from user code (adding/removing listens, performing mutations) and events from the
 * Datastore are simulated, while installing as much of the system in between as possible.
 *
 * FSTSpecTests is an abstract base class that must be subclassed to test against a specific local
 * store implementation. To create a new variant of FSTSpecTests:
 *
 * + Subclass FSTSpecTests
 * + override -persistence to create and return an appropriate id<FSTPersistence> implementation.
 */
@interface FSTSpecTests : XCTestCase

/** Creates and returns an appropriate id<FSTPersistence> implementation. */
- (id<FSTPersistence>)persistence;

@end

NS_ASSUME_NONNULL_END