1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-20 21:30:59 +00:00
CLK/OSBindings/Mac/Clock SignalTests/CommodoreStaticAnalyserTests.mm
2024-12-07 11:55:38 -06:00

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