DDBasicLoggingTests.m 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283
  1. // Software License Agreement (BSD License)
  2. //
  3. // Copyright (c) 2010-2025, Deusty, LLC
  4. // All rights reserved.
  5. //
  6. // Redistribution and use of this software in source and binary forms,
  7. // with or without modification, are permitted provided that the following conditions are met:
  8. //
  9. // * Redistributions of source code must retain the above copyright notice,
  10. // this list of conditions and the following disclaimer.
  11. //
  12. // * Neither the name of Deusty nor the names of its contributors may be used
  13. // to endorse or promote products derived from this software without specific
  14. // prior written permission of Deusty, LLC.
  15. @import XCTest;
  16. #import <CocoaLumberjack/DDLog.h>
  17. #import <CocoaLumberjack/DDLogMacros.h>
  18. #import <CocoaLumberjack/DDAbstractDatabaseLogger.h>
  19. #import "DDSampleFileManager.h"
  20. #import "DDSMocking.h"
  21. static const NSTimeInterval kAsyncExpectationTimeout = 3.0;
  22. static DDLogLevel ddLogLevel = DDLogLevelVerbose;
  23. static DDBasicMock<DDAbstractLogger *> *createAbstractLogger(void (^didLogBlock)(id)) {
  24. __auto_type logger = [DDBasicMock<DDAbstractLogger *> decoratedInstance:[[DDAbstractLogger alloc] init]];
  25. __auto_type argument = [DDBasicMockArgument alongsideWithBlock:didLogBlock];
  26. [logger addArgument:argument forSelector:@selector(logMessage:) atIndex:2];
  27. return logger;
  28. }
  29. @interface DDSingleLoggerLoggingTests : XCTestCase
  30. @property (nonatomic, strong) NSArray *logs;
  31. @property (nonatomic, strong) XCTestExpectation *expectation;
  32. @property (nonatomic, strong) DDAbstractLogger *logger;
  33. @property (nonatomic, assign) NSUInteger numberMessagesLogged;
  34. @property (nonatomic) dispatch_queue_t serial;
  35. @end
  36. @implementation DDSingleLoggerLoggingTests
  37. - (void)setupLoggers {
  38. __weak __auto_type weakSelf = self;
  39. self.logger = (DDAbstractLogger *)createAbstractLogger(^(DDLogMessage *logMessage) {
  40. dispatch_sync(self->_serial, ^{
  41. __auto_type strongSelf = weakSelf;
  42. XCTAssertTrue([logMessage isKindOfClass:[DDLogMessage class]]);
  43. XCTAssertTrue([strongSelf.logs containsObject:logMessage.message]);
  44. XCTAssertEqualObjects(logMessage.fileName, @"DDBasicLoggingTests");
  45. strongSelf.numberMessagesLogged++;
  46. if (strongSelf.numberMessagesLogged == [strongSelf.logs count]) {
  47. [strongSelf.expectation fulfill];
  48. }
  49. });
  50. });
  51. [DDLog addLogger:self.logger];
  52. }
  53. - (void)setUp {
  54. [super setUp];
  55. self.serial = dispatch_queue_create("serial", NULL);
  56. self.logs = @[];
  57. self.numberMessagesLogged = 0;
  58. ddLogLevel = DDLogLevelVerbose;
  59. [self setupLoggers];
  60. }
  61. - (void)tearDown {
  62. [DDLog removeAllLoggers];
  63. self.logger = nil;
  64. self.expectation = nil;
  65. [super tearDown];
  66. }
  67. - (void)testAll5DefaultLevelsAsync {
  68. self.expectation = [self expectationWithDescription:@"default log levels"];
  69. self.logs = @[ @"Error", @"Warn", @"Info", @"Debug", @"Verbose" ];
  70. DDLogError (@"Error");
  71. DDLogWarn (@"Warn");
  72. DDLogInfo (@"Info");
  73. DDLogDebug (@"Debug");
  74. DDLogVerbose(@"Verbose");
  75. [DDLog flushLog];
  76. [self waitForExpectationsWithTimeout:kAsyncExpectationTimeout handler:^(NSError *timeoutError) {
  77. XCTAssertNil(timeoutError);
  78. }];
  79. }
  80. - (void)testLoggerLogLevelAsync {
  81. self.expectation = [self expectationWithDescription:@"logger level"];
  82. self.logs = @[ @"Error", @"Warn" ];
  83. [DDLog removeLogger:self.logger];
  84. [DDLog addLogger:self.logger withLevel:DDLogLevelWarning];
  85. DDLogError (@"Error");
  86. DDLogWarn (@"Warn");
  87. DDLogInfo (@"Info");
  88. DDLogDebug (@"Debug");
  89. DDLogVerbose(@"Verbose");
  90. [DDLog flushLog];
  91. [self waitForExpectationsWithTimeout:kAsyncExpectationTimeout handler:^(NSError *timeoutError) {
  92. XCTAssertNil(timeoutError);
  93. }];
  94. }
  95. - (void)testGlobalLogLevelAsync {
  96. self.expectation = [self expectationWithDescription:@"ddLogLevel"];
  97. self.logs = @[ @"Error", @"Warn", @"Info" ];
  98. ddLogLevel = DDLogLevelInfo;
  99. DDLogError (@"Error");
  100. DDLogWarn (@"Warn");
  101. DDLogInfo (@"Info");
  102. DDLogDebug (@"Debug");
  103. DDLogVerbose(@"Verbose");
  104. [DDLog flushLog];
  105. [self waitForExpectationsWithTimeout:kAsyncExpectationTimeout handler:^(NSError *timeoutError) {
  106. XCTAssertNil(timeoutError);
  107. }];
  108. ddLogLevel = DDLogLevelVerbose;
  109. }
  110. @end
  111. static int const DDLoggerCount = 3;
  112. @interface DDMultipleLoggerLoggingTests : XCTestCase
  113. @property (nonatomic) NSArray *loggers;
  114. @property (nonatomic) NSArray *logs;
  115. @property (nonatomic) XCTestExpectation *expectation;
  116. @property (nonatomic) NSUInteger numberMessagesLogged;
  117. @property (nonatomic) dispatch_queue_t serial;
  118. @end
  119. @implementation DDMultipleLoggerLoggingTests
  120. - (void)setUp {
  121. [super setUp];
  122. self.serial = dispatch_queue_create("serial", NULL);
  123. self.logs = @[];
  124. self.numberMessagesLogged = 0;
  125. ddLogLevel = DDLogLevelVerbose;
  126. [self setupLoggers];
  127. }
  128. - (void)tearDown {
  129. [DDLog removeAllLoggers];
  130. self.loggers = nil;
  131. self.expectation = nil;
  132. [super tearDown];
  133. }
  134. - (void)setupLoggers {
  135. NSMutableArray *loggers = [NSMutableArray arrayWithCapacity:DDLoggerCount];
  136. for (NSUInteger i = 0; i < DDLoggerCount; i++) {
  137. __weak __auto_type weakSelf = self;
  138. __auto_type logger = (DDAbstractLogger *)createAbstractLogger(^(DDLogMessage *logMessage) {
  139. dispatch_sync(self->_serial, ^{
  140. __auto_type strongSelf = weakSelf;
  141. XCTAssertTrue([logMessage isKindOfClass:[DDLogMessage class]]);
  142. XCTAssertTrue([strongSelf.logs containsObject:logMessage.message]);
  143. XCTAssertEqualObjects(logMessage.fileName, @"DDBasicLoggingTests");
  144. strongSelf.numberMessagesLogged++;
  145. if (strongSelf.numberMessagesLogged == [strongSelf.logs count]) {
  146. [strongSelf.expectation fulfill];
  147. }
  148. });
  149. });
  150. [loggers addObject:logger];
  151. [DDLog addLogger:logger];
  152. }
  153. self.loggers = [loggers copy];
  154. }
  155. - (void)testAll5DefaultLevelsAsync {
  156. self.expectation = [self expectationWithDescription:@"default log levels"];
  157. self.logs = @[ @"Error" ];
  158. DDLogError(@"Error");
  159. [DDLog flushLog];
  160. [self waitForExpectationsWithTimeout:kAsyncExpectationTimeout handler:^(NSError *timeoutError) {
  161. XCTAssertNil(timeoutError);
  162. }];
  163. }
  164. @end
  165. @interface DDAbstractDatabaseLogger ()
  166. - (void)destroySaveTimer;
  167. - (void)updateAndResumeSaveTimer;
  168. - (void)createSuspendedSaveTimer;
  169. @end
  170. @interface DDTestDatabaseLogger : DDAbstractDatabaseLogger
  171. - (void)setUnsavedTime;
  172. - (void)suspendSaveTimer;
  173. @end
  174. @implementation DDTestDatabaseLogger
  175. - (void)setUnsavedTime
  176. {
  177. _unsavedTime = dispatch_time(DISPATCH_TIME_NOW, 0);
  178. }
  179. - (void)suspendSaveTimer {
  180. if (_saveTimer != NULL && _saveTimerSuspended == 0) {
  181. dispatch_suspend(_saveTimer);
  182. _saveTimerSuspended = 1;
  183. }
  184. }
  185. @end
  186. @interface DDAbstractDatabaseLoggerTests : XCTestCase
  187. @property (nonatomic) DDTestDatabaseLogger *logger;
  188. @end
  189. @implementation DDAbstractDatabaseLoggerTests
  190. - (void)setUp {
  191. [super setUp];
  192. self.logger = [[DDTestDatabaseLogger alloc] init];
  193. }
  194. - (void)tearDown {
  195. self.logger = nil;
  196. [super tearDown];
  197. }
  198. - (void)testDestroyDeactivatedSaveTimer {
  199. [self.logger createSuspendedSaveTimer];
  200. [self.logger destroySaveTimer];
  201. }
  202. - (void)testDestroyActivatedSaveTimer {
  203. [self.logger createSuspendedSaveTimer];
  204. [self.logger setUnsavedTime];
  205. [self.logger updateAndResumeSaveTimer];
  206. [self.logger destroySaveTimer];
  207. }
  208. - (void)testDestroySuspendedSaveTimer {
  209. [self.logger createSuspendedSaveTimer];
  210. [self.logger setUnsavedTime];
  211. [self.logger updateAndResumeSaveTimer];
  212. [self.logger suspendSaveTimer];
  213. [self.logger destroySaveTimer];
  214. }
  215. @end