aboutsummaryrefslogtreecommitdiffhomepage
path: root/Example/Core/Tests/FIRAnalyticsConfigurationTest.m
diff options
context:
space:
mode:
authorGravatar Rich Gowman <rgowman@google.com>2018-06-12 10:27:17 -0400
committerGravatar Rich Gowman <rgowman@google.com>2018-06-12 10:27:17 -0400
commitcf2899a085f7ceca3fad2d1fb5336be25cecd7ff (patch)
tree38c835a29fcda279c8dd220781d2b5c726da307f /Example/Core/Tests/FIRAnalyticsConfigurationTest.m
parent1597765af8c897ab73d21d6d404f8eeede7890b1 (diff)
parent9307f4893008f7d6cf9473e906d4c896546c5c8c (diff)
Merge remote-tracking branch 'origin/master' into rsgowman/protobuf_cpp
Also "fixed" BadFieldValueTagWithOtherValidTagsPresent test by changing 'false' to 'true'. Details: Depending on the version of nanopb, nanopb would explicitly encode 'false', which shouldn't be done in proto3. When it's explicitly encoded, the test worked properly. But when it was (properly) dropped, the invalid tag is the only field that's actually encoded, thus violating the assumptions of the test, leading to a test failure. s/false/true fixes it, as now the boolean_value field is (properly) encoded regardless of version.
Diffstat (limited to 'Example/Core/Tests/FIRAnalyticsConfigurationTest.m')
-rw-r--r--Example/Core/Tests/FIRAnalyticsConfigurationTest.m117
1 files changed, 117 insertions, 0 deletions
diff --git a/Example/Core/Tests/FIRAnalyticsConfigurationTest.m b/Example/Core/Tests/FIRAnalyticsConfigurationTest.m
new file mode 100644
index 0000000..a66ad06
--- /dev/null
+++ b/Example/Core/Tests/FIRAnalyticsConfigurationTest.m
@@ -0,0 +1,117 @@
+/*
+ * Copyright 2018 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 "FIRTestCase.h"
+
+#import <FirebaseCore/FIRAnalyticsConfiguration+Internal.h>
+#import <FirebaseCore/FIRAnalyticsConfiguration.h>
+
+@interface FIRAnalyticsConfigurationTest : FIRTestCase
+/// A mock for [NSNotificationCenter defaultCenter].
+@property(nonatomic, strong) id notificationCenterMock;
+@end
+
+@implementation FIRAnalyticsConfigurationTest
+
+- (void)setUp {
+ [super setUp];
+ _notificationCenterMock = OCMPartialMock([NSNotificationCenter defaultCenter]);
+}
+
+- (void)tearDown {
+ [_notificationCenterMock stopMocking];
+ [super tearDown];
+}
+
+/// Test access to the shared instance.
+- (void)testSharedInstance {
+ FIRAnalyticsConfiguration *analyticsConfig = [FIRAnalyticsConfiguration sharedInstance];
+ XCTAssertNotNil(analyticsConfig);
+}
+
+/// Test that setting the minimum session interval on the singleton fires a notification.
+- (void)testMinimumSessionIntervalNotification {
+ FIRAnalyticsConfiguration *config = [FIRAnalyticsConfiguration sharedInstance];
+ [config setMinimumSessionInterval:2601];
+ NSString *notificationName = kFIRAnalyticsConfigurationSetMinimumSessionIntervalNotification;
+ OCMVerify([self.notificationCenterMock postNotificationName:notificationName
+ object:config
+ userInfo:@{
+ notificationName : @2601
+ }]);
+}
+
+/// Test that setting the minimum session timeout interval on the singleton fires a notification.
+- (void)testSessionTimeoutIntervalNotification {
+ FIRAnalyticsConfiguration *config = [FIRAnalyticsConfiguration sharedInstance];
+ [config setSessionTimeoutInterval:1000];
+ NSString *notificationName = kFIRAnalyticsConfigurationSetSessionTimeoutIntervalNotification;
+ OCMVerify([self.notificationCenterMock postNotificationName:notificationName
+ object:config
+ userInfo:@{
+ notificationName : @1000
+ }]);
+}
+
+- (void)testSettingAnalyticsCollectionEnabled {
+ // The ordering matters for these notifications.
+ [self.notificationCenterMock setExpectationOrderMatters:YES];
+
+ // Test setting to enabled.
+ FIRAnalyticsConfiguration *config = [FIRAnalyticsConfiguration sharedInstance];
+ NSString *notificationName = kFIRAnalyticsConfigurationSetEnabledNotification;
+ [config setAnalyticsCollectionEnabled:YES];
+ OCMVerify([self.notificationCenterMock postNotificationName:notificationName
+ object:config
+ userInfo:@{
+ notificationName : @YES
+ }]);
+
+ // Test setting to disabled.
+ [config setAnalyticsCollectionEnabled:NO];
+ OCMVerify([self.notificationCenterMock postNotificationName:notificationName
+ object:config
+ userInfo:@{
+ notificationName : @NO
+ }]);
+}
+
+- (void)testSettingAnalyticsCollectionPersistence {
+ id userDefaultsMock = OCMPartialMock([NSUserDefaults standardUserDefaults]);
+ FIRAnalyticsConfiguration *config = [FIRAnalyticsConfiguration sharedInstance];
+
+ // Test that defaults are written to when persistence is enabled.
+ [config setAnalyticsCollectionEnabled:YES persistSetting:YES];
+ OCMVerify([userDefaultsMock setObject:[NSNumber numberWithInteger:kFIRAnalyticsEnabledStateSetYes]
+ forKey:kFIRAPersistedConfigMeasurementEnabledStateKey]);
+
+ [config setAnalyticsCollectionEnabled:NO persistSetting:YES];
+ OCMVerify([userDefaultsMock setObject:[NSNumber numberWithInteger:kFIRAnalyticsEnabledStateSetNo]
+ forKey:kFIRAPersistedConfigMeasurementEnabledStateKey]);
+
+ // Test that defaults are not written to when persistence is disabled.
+ [config setAnalyticsCollectionEnabled:YES persistSetting:NO];
+ OCMReject([userDefaultsMock setObject:OCMOCK_ANY
+ forKey:kFIRAPersistedConfigMeasurementEnabledStateKey]);
+
+ [config setAnalyticsCollectionEnabled:NO persistSetting:NO];
+ OCMReject([userDefaultsMock setObject:OCMOCK_ANY
+ forKey:kFIRAPersistedConfigMeasurementEnabledStateKey]);
+
+ [userDefaultsMock stopMocking];
+}
+
+@end