WuhuIslandTesting/Library/PackageCache/com.unity.burst@1.8.4/Tests/Editor/BurstStringSearchTests.cs

132 lines
5.8 KiB
C#
Raw Normal View History

2025-01-07 02:06:59 +01:00
using System;
using System.Text;
using System.Text.RegularExpressions;
using NUnit.Framework;
using Unity.Burst;
using Unity.Burst.Editor;
public class BurstStringSearchTests
{
private BurstDisassembler GetDisassemblerandText(string compileTargetName, int debugLvl, out string textToRender)
{
// Get target job assembly:
var assemblies = BurstReflection.EditorAssembliesThatCanPossiblyContainJobs;
var result = BurstReflection.FindExecuteMethods(assemblies, BurstReflectionAssemblyOptions.None);
var compileTarget = result.CompileTargets.Find(x => x.GetDisplayName() == compileTargetName);
Assert.IsTrue(compileTarget != default, $"Could not find compile target: {compileTarget}");
BurstDisassembler disassembler = new BurstDisassembler();
var options = new StringBuilder();
compileTarget.Options.TryGetOptions(compileTarget.JobType, true, out string defaultOptions);
options.AppendLine(defaultOptions);
// Disables the 2 current warnings generated from code (since they clutter up the inspector display)
// BC1370 - throw inside code not guarded with ConditionalSafetyCheck attribute
// BC1322 - loop intrinsic on loop that has been optimised away
options.AppendLine($"{BurstCompilerOptions.GetOption(BurstCompilerOptions.OptionDisableWarnings, "BC1370;BC1322")}");
options.AppendLine($"{BurstCompilerOptions.GetOption(BurstCompilerOptions.OptionTarget, BurstTargetCpu.X64_SSE4)}");
options.AppendLine($"{BurstCompilerOptions.GetOption(BurstCompilerOptions.OptionDebug, $"{debugLvl}")}");
var baseOptions = options.ToString();
var append = BurstInspectorGUI.GetDisasmOptions()[(int)DisassemblyKind.Asm];
// Setup disAssembler with the job:
compileTarget.RawDisassembly = BurstInspectorGUI.GetDisassembly(compileTarget.Method, baseOptions + append);
textToRender = compileTarget.RawDisassembly.TrimStart('\n');
return disassembler;
}
[Test]
public void FindLineNrTest()
{
// Load in a test text
var disassembler = GetDisassemblerandText("BurstInspectorGUITests.MyJob - (IJob)", 1, out string textToRender);
disassembler.Initialize(textToRender, BurstDisassembler.AsmKind.Intel, true, true);
var text = disassembler.GetOrRenderBlockToText(0);
// Call find line nr for:
// first line
// Around middle
// Last line
Assert.AreEqual(0, BurstStringSearch.FindLineNr(text, text.IndexOf('\n') - 1), "Couldn't find line 0");
Assert.AreEqual(2, BurstStringSearch.FindLineNr(text, text.IndexOf('\n', text.IndexOf('\n') + 1) + 1), "Couldn't find line in middle");
Assert.AreEqual(disassembler.Blocks[0].Length-1, BurstStringSearch.FindLineNr(text, text.Length-1), "Couldn't find last line");
}
[Test]
public void GetEndIndexOfPlainLineTest()
{
Assert.AreEqual(("This\nIs\nPerfect".Length-1, 6),
BurstStringSearch.GetEndIndexOfPlainLine("This\nIs\nPerfect", 2),
"Failed finding in well formed string");
const string text1 = "No line endings";
Assert.AreEqual((text1.Length-1, text1.Length-1),
BurstStringSearch.GetEndIndexOfPlainLine(text1, 0),
"Failed for missing line ending");
const string text2 = "No Line endings too many lines";
Assert.Throws<ArgumentOutOfRangeException>(() => BurstStringSearch.GetEndIndexOfPlainLine(text2, 2),
"Failed for missing line ending and too high line number");
const string text3 = "Line ending\n";
Assert.AreEqual((text3.Length-1, text3.Length-1),
BurstStringSearch.GetEndIndexOfPlainLine(text3, 0),
"Failed with line ending");
const string text4 = "Line ending too many lines\n";
Assert.Throws<ArgumentOutOfRangeException>(() => BurstStringSearch.GetEndIndexOfPlainLine(text4, 2),
"Failed with line endings and too high line number");
}
[Test]
public void FindMatchTest()
{
_ = GetDisassemblerandText("BurstInspectorGUITests.MyJob - (IJob)", 2, out var textToRender);
var expectedNormal = textToRender.IndexOf("def");
var tmp = Regex.Match(textToRender, @"\bdef\b");
var expectedWhole = tmp.Success ? tmp.Index : -1;
// Normal search
Assert.AreEqual((expectedNormal, 3),
BurstStringSearch.FindMatch(textToRender,
new SearchCriteria("def", false, false, false), default),
"Standard search failed"); // standard search: Match def in .endef
Assert.AreEqual((expectedWhole, 3),
BurstStringSearch.FindMatch(textToRender,
new SearchCriteria("def", false, true, false), default),
"Standard whole words failed"); // whole word search: Match def in .def
// Regex search
const RegexOptions opt = RegexOptions.CultureInvariant;
Assert.AreEqual((expectedNormal, 3),
BurstStringSearch.FindMatch(textToRender,
new SearchCriteria("def", false, false, true),
new Regex("def", opt | RegexOptions.IgnoreCase)),
"Regex search failed"); // standard search: Match def in .endef
Assert.AreEqual((expectedWhole, tmp.Success ? 3 : 0),
BurstStringSearch.FindMatch(textToRender,
new SearchCriteria(@"\bdef\b", false, true, true),
new Regex(@"\bdef\b", opt)),
"Regex whole word failed"); // whole word search: Match def in .def
// Across lines and blocks
Assert.AreEqual((12, 4),
BurstStringSearch.FindMatch(textToRender,
new SearchCriteria(@"t[\n]+..", false, false, true),
new Regex(@"t[\n]+..", opt | RegexOptions.IgnoreCase)),
"Regex across lines failed");
}
}