FIRLoggerTest.m 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. // Copyright 2017 Google
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #ifdef DEBUG
  15. // The tests depend upon library methods only built with #ifdef DEBUG
  16. #import "FirebaseCore/Tests/Unit/FIRTestCase.h"
  17. // TODO - FIRLoggerTest should be split into a separate FIRLoggerTest and GULLoggerTest.
  18. // No test should include both includes.
  19. #import <GoogleUtilities/GULLogger.h>
  20. #import "FirebaseCore/Extension/FIRLogger.h"
  21. #import "FirebaseCore/Sources/Public/FirebaseCore/FIRLoggerLevel.h"
  22. #import <asl.h>
  23. // The following constants are exposed from FIRLogger for unit tests.
  24. extern NSString *const kFIRDisableDebugModeApplicationArgument;
  25. extern NSString *const kFIREnableDebugModeApplicationArgument;
  26. /// Key for the debug mode bit in NSUserDefaults.
  27. extern NSString *const kFIRPersistedDebugModeKey;
  28. extern const char *kGULLoggerASLClientFacilityName;
  29. extern void FIRResetLogger(void);
  30. extern void FIRSetLoggerUserDefaults(NSUserDefaults *defaults);
  31. extern aslclient getGULLoggerClient(void);
  32. extern dispatch_queue_t getGULClientQueue(void);
  33. extern BOOL getGULLoggerDebugMode(void);
  34. static NSString *const kMessageCode = @"I-COR000001";
  35. @interface FIRLoggerTest : FIRTestCase
  36. @property(nonatomic) NSString *randomLogString;
  37. @property(nonatomic, strong) NSUserDefaults *defaults;
  38. @end
  39. @implementation FIRLoggerTest
  40. - (void)setUp {
  41. [super setUp];
  42. FIRResetLogger();
  43. // Stub NSUserDefaults for cleaner testing.
  44. _defaults = [[NSUserDefaults alloc] initWithSuiteName:@"com.firebase.logger_test"];
  45. FIRSetLoggerUserDefaults(_defaults);
  46. }
  47. - (void)tearDown {
  48. [super tearDown];
  49. _defaults = nil;
  50. }
  51. // Test some stable variables to make sure they weren't accidentally changed.
  52. - (void)testStableVariables {
  53. // Strings of type FIRLoggerServices.
  54. XCTAssertEqualObjects(kFIRLoggerAnalytics, @"[FirebaseAnalytics]");
  55. XCTAssertEqualObjects(kFIRLoggerCore, @"[FirebaseCore]");
  56. }
  57. - (void)testInitializeASLForNonDebugMode {
  58. // Stub.
  59. id processInfoMock = [OCMockObject partialMockForObject:[NSProcessInfo processInfo]];
  60. NSArray *arguments = @[ kFIRDisableDebugModeApplicationArgument ];
  61. [[[processInfoMock stub] andReturn:arguments] arguments];
  62. // Test.
  63. FIRLogError(kFIRLoggerCore, kMessageCode, @"Some error.");
  64. // Assert.
  65. #if MAKE_THREAD_SAFE
  66. NSNumber *debugMode = [self.defaults objectForKey:kFIRPersistedDebugModeKey];
  67. XCTAssertNil(debugMode);
  68. XCTAssertFalse(getGULLoggerDebugMode());
  69. #endif
  70. // Stop.
  71. [processInfoMock stopMocking];
  72. }
  73. - (void)testInitializeASLForDebugModeWithArgument {
  74. // Stub.
  75. id processInfoMock = [OCMockObject partialMockForObject:[NSProcessInfo processInfo]];
  76. NSArray *arguments = @[ kFIREnableDebugModeApplicationArgument ];
  77. [[[processInfoMock stub] andReturn:arguments] arguments];
  78. // Test.
  79. FIRLogError(kFIRLoggerCore, kMessageCode, @"Some error.");
  80. #ifdef MAKE_THREAD_SAFE
  81. // Assert.
  82. NSNumber *debugMode = [self.defaults objectForKey:kGULPersistedDebugModeKey];
  83. XCTAssertTrue(debugMode.boolValue);
  84. XCTAssertTrue(getGULLoggerDebugMode());
  85. #endif
  86. // Stop.
  87. [processInfoMock stopMocking];
  88. }
  89. - (void)testInitializeForDebugModeWithUserDefaults {
  90. // Stub.
  91. NSNumber *debugMode = @YES;
  92. [self.defaults setBool:debugMode.boolValue forKey:kFIRPersistedDebugModeKey];
  93. // Test.
  94. FIRLogError(kFIRLoggerCore, kMessageCode, @"Some error.");
  95. // Assert.
  96. debugMode = [self.defaults objectForKey:kFIRPersistedDebugModeKey];
  97. XCTAssertTrue(debugMode.boolValue);
  98. }
  99. - (void)testMessageCodeFormat {
  100. // Valid case.
  101. XCTAssertNoThrow(FIRLogError(kFIRLoggerCore, @"I-APP000001", @"Message."));
  102. // An extra dash or missing dash should fail.
  103. XCTAssertThrows(FIRLogError(kFIRLoggerCore, @"I-APP-000001", @"Message."));
  104. XCTAssertThrows(FIRLogError(kFIRLoggerCore, @"IAPP000001", @"Message."));
  105. // Wrong number of digits should fail.
  106. XCTAssertThrows(FIRLogError(kFIRLoggerCore, @"I-APP00001", @"Message."));
  107. XCTAssertThrows(FIRLogError(kFIRLoggerCore, @"I-APP0000001", @"Message."));
  108. // Lowercase should fail.
  109. XCTAssertThrows(FIRLogError(kFIRLoggerCore, @"I-app000001", @"Message."));
  110. // nil or empty message code should fail.
  111. #pragma clang diagnostic push
  112. #pragma clang diagnostic ignored "-Wnonnull"
  113. XCTAssertThrows(FIRLogError(kFIRLoggerCore, nil, @"Message."));
  114. #pragma clang diagnostic pop
  115. XCTAssertThrows(FIRLogError(kFIRLoggerCore, @"", @"Message."));
  116. // Android message code should fail.
  117. XCTAssertThrows(FIRLogError(kFIRLoggerCore, @"A-APP000001", @"Message."));
  118. }
  119. - (void)testLoggerInterface {
  120. XCTAssertNoThrow(FIRLogError(kFIRLoggerCore, kMessageCode, @"Message."));
  121. XCTAssertNoThrow(FIRLogError(kFIRLoggerCore, kMessageCode, @"Configure %@.", @"blah"));
  122. XCTAssertNoThrow(FIRLogWarning(kFIRLoggerCore, kMessageCode, @"Message."));
  123. XCTAssertNoThrow(FIRLogWarning(kFIRLoggerCore, kMessageCode, @"Configure %@.", @"blah"));
  124. XCTAssertNoThrow(FIRLogNotice(kFIRLoggerCore, kMessageCode, @"Message."));
  125. XCTAssertNoThrow(FIRLogNotice(kFIRLoggerCore, kMessageCode, @"Configure %@.", @"blah"));
  126. XCTAssertNoThrow(FIRLogInfo(kFIRLoggerCore, kMessageCode, @"Message."));
  127. XCTAssertNoThrow(FIRLogInfo(kFIRLoggerCore, kMessageCode, @"Configure %@.", @"blah"));
  128. XCTAssertNoThrow(FIRLogDebug(kFIRLoggerCore, kMessageCode, @"Message."));
  129. XCTAssertNoThrow(FIRLogDebug(kFIRLoggerCore, kMessageCode, @"Configure %@.", @"blah"));
  130. }
  131. // The FIRLoggerLevel enum must match the ASL_LEVEL_* constants, but we manually redefine
  132. // them in FIRLoggerLevel.h since we cannot include <asl.h> (see b/34976089 for more details).
  133. // This test ensures the constants match.
  134. - (void)testFIRLoggerLevelValues {
  135. XCTAssertEqual(FIRLoggerLevelError, ASL_LEVEL_ERR);
  136. XCTAssertEqual(FIRLoggerLevelWarning, ASL_LEVEL_WARNING);
  137. XCTAssertEqual(FIRLoggerLevelNotice, ASL_LEVEL_NOTICE);
  138. XCTAssertEqual(FIRLoggerLevelInfo, ASL_LEVEL_INFO);
  139. XCTAssertEqual(FIRLoggerLevelDebug, ASL_LEVEL_DEBUG);
  140. }
  141. - (void)testFIRGetLoggerLevel {
  142. FIRLoggerLevel loggerLevel = FIRGetLoggerLevel();
  143. // The default logger level is FIRLoggerLevelNotice.
  144. XCTAssertEqual(loggerLevel, FIRLoggerLevelNotice);
  145. }
  146. - (void)testFIRSetLoggerLevel {
  147. FIRSetLoggerLevel(FIRLoggerLevelDebug);
  148. FIRLoggerLevel loggerLevel = FIRGetLoggerLevel();
  149. // The default logger level is FIRLoggerLevelNotice.
  150. XCTAssertEqual(loggerLevel, FIRLoggerLevelDebug);
  151. }
  152. - (void)testFIRResetLogger_ResetsLoggerLevel {
  153. FIRSetLoggerLevel(FIRLoggerLevelDebug);
  154. FIRResetLogger();
  155. FIRLoggerLevel loggerLevel = FIRGetLoggerLevel();
  156. // The default logger level is FIRLoggerLevelNotice.
  157. XCTAssertEqual(loggerLevel, FIRLoggerLevelNotice);
  158. }
  159. @end
  160. #endif