xref: /aosp_15_r20/external/webrtc/sdk/objc/unittests/RTCCallbackLogger_xctest.m (revision d9f758449e529ab9291ac668be2861e7a55c2422)
1*d9f75844SAndroid Build Coastguard Worker/*
2*d9f75844SAndroid Build Coastguard Worker *  Copyright 2018 The WebRTC project authors. All Rights Reserved.
3*d9f75844SAndroid Build Coastguard Worker *
4*d9f75844SAndroid Build Coastguard Worker *  Use of this source code is governed by a BSD-style license
5*d9f75844SAndroid Build Coastguard Worker *  that can be found in the LICENSE file in the root of the source
6*d9f75844SAndroid Build Coastguard Worker *  tree. An additional intellectual property rights grant can be found
7*d9f75844SAndroid Build Coastguard Worker *  in the file PATENTS.  All contributing project authors may
8*d9f75844SAndroid Build Coastguard Worker *  be found in the AUTHORS file in the root of the source tree.
9*d9f75844SAndroid Build Coastguard Worker */
10*d9f75844SAndroid Build Coastguard Worker
11*d9f75844SAndroid Build Coastguard Worker#import "api/logging/RTCCallbackLogger.h"
12*d9f75844SAndroid Build Coastguard Worker
13*d9f75844SAndroid Build Coastguard Worker#import <XCTest/XCTest.h>
14*d9f75844SAndroid Build Coastguard Worker
15*d9f75844SAndroid Build Coastguard Worker@interface RTCCallbackLoggerTests : XCTestCase
16*d9f75844SAndroid Build Coastguard Worker
17*d9f75844SAndroid Build Coastguard Worker@property(nonatomic, strong) RTC_OBJC_TYPE(RTCCallbackLogger) * logger;
18*d9f75844SAndroid Build Coastguard Worker
19*d9f75844SAndroid Build Coastguard Worker@end
20*d9f75844SAndroid Build Coastguard Worker
21*d9f75844SAndroid Build Coastguard Worker@implementation RTCCallbackLoggerTests
22*d9f75844SAndroid Build Coastguard Worker
23*d9f75844SAndroid Build Coastguard Worker@synthesize logger;
24*d9f75844SAndroid Build Coastguard Worker
25*d9f75844SAndroid Build Coastguard Worker- (void)setUp {
26*d9f75844SAndroid Build Coastguard Worker  self.logger = [[RTC_OBJC_TYPE(RTCCallbackLogger) alloc] init];
27*d9f75844SAndroid Build Coastguard Worker}
28*d9f75844SAndroid Build Coastguard Worker
29*d9f75844SAndroid Build Coastguard Worker- (void)tearDown {
30*d9f75844SAndroid Build Coastguard Worker  self.logger = nil;
31*d9f75844SAndroid Build Coastguard Worker}
32*d9f75844SAndroid Build Coastguard Worker
33*d9f75844SAndroid Build Coastguard Worker- (void)testDefaultSeverityLevel {
34*d9f75844SAndroid Build Coastguard Worker  XCTAssertEqual(self.logger.severity, RTCLoggingSeverityInfo);
35*d9f75844SAndroid Build Coastguard Worker}
36*d9f75844SAndroid Build Coastguard Worker
37*d9f75844SAndroid Build Coastguard Worker- (void)testCallbackGetsCalledForAppropriateLevel {
38*d9f75844SAndroid Build Coastguard Worker  self.logger.severity = RTCLoggingSeverityWarning;
39*d9f75844SAndroid Build Coastguard Worker
40*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"callbackWarning"];
41*d9f75844SAndroid Build Coastguard Worker
42*d9f75844SAndroid Build Coastguard Worker  [self.logger start:^(NSString *message) {
43*d9f75844SAndroid Build Coastguard Worker    XCTAssertTrue([message hasSuffix:@"Horrible error\n"]);
44*d9f75844SAndroid Build Coastguard Worker    [callbackExpectation fulfill];
45*d9f75844SAndroid Build Coastguard Worker  }];
46*d9f75844SAndroid Build Coastguard Worker
47*d9f75844SAndroid Build Coastguard Worker  RTCLogError("Horrible error");
48*d9f75844SAndroid Build Coastguard Worker
49*d9f75844SAndroid Build Coastguard Worker  [self waitForExpectations:@[ callbackExpectation ] timeout:10.0];
50*d9f75844SAndroid Build Coastguard Worker}
51*d9f75844SAndroid Build Coastguard Worker
52*d9f75844SAndroid Build Coastguard Worker- (void)testCallbackWithSeverityGetsCalledForAppropriateLevel {
53*d9f75844SAndroid Build Coastguard Worker  self.logger.severity = RTCLoggingSeverityWarning;
54*d9f75844SAndroid Build Coastguard Worker
55*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"callbackWarning"];
56*d9f75844SAndroid Build Coastguard Worker
57*d9f75844SAndroid Build Coastguard Worker  [self.logger
58*d9f75844SAndroid Build Coastguard Worker      startWithMessageAndSeverityHandler:^(NSString *message, RTCLoggingSeverity severity) {
59*d9f75844SAndroid Build Coastguard Worker        XCTAssertTrue([message hasSuffix:@"Horrible error\n"]);
60*d9f75844SAndroid Build Coastguard Worker        XCTAssertEqual(severity, RTCLoggingSeverityError);
61*d9f75844SAndroid Build Coastguard Worker        [callbackExpectation fulfill];
62*d9f75844SAndroid Build Coastguard Worker      }];
63*d9f75844SAndroid Build Coastguard Worker
64*d9f75844SAndroid Build Coastguard Worker  RTCLogError("Horrible error");
65*d9f75844SAndroid Build Coastguard Worker
66*d9f75844SAndroid Build Coastguard Worker  [self waitForExpectations:@[ callbackExpectation ] timeout:10.0];
67*d9f75844SAndroid Build Coastguard Worker}
68*d9f75844SAndroid Build Coastguard Worker
69*d9f75844SAndroid Build Coastguard Worker- (void)testCallbackDoesNotGetCalledForOtherLevels {
70*d9f75844SAndroid Build Coastguard Worker  self.logger.severity = RTCLoggingSeverityError;
71*d9f75844SAndroid Build Coastguard Worker
72*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"callbackError"];
73*d9f75844SAndroid Build Coastguard Worker
74*d9f75844SAndroid Build Coastguard Worker  [self.logger start:^(NSString *message) {
75*d9f75844SAndroid Build Coastguard Worker    XCTAssertTrue([message hasSuffix:@"Horrible error\n"]);
76*d9f75844SAndroid Build Coastguard Worker    [callbackExpectation fulfill];
77*d9f75844SAndroid Build Coastguard Worker  }];
78*d9f75844SAndroid Build Coastguard Worker
79*d9f75844SAndroid Build Coastguard Worker  RTCLogInfo("Just some info");
80*d9f75844SAndroid Build Coastguard Worker  RTCLogWarning("Warning warning");
81*d9f75844SAndroid Build Coastguard Worker  RTCLogError("Horrible error");
82*d9f75844SAndroid Build Coastguard Worker
83*d9f75844SAndroid Build Coastguard Worker  [self waitForExpectations:@[ callbackExpectation ] timeout:10.0];
84*d9f75844SAndroid Build Coastguard Worker}
85*d9f75844SAndroid Build Coastguard Worker
86*d9f75844SAndroid Build Coastguard Worker- (void)testCallbackWithSeverityDoesNotGetCalledForOtherLevels {
87*d9f75844SAndroid Build Coastguard Worker  self.logger.severity = RTCLoggingSeverityError;
88*d9f75844SAndroid Build Coastguard Worker
89*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"callbackError"];
90*d9f75844SAndroid Build Coastguard Worker
91*d9f75844SAndroid Build Coastguard Worker  [self.logger
92*d9f75844SAndroid Build Coastguard Worker      startWithMessageAndSeverityHandler:^(NSString *message, RTCLoggingSeverity severity) {
93*d9f75844SAndroid Build Coastguard Worker        XCTAssertTrue([message hasSuffix:@"Horrible error\n"]);
94*d9f75844SAndroid Build Coastguard Worker        XCTAssertEqual(severity, RTCLoggingSeverityError);
95*d9f75844SAndroid Build Coastguard Worker        [callbackExpectation fulfill];
96*d9f75844SAndroid Build Coastguard Worker      }];
97*d9f75844SAndroid Build Coastguard Worker
98*d9f75844SAndroid Build Coastguard Worker  RTCLogInfo("Just some info");
99*d9f75844SAndroid Build Coastguard Worker  RTCLogWarning("Warning warning");
100*d9f75844SAndroid Build Coastguard Worker  RTCLogError("Horrible error");
101*d9f75844SAndroid Build Coastguard Worker
102*d9f75844SAndroid Build Coastguard Worker  [self waitForExpectations:@[ callbackExpectation ] timeout:10.0];
103*d9f75844SAndroid Build Coastguard Worker}
104*d9f75844SAndroid Build Coastguard Worker
105*d9f75844SAndroid Build Coastguard Worker- (void)testCallbackDoesNotgetCalledForSeverityNone {
106*d9f75844SAndroid Build Coastguard Worker  self.logger.severity = RTCLoggingSeverityNone;
107*d9f75844SAndroid Build Coastguard Worker
108*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"unexpectedCallback"];
109*d9f75844SAndroid Build Coastguard Worker
110*d9f75844SAndroid Build Coastguard Worker  [self.logger start:^(NSString *message) {
111*d9f75844SAndroid Build Coastguard Worker    [callbackExpectation fulfill];
112*d9f75844SAndroid Build Coastguard Worker    XCTAssertTrue(false);
113*d9f75844SAndroid Build Coastguard Worker  }];
114*d9f75844SAndroid Build Coastguard Worker
115*d9f75844SAndroid Build Coastguard Worker  RTCLogInfo("Just some info");
116*d9f75844SAndroid Build Coastguard Worker  RTCLogWarning("Warning warning");
117*d9f75844SAndroid Build Coastguard Worker  RTCLogError("Horrible error");
118*d9f75844SAndroid Build Coastguard Worker
119*d9f75844SAndroid Build Coastguard Worker  XCTWaiter *waiter = [[XCTWaiter alloc] init];
120*d9f75844SAndroid Build Coastguard Worker  XCTWaiterResult result = [waiter waitForExpectations:@[ callbackExpectation ] timeout:1.0];
121*d9f75844SAndroid Build Coastguard Worker  XCTAssertEqual(result, XCTWaiterResultTimedOut);
122*d9f75844SAndroid Build Coastguard Worker}
123*d9f75844SAndroid Build Coastguard Worker
124*d9f75844SAndroid Build Coastguard Worker- (void)testCallbackWithSeverityDoesNotgetCalledForSeverityNone {
125*d9f75844SAndroid Build Coastguard Worker  self.logger.severity = RTCLoggingSeverityNone;
126*d9f75844SAndroid Build Coastguard Worker
127*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"unexpectedCallback"];
128*d9f75844SAndroid Build Coastguard Worker
129*d9f75844SAndroid Build Coastguard Worker  [self.logger
130*d9f75844SAndroid Build Coastguard Worker      startWithMessageAndSeverityHandler:^(NSString *message, RTCLoggingSeverity severity) {
131*d9f75844SAndroid Build Coastguard Worker        [callbackExpectation fulfill];
132*d9f75844SAndroid Build Coastguard Worker        XCTAssertTrue(false);
133*d9f75844SAndroid Build Coastguard Worker      }];
134*d9f75844SAndroid Build Coastguard Worker
135*d9f75844SAndroid Build Coastguard Worker  RTCLogInfo("Just some info");
136*d9f75844SAndroid Build Coastguard Worker  RTCLogWarning("Warning warning");
137*d9f75844SAndroid Build Coastguard Worker  RTCLogError("Horrible error");
138*d9f75844SAndroid Build Coastguard Worker
139*d9f75844SAndroid Build Coastguard Worker  XCTWaiter *waiter = [[XCTWaiter alloc] init];
140*d9f75844SAndroid Build Coastguard Worker  XCTWaiterResult result = [waiter waitForExpectations:@[ callbackExpectation ] timeout:1.0];
141*d9f75844SAndroid Build Coastguard Worker  XCTAssertEqual(result, XCTWaiterResultTimedOut);
142*d9f75844SAndroid Build Coastguard Worker}
143*d9f75844SAndroid Build Coastguard Worker
144*d9f75844SAndroid Build Coastguard Worker- (void)testStartingWithNilCallbackDoesNotCrash {
145*d9f75844SAndroid Build Coastguard Worker  [self.logger start:nil];
146*d9f75844SAndroid Build Coastguard Worker
147*d9f75844SAndroid Build Coastguard Worker  RTCLogError("Horrible error");
148*d9f75844SAndroid Build Coastguard Worker}
149*d9f75844SAndroid Build Coastguard Worker
150*d9f75844SAndroid Build Coastguard Worker- (void)testStartingWithNilCallbackWithSeverityDoesNotCrash {
151*d9f75844SAndroid Build Coastguard Worker  [self.logger startWithMessageAndSeverityHandler:nil];
152*d9f75844SAndroid Build Coastguard Worker
153*d9f75844SAndroid Build Coastguard Worker  RTCLogError("Horrible error");
154*d9f75844SAndroid Build Coastguard Worker}
155*d9f75844SAndroid Build Coastguard Worker
156*d9f75844SAndroid Build Coastguard Worker- (void)testStopCallbackLogger {
157*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"stopped"];
158*d9f75844SAndroid Build Coastguard Worker
159*d9f75844SAndroid Build Coastguard Worker  [self.logger start:^(NSString *message) {
160*d9f75844SAndroid Build Coastguard Worker    [callbackExpectation fulfill];
161*d9f75844SAndroid Build Coastguard Worker  }];
162*d9f75844SAndroid Build Coastguard Worker
163*d9f75844SAndroid Build Coastguard Worker  [self.logger stop];
164*d9f75844SAndroid Build Coastguard Worker
165*d9f75844SAndroid Build Coastguard Worker  RTCLogInfo("Just some info");
166*d9f75844SAndroid Build Coastguard Worker
167*d9f75844SAndroid Build Coastguard Worker  XCTWaiter *waiter = [[XCTWaiter alloc] init];
168*d9f75844SAndroid Build Coastguard Worker  XCTWaiterResult result = [waiter waitForExpectations:@[ callbackExpectation ] timeout:1.0];
169*d9f75844SAndroid Build Coastguard Worker  XCTAssertEqual(result, XCTWaiterResultTimedOut);
170*d9f75844SAndroid Build Coastguard Worker}
171*d9f75844SAndroid Build Coastguard Worker
172*d9f75844SAndroid Build Coastguard Worker- (void)testStopCallbackWithSeverityLogger {
173*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"stopped"];
174*d9f75844SAndroid Build Coastguard Worker
175*d9f75844SAndroid Build Coastguard Worker  [self.logger
176*d9f75844SAndroid Build Coastguard Worker      startWithMessageAndSeverityHandler:^(NSString *message, RTCLoggingSeverity loggingServerity) {
177*d9f75844SAndroid Build Coastguard Worker        [callbackExpectation fulfill];
178*d9f75844SAndroid Build Coastguard Worker      }];
179*d9f75844SAndroid Build Coastguard Worker
180*d9f75844SAndroid Build Coastguard Worker  [self.logger stop];
181*d9f75844SAndroid Build Coastguard Worker
182*d9f75844SAndroid Build Coastguard Worker  RTCLogInfo("Just some info");
183*d9f75844SAndroid Build Coastguard Worker
184*d9f75844SAndroid Build Coastguard Worker  XCTWaiter *waiter = [[XCTWaiter alloc] init];
185*d9f75844SAndroid Build Coastguard Worker  XCTWaiterResult result = [waiter waitForExpectations:@[ callbackExpectation ] timeout:1.0];
186*d9f75844SAndroid Build Coastguard Worker  XCTAssertEqual(result, XCTWaiterResultTimedOut);
187*d9f75844SAndroid Build Coastguard Worker}
188*d9f75844SAndroid Build Coastguard Worker
189*d9f75844SAndroid Build Coastguard Worker- (void)testDestroyingCallbackLogger {
190*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"destroyed"];
191*d9f75844SAndroid Build Coastguard Worker
192*d9f75844SAndroid Build Coastguard Worker  [self.logger start:^(NSString *message) {
193*d9f75844SAndroid Build Coastguard Worker    [callbackExpectation fulfill];
194*d9f75844SAndroid Build Coastguard Worker  }];
195*d9f75844SAndroid Build Coastguard Worker
196*d9f75844SAndroid Build Coastguard Worker  self.logger = nil;
197*d9f75844SAndroid Build Coastguard Worker
198*d9f75844SAndroid Build Coastguard Worker  RTCLogInfo("Just some info");
199*d9f75844SAndroid Build Coastguard Worker
200*d9f75844SAndroid Build Coastguard Worker  XCTWaiter *waiter = [[XCTWaiter alloc] init];
201*d9f75844SAndroid Build Coastguard Worker  XCTWaiterResult result = [waiter waitForExpectations:@[ callbackExpectation ] timeout:1.0];
202*d9f75844SAndroid Build Coastguard Worker  XCTAssertEqual(result, XCTWaiterResultTimedOut);
203*d9f75844SAndroid Build Coastguard Worker}
204*d9f75844SAndroid Build Coastguard Worker
205*d9f75844SAndroid Build Coastguard Worker- (void)testDestroyingCallbackWithSeverityLogger {
206*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"destroyed"];
207*d9f75844SAndroid Build Coastguard Worker
208*d9f75844SAndroid Build Coastguard Worker  [self.logger
209*d9f75844SAndroid Build Coastguard Worker      startWithMessageAndSeverityHandler:^(NSString *message, RTCLoggingSeverity loggingServerity) {
210*d9f75844SAndroid Build Coastguard Worker        [callbackExpectation fulfill];
211*d9f75844SAndroid Build Coastguard Worker      }];
212*d9f75844SAndroid Build Coastguard Worker
213*d9f75844SAndroid Build Coastguard Worker  self.logger = nil;
214*d9f75844SAndroid Build Coastguard Worker
215*d9f75844SAndroid Build Coastguard Worker  RTCLogInfo("Just some info");
216*d9f75844SAndroid Build Coastguard Worker
217*d9f75844SAndroid Build Coastguard Worker  XCTWaiter *waiter = [[XCTWaiter alloc] init];
218*d9f75844SAndroid Build Coastguard Worker  XCTWaiterResult result = [waiter waitForExpectations:@[ callbackExpectation ] timeout:1.0];
219*d9f75844SAndroid Build Coastguard Worker  XCTAssertEqual(result, XCTWaiterResultTimedOut);
220*d9f75844SAndroid Build Coastguard Worker}
221*d9f75844SAndroid Build Coastguard Worker
222*d9f75844SAndroid Build Coastguard Worker- (void)testCallbackWithSeverityLoggerCannotStartTwice {
223*d9f75844SAndroid Build Coastguard Worker  self.logger.severity = RTCLoggingSeverityWarning;
224*d9f75844SAndroid Build Coastguard Worker
225*d9f75844SAndroid Build Coastguard Worker  XCTestExpectation *callbackExpectation = [self expectationWithDescription:@"callbackWarning"];
226*d9f75844SAndroid Build Coastguard Worker
227*d9f75844SAndroid Build Coastguard Worker  [self.logger
228*d9f75844SAndroid Build Coastguard Worker      startWithMessageAndSeverityHandler:^(NSString *message, RTCLoggingSeverity loggingServerity) {
229*d9f75844SAndroid Build Coastguard Worker        XCTAssertTrue([message hasSuffix:@"Horrible error\n"]);
230*d9f75844SAndroid Build Coastguard Worker        XCTAssertEqual(loggingServerity, RTCLoggingSeverityError);
231*d9f75844SAndroid Build Coastguard Worker        [callbackExpectation fulfill];
232*d9f75844SAndroid Build Coastguard Worker      }];
233*d9f75844SAndroid Build Coastguard Worker
234*d9f75844SAndroid Build Coastguard Worker  [self.logger start:^(NSString *message) {
235*d9f75844SAndroid Build Coastguard Worker    [callbackExpectation fulfill];
236*d9f75844SAndroid Build Coastguard Worker    XCTAssertTrue(false);
237*d9f75844SAndroid Build Coastguard Worker  }];
238*d9f75844SAndroid Build Coastguard Worker
239*d9f75844SAndroid Build Coastguard Worker  RTCLogError("Horrible error");
240*d9f75844SAndroid Build Coastguard Worker
241*d9f75844SAndroid Build Coastguard Worker  [self waitForExpectations:@[ callbackExpectation ] timeout:10.0];
242*d9f75844SAndroid Build Coastguard Worker}
243*d9f75844SAndroid Build Coastguard Worker
244*d9f75844SAndroid Build Coastguard Worker@end
245