-
Notifications
You must be signed in to change notification settings - Fork 232
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1346 from BranchMetrics/SDK-2163
[SDK-2163] Added new BranchLogger class
- Loading branch information
Showing
44 changed files
with
553 additions
and
570 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
// | ||
// BranchLoggerTests.m | ||
// Branch-SDK-Tests | ||
// | ||
// Created by Nipun Singh on 2/5/24. | ||
// Copyright © 2024 Branch, Inc. All rights reserved. | ||
// | ||
|
||
#import <XCTest/XCTest.h> | ||
#import "BranchLogger.h" | ||
#import "Branch.h" | ||
|
||
@interface BranchLoggerTests : XCTestCase | ||
@end | ||
|
||
@implementation BranchLoggerTests | ||
|
||
- (void)testEnableLoggingSetsCorrectDefaultLevel { | ||
[[Branch getInstance] enableLogging]; | ||
XCTAssertEqual([BranchLogger shared].logLevelThreshold, BranchLogLevelDebug, "Default log level should be Debug."); | ||
} | ||
|
||
- (void)testLogLevelThresholdBlocksLowerLevels { | ||
BranchLogger *logger = [BranchLogger new]; | ||
logger.loggingEnabled = true; | ||
logger.logLevelThreshold = BranchLogLevelDebug; | ||
|
||
XCTestExpectation *expectation = [self expectationWithDescription:@"Log callback expectation for message that should pass the threshold"]; | ||
|
||
logger.logCallback = ^(NSString * _Nonnull message, BranchLogLevel logLevel, NSError * _Nullable error) { | ||
if ([message isEqualToString:@"[BranchSDK][Debug][BranchLoggerTests testLogLevelThresholdBlocksLowerLevels] This message should trigger the log callback."] && logLevel >= BranchLogLevelDebug) { | ||
[expectation fulfill]; | ||
} else if (logLevel == BranchLogLevelVerbose) { | ||
XCTFail(); | ||
} | ||
}; | ||
|
||
[logger logVerbose:@"This verbose message should not trigger the log callback."]; | ||
[logger logDebug:@"This message should trigger the log callback."]; | ||
|
||
[self waitForExpectationsWithTimeout:1 handler:nil]; | ||
} | ||
|
||
- (void)testLogCallbackExecutesWithCorrectParameters { | ||
XCTestExpectation *expectation = [self expectationWithDescription:@"Log callback expectation"]; | ||
NSString *expectedMessage = @"[BranchSDK][Info][BranchLoggerTests testLogCallbackExecutesWithCorrectParameters] Test message"; | ||
BranchLogLevel expectedLevel = BranchLogLevelInfo; | ||
|
||
BranchLogger *logger = [BranchLogger new]; | ||
|
||
logger.logCallback = ^(NSString * _Nonnull message, BranchLogLevel logLevel, NSError * _Nullable error) { | ||
XCTAssertEqualObjects(message, expectedMessage, "Logged message does not match expected message."); | ||
XCTAssertEqual(logLevel, expectedLevel, "Logged level does not match expected level."); | ||
XCTAssertNil(error, "Error should be nil."); | ||
[expectation fulfill]; | ||
}; | ||
|
||
logger.loggingEnabled = YES; | ||
logger.logLevelThreshold = BranchLogLevelInfo; | ||
[logger logInfo:@"Test message"]; | ||
|
||
[self waitForExpectationsWithTimeout:1 handler:nil]; | ||
} | ||
|
||
- (void)testLogLevelSpecificityFiltersLowerLevels { | ||
BranchLogger *logger = [BranchLogger new]; | ||
logger.loggingEnabled = YES; | ||
logger.logLevelThreshold = BranchLogLevelWarning; | ||
|
||
XCTestExpectation *verboseExpectation = [self expectationWithDescription:@"Verbose log callback"]; | ||
verboseExpectation.inverted = YES; | ||
XCTestExpectation *errorExpectation = [self expectationWithDescription:@"Error log callback"]; | ||
|
||
__block NSUInteger callbackCount = 0; | ||
logger.logCallback = ^(NSString * _Nonnull message, BranchLogLevel logLevel, NSError * _Nullable error) { | ||
if (logLevel == BranchLogLevelVerbose) { | ||
[verboseExpectation fulfill]; | ||
} else if (logLevel == BranchLogLevelError) { | ||
[errorExpectation fulfill]; | ||
} | ||
callbackCount++; | ||
}; | ||
|
||
[logger logVerbose:@"This should not be logged due to log level threshold."]; | ||
[logger logError:@"This should be logged" error:nil]; | ||
|
||
[self waitForExpectations:@[verboseExpectation, errorExpectation] timeout:2]; | ||
XCTAssertEqual(callbackCount, 1, "Only one log callback should have been invoked."); | ||
} | ||
|
||
- (void)testErrorLoggingIncludesErrorDetails { | ||
BranchLogger *logger = [BranchLogger new]; | ||
logger.loggingEnabled = YES; | ||
|
||
XCTestExpectation *expectation = [self expectationWithDescription:@"Error log includes error details"]; | ||
|
||
NSError *testError = [NSError errorWithDomain:@"TestDomain" code:42 userInfo:@{NSLocalizedDescriptionKey: @"Test error description"}]; | ||
logger.logCallback = ^(NSString * _Nonnull message, BranchLogLevel logLevel, NSError * _Nullable error) { | ||
if ([message containsString:@"Test error description"] && error == testError) { | ||
[expectation fulfill]; | ||
} | ||
}; | ||
|
||
[logger logError:@"Testing error logging" error:testError]; | ||
|
||
[self waitForExpectationsWithTimeout:1 handler:nil]; | ||
} | ||
|
||
@end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.