2
0
mirror of synced 2025-01-13 10:04:29 +00:00
This commit is contained in:
Ben 2024-11-25 11:54:37 +01:00
parent 3c7892e4be
commit 18b6908cb9
No known key found for this signature in database
GPG Key ID: 0F16E812E736C24B
3 changed files with 210 additions and 0 deletions

View File

@ -0,0 +1,10 @@
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<OutputType>Exe</OutputType>
<TargetFramework>net8.0</TargetFramework>
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable>
</PropertyGroup>
</Project>

View File

@ -0,0 +1,193 @@
namespace CodexUnitTestCrusher
{
public class Program
{
public static void Main(string[] args)
{
var p = new Program();
p.Run();
}
private const bool AddRandomSleeps = true;
private const bool GenerateLoopTestRunners = true;
private readonly string Root = "C:\\Projects\\nim-codex";
private readonly string[] Exclude =
[
"vendor"
];
private readonly string Include = "import std/random";
private readonly string SleepLine = "await sleepAsync(rand(10))";
private readonly int NumCompiles = 10;
private readonly int NumRuns = 100;
private readonly string[] TestRunner =
[
"set -e",
"for i in {0..<NUMCOMPILES>}",
"do",
" echo \"#1\" >> \"<TESTFILE>\"",
" for j in {0..<NUMRUNS>}",
" do",
" nim c -r \"<TESTFILE>\"",
" done",
"done",
"rm <SCRIPTFILE>",
];
public void Run()
{
TraverseFolder(Root);
}
private void TraverseFolder(string root)
{
if (Exclude.Any(x => root.Contains(x))) return;
var folder = Directory.GetDirectories(root);
foreach (var dir in folder) TraverseFolder(dir);
var files = Directory.GetFiles(root);
foreach (var file in files) ProcessFile(file);
}
private void ProcessFile(string file)
{
if (!file.EndsWith(".nim")) return;
if (AddRandomSleeps) AddRandomSleepsToNimFile(file);
if (GenerateLoopTestRunners) GenerateTestRunner(file);
}
private void GenerateTestRunner(string file)
{
var filename = Path.GetFileName(file);
if (!filename.StartsWith("test")) return;
var path = Path.GetDirectoryName(file);
var testFile = file;
var scriptFile = filename.Replace(".nim", ".sh");
WriteScriptFile(path!, testFile, scriptFile);
}
private void WriteScriptFile(string path, string testFile, string scriptFile)
{
var lines = TestRunner.Select(l =>
{
return l
.Replace("<NUMCOMPILES>", NumCompiles.ToString())
.Replace("<NUMRUNS>", NumRuns.ToString())
.Replace("<TESTFILE>", testFile.ToString())
.Replace("<SCRIPTFILE>", scriptFile.ToString())
;
}).ToArray();
File.WriteAllLines(Path.Combine(path, scriptFile), lines);
}
private void AddRandomSleepsToNimFile(string file)
{
Console.WriteLine("Processing file: " + file);
var lines = File.ReadAllLines(file).ToList();
if (!lines.Any(l => l == Include))
{
AddInclude(lines);
}
var modified = false;
for (int i = 0; i < lines.Count; i++)
{
if (ProcessLine(i, lines[i], lines))
{
i++;
modified = true;
}
}
if (modified) File.WriteAllLines(file, lines);
}
private bool ProcessLine(int i, string line, List<string> lines)
{
if (IsComment(line)) return false;
if (line.Contains("await "))
{
if (!line.Contains("sleep"))
{
var previous = GetPreviousLine(i, lines);
if (previous != null)
{
var trim = previous.Trim();
// previous line was "let" ???
if (trim == "let")
{
// insert before let.
InsertSleepLine(i - 1, lines);
return true;
}
// previous line was "without =?" ??
if (trim.StartsWith("without") && trim.EndsWith("=?"))
{
// insert before without.
InsertSleepLine(i - 1, lines);
return true;
}
// previous line was "const" ??
if (trim == "const") return false;
}
var indent = GetIndent(line);
if (indent.Length < 3) InsertSleepLine(i, lines);
return true;
}
}
return false;
}
private void InsertSleepLine(int i, List<string> lines)
{
lines.Insert(i, GetIndent(lines[i]) + SleepLine);
}
private string? GetPreviousLine(int i, List<string> lines)
{
var idx = i - 1;
if (idx < 0) return null;
return lines[idx];
}
private bool IsComment(string line)
{
return line.Trim().StartsWith("#");
}
private string GetIndent(string line)
{
var result = "";
while (line.StartsWith(" "))
{
result += " ";
line = line.Substring(1);
}
return result;
}
private void AddInclude(List<string> lines)
{
for (var i = 0; i < lines.Count; i++)
{
var line = lines[i];
if (line.StartsWith("import "))
{
lines.Insert(i, Include);
return;
}
}
}
}
}

View File

@ -78,6 +78,8 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "MarketInsights", "Tools\Mar
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "CsvCombiner", "Tools\CsvCombiner\CsvCombiner.csproj", "{6230347F-5045-4E25-8E7A-13D7221B7444}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "CodexUnitTestCrusher", "CodexUnitTestCrusher\CodexUnitTestCrusher.csproj", "{E1B15D68-7055-42C9-B3DC-3130CA1CFBBE}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
@ -208,6 +210,10 @@ Global
{6230347F-5045-4E25-8E7A-13D7221B7444}.Debug|Any CPU.Build.0 = Debug|Any CPU
{6230347F-5045-4E25-8E7A-13D7221B7444}.Release|Any CPU.ActiveCfg = Release|Any CPU
{6230347F-5045-4E25-8E7A-13D7221B7444}.Release|Any CPU.Build.0 = Release|Any CPU
{E1B15D68-7055-42C9-B3DC-3130CA1CFBBE}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{E1B15D68-7055-42C9-B3DC-3130CA1CFBBE}.Debug|Any CPU.Build.0 = Debug|Any CPU
{E1B15D68-7055-42C9-B3DC-3130CA1CFBBE}.Release|Any CPU.ActiveCfg = Release|Any CPU
{E1B15D68-7055-42C9-B3DC-3130CA1CFBBE}.Release|Any CPU.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
@ -244,6 +250,7 @@ Global
{C0EEBD32-23CB-45EC-A863-79FB948508C8} = {7591C5B3-D86E-4AE4-8ED2-B272D17FE7E3}
{004614DF-1C65-45E3-882D-59AE44282573} = {7591C5B3-D86E-4AE4-8ED2-B272D17FE7E3}
{6230347F-5045-4E25-8E7A-13D7221B7444} = {7591C5B3-D86E-4AE4-8ED2-B272D17FE7E3}
{E1B15D68-7055-42C9-B3DC-3130CA1CFBBE} = {7591C5B3-D86E-4AE4-8ED2-B272D17FE7E3}
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {237BF0AA-9EC4-4659-AD9A-65DEB974250C}