Files
flipper/react-native/ReactNativeFlipperExample/ios/ReactNativeFlipperExampleTests/ReactNativeFlipperExampleTests.m
Pritesh Nandgaonkar bd388f73e4 CLANGFORMAT the remaining files of xplat/sonar
Summary:
As per title.
Ran `arc lint -a --take CLANGFORMAT --paths-cmd 'hg files ./'` from xplat/sonar

Reviewed By: zertosh

Differential Revision: D19943131

fbshipit-source-id: c1dc10b27389fd6f54f055803519dac6bf0e7997
2020-02-18 05:27:56 -08:00

84 lines
2.3 KiB
Objective-C

/*
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#import <UIKit/UIKit.h>
#import <XCTest/XCTest.h>
#import <React/RCTLog.h>
#import <React/RCTRootView.h>
#define TIMEOUT_SECONDS 600
#define TEXT_TO_LOOK_FOR @"Welcome to React"
@interface ReactNativeFlipperExampleTests : XCTestCase
@end
@implementation ReactNativeFlipperExampleTests
- (BOOL)findSubviewInView:(UIView*)view matching:(BOOL (^)(UIView* view))test {
if (test(view)) {
return YES;
}
for (UIView* subview in [view subviews]) {
if ([self findSubviewInView:subview matching:test]) {
return YES;
}
}
return NO;
}
- (void)testRendersWelcomeScreen {
UIViewController* vc =
[[[RCTSharedApplication() delegate] window] rootViewController];
NSDate* date = [NSDate dateWithTimeIntervalSinceNow:TIMEOUT_SECONDS];
BOOL foundElement = NO;
__block NSString* redboxError = nil;
#ifdef DEBUG
RCTSetLogFunction(
^(RCTLogLevel level,
RCTLogSource source,
NSString* fileName,
NSNumber* lineNumber,
NSString* message) {
if (level >= RCTLogLevelError) {
redboxError = message;
}
});
#endif
while ([date timeIntervalSinceNow] > 0 && !foundElement && !redboxError) {
[[NSRunLoop mainRunLoop] runMode:NSDefaultRunLoopMode
beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]];
[[NSRunLoop mainRunLoop] runMode:NSRunLoopCommonModes
beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]];
foundElement = [self findSubviewInView:vc.view
matching:^BOOL(UIView* view) {
if ([view.accessibilityLabel
isEqualToString:TEXT_TO_LOOK_FOR]) {
return YES;
}
return NO;
}];
}
#ifdef DEBUG
RCTSetLogFunction(RCTDefaultLogFunction);
#endif
XCTAssertNil(redboxError, @"RedBox error: %@", redboxError);
XCTAssertTrue(
foundElement,
@"Couldn't find element with text '%@' in %d seconds",
TEXT_TO_LOOK_FOR,
TIMEOUT_SECONDS);
}
@end