Swiftgram/Tests/ASPerformanceTestContext.mm
Adlai Holler d0ba092a77
Convert the codebase to Objective-C++ (#1206)
* Convert the codebase to Objective-C++ throughout. One language is better than two.

* Put it back

* Fix linker

* Point explicitly to updated Weaver to unblock build

* Revert "Point explicitly to updated Weaver to unblock build"

This reverts commit fdc25296e8794d4e6e56c35f5fe6da2be3f71dbc.

* Revert "Fix linker"

This reverts commit 7be25f91519b8497ef42de79f115bcfbdb965c39.

* Add in the frameworks

* no message

* Address spec lint warnings

* Fix tvos build

* Put that back

* Address Michael's review

* Add comment to kick CI
2018-11-02 12:04:14 -07:00

136 lines
3.8 KiB
Plaintext

//
// ASPerformanceTestContext.mm
// Texture
//
// Copyright (c) Facebook, Inc. and its affiliates. All rights reserved.
// Changes after 4/13/2017 are: Copyright (c) Pinterest, Inc. All rights reserved.
// Licensed under Apache 2.0: http://www.apache.org/licenses/LICENSE-2.0
//
#import "ASPerformanceTestContext.h"
#import <AsyncDisplayKit/ASAssert.h>
#import <Foundation/Foundation.h>
#import <QuartzCore/CABase.h>
@interface ASPerformanceTestResult ()
@property (nonatomic) NSTimeInterval timePer1000;
@property (nonatomic) NSString *caseName;
@property (nonatomic, getter=isReferenceCase) BOOL referenceCase;
@property (nonatomic) float relativePerformance;
@end
@implementation ASPerformanceTestResult
- (instancetype)init
{
self = [super init];
if (self != nil) {
_userInfo = [[NSMutableDictionary alloc] init];
}
return self;
}
- (NSString *)description
{
NSString *userInfoStr = [_userInfo.description stringByReplacingOccurrencesOfString:@"\n" withString:@" "];
return [NSString stringWithFormat:@"<%-20s: time-per-1000=%04.2f rel-perf=%04.2f user-info=%@>", _caseName.UTF8String, _timePer1000, _relativePerformance, userInfoStr];
}
@end
@implementation ASPerformanceTestContext {
NSMutableDictionary *_results;
NSInteger _iterationCount;
ASPerformanceTestResult * _Nullable _referenceResult;
}
- (instancetype)init
{
self = [super init];
if (self != nil) {
_iterationCount = 1E4;
_results = [[NSMutableDictionary alloc] init];
}
return self;
}
- (NSDictionary<NSString *, ASPerformanceTestResult *> *)results
{
return _results;
}
- (void)dealloc
{
/**
* I know this seems wacky but it's a pain to have to put this in every single test method.
*/
NSLog(@"%@", self.description);
}
- (BOOL)areAllUserInfosEqual
{
ASDisplayNodeAssert(_results.count >= 2, nil);
NSEnumerator *resultsEnumerator = [_results objectEnumerator];
NSDictionary *userInfo = [[resultsEnumerator nextObject] userInfo];
for (ASPerformanceTestResult *otherResult in resultsEnumerator) {
if ([userInfo isEqualToDictionary:otherResult.userInfo] == NO) {
return NO;
}
}
return YES;
}
- (void)addCaseWithName:(NSString *)caseName block:(AS_NOESCAPE ASTestPerformanceCaseBlock)block
{
ASDisplayNodeAssert(_results[caseName] == nil, @"Already have a case named %@", caseName);
ASPerformanceTestResult *result = [[ASPerformanceTestResult alloc] init];
result.caseName = caseName;
result.timePer1000 = [self _testPerformanceForCaseWithBlock:block] / (_iterationCount / 1000);
if (_referenceResult == nil) {
result.referenceCase = YES;
result.relativePerformance = 1.0f;
_referenceResult = result;
} else {
result.relativePerformance = _referenceResult.timePer1000 / result.timePer1000;
}
_results[caseName] = result;
}
/// Returns total work time
- (CFTimeInterval)_testPerformanceForCaseWithBlock:(AS_NOESCAPE ASTestPerformanceCaseBlock)block
{
__block CFTimeInterval time = 0;
for (NSInteger i = 0; i < _iterationCount; i++) {
__block CFTimeInterval start = 0;
__block BOOL calledStop = NO;
@autoreleasepool {
block(i, ^{
ASDisplayNodeAssert(start == 0, @"Called startMeasuring block twice.");
start = CACurrentMediaTime();
}, ^{
time += (CACurrentMediaTime() - start);
ASDisplayNodeAssert(calledStop == NO, @"Called stopMeasuring block twice.");
ASDisplayNodeAssert(start != 0, @"Failed to call startMeasuring block");
calledStop = YES;
});
}
ASDisplayNodeAssert(calledStop, @"Failed to call stopMeasuring block.");
}
return time;
}
- (NSString *)description
{
NSMutableString *str = [NSMutableString stringWithString:@"Results:\n"];
for (ASPerformanceTestResult *result in [_results objectEnumerator]) {
[str appendFormat:@"\t%@\n", result];
}
return str;
}
@end