ecency-mobile/ios/EcencyTests/EcencyTests.m

66 lines
1.7 KiB
Mathematica
Raw Normal View History

2018-07-20 15:57:12 +03:00
#import <UIKit/UIKit.h>
#import <XCTest/XCTest.h>
#import <React/RCTLog.h>
#import <React/RCTRootView.h>
#define TIMEOUT_SECONDS 600
2019-10-09 18:26:38 +03:00
#define TEXT_TO_LOOK_FOR @"Welcome to React"
2018-07-20 15:57:12 +03:00
2020-07-17 14:22:06 +03:00
@interface EcencyTests : XCTestCase
2018-07-20 15:57:12 +03:00
@end
2020-07-17 14:22:06 +03:00
@implementation EcencyTests
2018-07-20 15:57:12 +03:00
- (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;
2019-10-09 18:26:38 +03:00
#ifdef DEBUG
2018-07-20 15:57:12 +03:00
RCTSetLogFunction(^(RCTLogLevel level, RCTLogSource source, NSString *fileName, NSNumber *lineNumber, NSString *message) {
if (level >= RCTLogLevelError) {
redboxError = message;
}
});
2019-10-09 18:26:38 +03:00
#endif
2018-07-20 15:57:12 +03:00
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;
}];
}
2019-10-09 18:26:38 +03:00
#ifdef DEBUG
2018-07-20 15:57:12 +03:00
RCTSetLogFunction(RCTDefaultLogFunction);
2019-10-09 18:26:38 +03:00
#endif
2018-07-20 15:57:12 +03:00
XCTAssertNil(redboxError, @"RedBox error: %@", redboxError);
XCTAssertTrue(foundElement, @"Couldn't find element with text '%@' in %d seconds", TEXT_TO_LOOK_FOR, TIMEOUT_SECONDS);
}
@end