mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-20 21:30:59 +00:00
103 lines
3.1 KiB
Plaintext
103 lines
3.1 KiB
Plaintext
//
|
|
// AtariStaticAnalyserTests.m
|
|
// Clock Signal
|
|
//
|
|
// Created by Thomas Harte on 11/03/2017.
|
|
// Copyright 2017 Thomas Harte. All rights reserved.
|
|
//
|
|
|
|
#import <XCTest/XCTest.h>
|
|
|
|
#import <CommonCrypto/CommonDigest.h>
|
|
#include "../../../Analyser/Static/StaticAnalyser.hpp"
|
|
#include "../../../Analyser/Static/Commodore/Target.hpp"
|
|
|
|
#include <atomic>
|
|
|
|
// This test runs through a whole bunch of files somewhere on disk. These files are not included in the repository
|
|
// because they are not suitably licensed. So this path is specific to my local system, at the time I happen to be
|
|
// writing these tests. Update in the future, as necessary.
|
|
static constexpr const char *const plus4Path =
|
|
"/Users/thomasharte/Library/Mobile Documents/com~apple~CloudDocs/Soft/C16+4";
|
|
static constexpr const char *const vic20Path =
|
|
"/Users/thomasharte/Library/Mobile Documents/com~apple~CloudDocs/Soft/Vic-20";
|
|
|
|
@interface CommodoreStaticAnalyserTests : XCTestCase
|
|
@end
|
|
|
|
struct HitRate {
|
|
int files = 0;
|
|
int matches = 0;
|
|
|
|
HitRate &operator += (const HitRate &rhs) {
|
|
files += rhs.files;
|
|
matches += rhs.matches;
|
|
return *this;
|
|
}
|
|
};
|
|
|
|
@implementation CommodoreStaticAnalyserTests
|
|
|
|
- (HitRate)hitRateBeneathPath:(NSString *)path forMachine:(Analyser::Machine)machine {
|
|
__block std::atomic<int> files_source = 0;
|
|
__block std::atomic<int> matches_source = 0;
|
|
auto &files = files_source;
|
|
auto &matches = matches_source;
|
|
|
|
NSDirectoryEnumerator<NSString *> *enumerator = [[NSFileManager defaultManager] enumeratorAtPath:path];
|
|
NSMutableArray<NSString *> *items = [[NSMutableArray alloc] init];
|
|
while(NSString *diskItem = [enumerator nextObject]) {
|
|
[items addObject:[path stringByAppendingPathComponent:diskItem]];
|
|
}
|
|
|
|
static constexpr int BatchSize = 10;
|
|
dispatch_apply(
|
|
([items count] + BatchSize - 1) / BatchSize,
|
|
dispatch_get_global_queue(QOS_CLASS_DEFAULT, 0),
|
|
^(size_t iteration) {
|
|
|
|
const auto base = iteration * BatchSize;
|
|
for(size_t index = base; index < base + BatchSize && index < [items count]; index++) {
|
|
NSString *const fullPath = [items objectAtIndex:index];
|
|
|
|
NSLog(@"Starting %@", fullPath);
|
|
const auto list = Analyser::Static::GetTargets(fullPath.UTF8String);
|
|
NSLog(@"Ending %@", fullPath);
|
|
if(list.empty()) {
|
|
return;
|
|
}
|
|
|
|
++files;
|
|
if(list.size() != 1) {
|
|
return;
|
|
}
|
|
|
|
const auto &first = *list.begin();
|
|
matches += first->machine == machine;
|
|
}
|
|
NSLog(@"Currently %d in %d, i.e. %0.2f",
|
|
matches.load(), files.load(), float(matches.load()) / float(files.load()));
|
|
});
|
|
|
|
return HitRate {
|
|
.files = files,
|
|
.matches = matches,
|
|
};
|
|
}
|
|
|
|
- (void)testPlus4 {
|
|
const auto hitRate =
|
|
[self hitRateBeneathPath:[NSString stringWithUTF8String:plus4Path] forMachine:Analyser::Machine::Plus4];
|
|
NSLog(@"Got hit rate of %d in %d, i.e. %0.2f",
|
|
hitRate.matches, hitRate.files, float(hitRate.matches) / float(hitRate.files));
|
|
}
|
|
|
|
- (void)testVic20 {
|
|
const auto hitRate =
|
|
[self hitRateBeneathPath:[NSString stringWithUTF8String:vic20Path] forMachine:Analyser::Machine::Vic20];
|
|
NSLog(@"Got hit rate of %d in %d, i.e. %0.2f",
|
|
hitRate.matches, hitRate.files, float(hitRate.matches) / float(hitRate.files));
|
|
}
|
|
|
|
@end
|