diff --git a/.github/workflows/generate-coverage-report.yaml b/.github/workflows/generate-coverage-report.yaml
index f6684bcbf8..86c1850cfb 100644
--- a/.github/workflows/generate-coverage-report.yaml
+++ b/.github/workflows/generate-coverage-report.yaml
@@ -44,13 +44,13 @@ jobs:
- name: Collect Code Coverage
run: |
- dotnet coverage connect bdn_coverage "dotnet test tests/BenchmarkDotNet.Tests -c Release --no-build --framework net8.0"
- dotnet coverage connect bdn_coverage "dotnet test tests/BenchmarkDotNet.Analyzers.Tests -c Release --no-build --framework net8.0"
+ dotnet coverage connect bdn_coverage "dotnet test --project tests/BenchmarkDotNet.Tests -c Release --no-build --framework net8.0"
+ dotnet coverage connect bdn_coverage "dotnet test --project tests/BenchmarkDotNet.Analyzers.Tests -c Release --no-build --framework net8.0"
- name: Collect Code Coverage for BenchmarkDotNet.IntegrationTests
if: ${{ github.event.inputs.skip_integration_tests == 'false'}}
run: |
- dotnet coverage connect bdn_coverage 'dotnet test tests/BenchmarkDotNet.IntegrationTests -c Release --no-build --framework net8.0 --filter "(FullyQualifiedName!~DotMemoryTests) & (FullyQualifiedName!~DotTraceTests) & (FullyQualifiedName!~WasmIsSupported) & (FullyQualifiedName!~WasmSupportsInProcessDiagnosers)"'
+ dotnet coverage connect bdn_coverage 'dotnet test --project tests/BenchmarkDotNet.IntegrationTests -c Release --no-build --framework net8.0 --filter-query "/*/*/(!*DotMemoryTests)&(!*DotTraceTests)&(!*WasmTests)"' --no-ansi --output Detailed
- name: Shutdown dotnet-coverage server.
run: dotnet coverage shutdown bdn_coverage --timeout 60000
@@ -80,13 +80,13 @@ jobs:
- name: Collect Code Coverage
run: |
- dotnet coverage connect bdn_coverage "dotnet test tests/BenchmarkDotNet.Tests -c Release --no-build --framework net472"
- dotnet coverage connect bdn_coverage "dotnet test tests/BenchmarkDotNet.Analyzers.Tests -c Release --no-build --framework net472"
+ dotnet coverage connect bdn_coverage "dotnet test --project tests/BenchmarkDotNet.Tests -c Release --no-build --framework net472"
+ dotnet coverage connect bdn_coverage "dotnet test --project tests/BenchmarkDotNet.Analyzers.Tests -c Release --no-build --framework net472"
- name: Collect Code Coverage for BenchmarkDotNet.IntegrationTests
if: ${{ github.event.inputs.skip_integration_tests == 'false'}}
run: |
- dotnet coverage connect bdn_coverage 'dotnet test tests/BenchmarkDotNet.IntegrationTests -c Release --no-build --framework net472 --filter "(FullyQualifiedName!~DotMemoryTests) & (FullyQualifiedName!~DotTraceTests) & (FullyQualifiedName!~WasmIsSupported) & (FullyQualifiedName!~WasmSupportsInProcessDiagnosers)"'
+ dotnet coverage connect bdn_coverage 'dotnet test --project tests/BenchmarkDotNet.IntegrationTests -c Release --no-build --framework net472 --filter-query "/*/*/(!*DotMemoryTests)&(!*DotTraceTests)&(!*WasmTests)"' --no-ansi --output Detailed
- name: Shutdown dotnet-coverage server.
run: dotnet coverage shutdown bdn_coverage --timeout 60000
diff --git a/.github/workflows/run-tests-selected.yaml b/.github/workflows/run-tests-selected.yaml
index 28711fda21..b62b122217 100644
--- a/.github/workflows/run-tests-selected.yaml
+++ b/.github/workflows/run-tests-selected.yaml
@@ -34,7 +34,7 @@ on:
- net472
filter:
type: string
- description: Test filter text (It's used for `dotnet test --filter`) Use default value when running all tests
+ description: Test filter text (It's used for `dotnet test --filter-method`) Use default value when running all tests
required: true
default: "BenchmarkDotNet"
iteration_count:
@@ -83,12 +83,13 @@ jobs:
run: |
$PSNativeCommandUseErrorActionPreference = $true
$iterationCount = ${{ inputs.iteration_count }}
+
+ Write-Host ("OSArchitecture" + [System.Runtime.InteropServices.RuntimeInformation]::OSArchitecture)
foreach($i in 1..$iterationCount) {
Write-Output ('##[group]Executing Iteration: {0}/${{ inputs.iteration_count }}' -f $i)
- dotnet test -c Release --framework ${{ inputs.framework }} --filter ${{ inputs.filter }} -tl:off --no-build --logger "console;verbosity=normal"
-
+ dotnet test -c Release --framework ${{ inputs.framework }} --no-build --filter-method "${{ inputs.filter }}" --no-ansi
Write-Output '##[endgroup]'
}
diff --git a/.github/workflows/run-tests.yaml b/.github/workflows/run-tests.yaml
index 7b8d6e578e..bd21f48d3e 100644
--- a/.github/workflows/run-tests.yaml
+++ b/.github/workflows/run-tests.yaml
@@ -52,7 +52,9 @@ jobs:
if: always()
with:
name: test-windows-core-trx-${{ github.run_id }}-${{ matrix.os }}
- path: "**/*.trx"
+ path: |
+ **/*.trx
+ **/log_*.diag
test-windows-full:
strategy:
@@ -94,7 +96,9 @@ jobs:
if: always()
with:
name: test-windows-full-trx-${{ github.run_id }}-${{ matrix.os }}
- path: "**/*.trx"
+ path: |
+ **/*.trx
+ **/log_*.diag
test-linux:
strategy:
@@ -129,7 +133,9 @@ jobs:
if: always()
with:
name: test-linux-trx-${{ github.run_id }}-${{ matrix.os }}
- path: "**/*.trx"
+ path: |
+ **/*.trx
+ **/log_*.diag
test-macos:
name: test-macos (${{ matrix.os.arch }})
@@ -169,7 +175,9 @@ jobs:
if: always()
with:
name: test-macos(${{ matrix.os.arch }})-trx-${{ github.run_id }}
- path: "**/*.trx"
+ path: |
+ **/*.trx
+ **/log_*.diag
test-pack:
runs-on: ubuntu-latest
diff --git a/BenchmarkDotNet.slnx b/BenchmarkDotNet.slnx
index 7fa4bade23..56aaa43b06 100644
--- a/BenchmarkDotNet.slnx
+++ b/BenchmarkDotNet.slnx
@@ -28,7 +28,9 @@
+
+
diff --git a/build/BenchmarkDotNet.Build/BenchmarkDotNet.Build.csproj b/build/BenchmarkDotNet.Build/BenchmarkDotNet.Build.csproj
index 1992bbf28e..44c9df5cfc 100644
--- a/build/BenchmarkDotNet.Build/BenchmarkDotNet.Build.csproj
+++ b/build/BenchmarkDotNet.Build/BenchmarkDotNet.Build.csproj
@@ -7,7 +7,7 @@
$(NoWarn);CA2007
-
+
diff --git a/build/BenchmarkDotNet.Build/Runners/UnitTestRunner.cs b/build/BenchmarkDotNet.Build/Runners/UnitTestRunner.cs
index e6d5637040..f592ea65e7 100644
--- a/build/BenchmarkDotNet.Build/Runners/UnitTestRunner.cs
+++ b/build/BenchmarkDotNet.Build/Runners/UnitTestRunner.cs
@@ -3,7 +3,9 @@
using Cake.Common.Diagnostics;
using Cake.Common.Tools.DotNet;
using Cake.Common.Tools.DotNet.Test;
+using Cake.Core;
using Cake.Core.IO;
+using System.Linq;
using System.Runtime.InteropServices;
namespace BenchmarkDotNet.Build.Runners;
@@ -41,11 +43,18 @@ private DotNetTestSettings GetTestSettingsParameters(FilePath logFile, string tf
Framework = tfm,
NoBuild = true,
NoRestore = true,
- Loggers = new[] { "trx", $"trx;LogFileName={logFile.FullPath}", "console;verbosity=detailed" },
EnvironmentVariables =
{
["Platform"] = "" // force the tool to not look for the .dll in platform-specific directory
- }
+ },
+ PathType = DotNetTestPathType.Auto,
+ ArgumentCustomization = args
+ => args.Append("--report-xunit-trx")
+ .AppendSwitchQuoted("--report-xunit-trx-filename", System.IO.Path.GetFileName(logFile.FullPath))
+ .Append("--no-ansi")
+ .AppendSwitch("--output", "Detailed")
+ .Append("--diagnostic")
+ .AppendSwitch("--diagnostic-verbosity", "Trace")
};
return settings;
}
diff --git a/global.json b/global.json
new file mode 100644
index 0000000000..3140116df3
--- /dev/null
+++ b/global.json
@@ -0,0 +1,5 @@
+{
+ "test": {
+ "runner": "Microsoft.Testing.Platform"
+ }
+}
diff --git a/src/BenchmarkDotNet/Templates/CsProj.txt b/src/BenchmarkDotNet/Templates/CsProj.txt
index d7ae3cae05..f247140b21 100644
--- a/src/BenchmarkDotNet/Templates/CsProj.txt
+++ b/src/BenchmarkDotNet/Templates/CsProj.txt
@@ -27,6 +27,7 @@
true
BenchmarkDotNet.Autogenerated.UniqueProgramName
+ false
diff --git a/src/BenchmarkDotNet/Templates/MonoAOTLLVMCsProj.txt b/src/BenchmarkDotNet/Templates/MonoAOTLLVMCsProj.txt
index e87eee2527..418b2c537b 100644
--- a/src/BenchmarkDotNet/Templates/MonoAOTLLVMCsProj.txt
+++ b/src/BenchmarkDotNet/Templates/MonoAOTLLVMCsProj.txt
@@ -1,4 +1,4 @@
-
+
$CSPROJPATH$
$([System.IO.Path]::ChangeExtension('$(OriginalCSProjPath)', '.Mono.props'))
@@ -21,6 +21,7 @@
true
true
+ false
diff --git a/src/BenchmarkDotNet/Templates/R2RCsProj.txt b/src/BenchmarkDotNet/Templates/R2RCsProj.txt
index 0a9702ac1c..54f2c2aaa9 100644
--- a/src/BenchmarkDotNet/Templates/R2RCsProj.txt
+++ b/src/BenchmarkDotNet/Templates/R2RCsProj.txt
@@ -30,6 +30,7 @@
BenchmarkDotNet.Autogenerated.UniqueProgramName
false
+ false
diff --git a/src/BenchmarkDotNet/Templates/WasmCsProj.txt b/src/BenchmarkDotNet/Templates/WasmCsProj.txt
index 5ab10b2a57..38068cef34 100644
--- a/src/BenchmarkDotNet/Templates/WasmCsProj.txt
+++ b/src/BenchmarkDotNet/Templates/WasmCsProj.txt
@@ -1,4 +1,4 @@
-
+
$CSPROJPATH$
$([System.IO.Path]::ChangeExtension('$(OriginalCSProjPath)', '.Wasm.props'))
@@ -26,6 +26,7 @@ $CORECLR_OVERRIDES$
true
BenchmarkDotNet.Autogenerated.UniqueProgramName
+ false
diff --git a/src/BenchmarkDotNet/Toolchains/NativeAot/Generator.cs b/src/BenchmarkDotNet/Toolchains/NativeAot/Generator.cs
index 2cfdce0259..fa21dc2d36 100644
--- a/src/BenchmarkDotNet/Toolchains/NativeAot/Generator.cs
+++ b/src/BenchmarkDotNet/Toolchains/NativeAot/Generator.cs
@@ -165,6 +165,10 @@ private string GenerateProjectForNuGetBuild(string projectFilePath, BuildPartiti
true
{GetInstructionSetSettings(buildPartition)}
+
+ false
+ false
+
{GetRuntimeSettings(buildPartition.RepresentativeBenchmarkCase.Job.Environment.Gc, buildPartition.Resolver)}
diff --git a/tests/.editorconfig b/tests/.editorconfig
new file mode 100644
index 0000000000..64a64c01c8
--- /dev/null
+++ b/tests/.editorconfig
@@ -0,0 +1,7 @@
+root = false
+
+# C# files
+[*.cs]
+# xUnit1051: Calls to methods which accept CancellationToken should use TestContext.Current.CancellationToken to allow test cancellation to be more responsive.
+dotnet_diagnostic.xUnit1051.severity = suggestion
+
diff --git a/tests/BenchmarkDotNet.Analyzers.Tests/AnalyzerTests/Attributes/ArgumentsAttributeAnalyzerTests.cs b/tests/BenchmarkDotNet.Analyzers.Tests/AnalyzerTests/Attributes/ArgumentsAttributeAnalyzerTests.cs
index 34d687adb4..68437e5eb5 100644
--- a/tests/BenchmarkDotNet.Analyzers.Tests/AnalyzerTests/Attributes/ArgumentsAttributeAnalyzerTests.cs
+++ b/tests/BenchmarkDotNet.Analyzers.Tests/AnalyzerTests/Attributes/ArgumentsAttributeAnalyzerTests.cs
@@ -555,7 +555,7 @@ public async Task Providing_expected_value_type_should_not_trigger_diagnostic(
{
var testCode = /* lang=c#-test */ $$"""
using DifferentNamespace;
-
+
using BenchmarkDotNet.Attributes;
public class BenchmarkClass
@@ -1110,7 +1110,7 @@ public void BenchmarkMethod({{integerValueAndType.Value2}} a)
}
public static IEnumerable DummyAttributeUsage
- => DummyAttributeUsageTheoryData;
+ => DummyAttributeUsageTheoryData.Select(x => x.Data);
public static TheoryData EmptyArgumentsAttributeUsagesWithMismatchingValueCount()
{
diff --git a/tests/BenchmarkDotNet.Analyzers.Tests/AnalyzerTests/Attributes/GeneralParameterAttributesAnalyzerTests.cs b/tests/BenchmarkDotNet.Analyzers.Tests/AnalyzerTests/Attributes/GeneralParameterAttributesAnalyzerTests.cs
index 16bf923259..3249f36163 100644
--- a/tests/BenchmarkDotNet.Analyzers.Tests/AnalyzerTests/Attributes/GeneralParameterAttributesAnalyzerTests.cs
+++ b/tests/BenchmarkDotNet.Analyzers.Tests/AnalyzerTests/Attributes/GeneralParameterAttributesAnalyzerTests.cs
@@ -159,7 +159,7 @@ public class BenchmarkClass
}
public static TheoryData UniqueParameterAttributeUsages
- => [.. UniqueParameterAttributesTheoryData.Select(tdr => (tdr[1] as string)!)];
+ => [.. UniqueParameterAttributesTheoryData.Select(tdr => tdr.Data.Item2)];
public static TheoryData DuplicateSameParameterAttributeUsages
=> DuplicateSameAttributeUsagesTheoryData;
@@ -321,7 +321,7 @@ public class BenchmarkClass
await RunAsync();
}
- public static TheoryData UniqueParameterAttributeUsages => [.. UniqueParameterAttributesTheoryData.Select(tdr => (tdr[1] as string)!)];
+ public static TheoryData UniqueParameterAttributeUsages => [.. UniqueParameterAttributesTheoryData.Select(tdr => tdr.Data.Item2)];
public static TheoryData DuplicateSameParameterAttributeUsages => DuplicateSameAttributeUsagesTheoryData;
@@ -480,21 +480,19 @@ public static IEnumerable
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Extensions/TheoryDataExtensions.cs b/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Extensions/TheoryDataExtensions.cs
index bc5fcc258c..1970ab058d 100644
--- a/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Extensions/TheoryDataExtensions.cs
+++ b/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Extensions/TheoryDataExtensions.cs
@@ -6,5 +6,5 @@ namespace BenchmarkDotNet.Analyzers.Tests.Fixtures;
public static class TheoryDataExtensions
{
public static ReadOnlyCollection AsReadOnly(this TheoryData theoryData)
- => (theoryData as IEnumerable).ToList().AsReadOnly();
+ => theoryData.Select(x => x.Data).ToList().AsReadOnly();
}
\ No newline at end of file
diff --git a/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Serializable/ValueTupleDouble.cs b/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Serializable/ValueTupleDouble.cs
index 5642d4c615..56819e9cf2 100644
--- a/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Serializable/ValueTupleDouble.cs
+++ b/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Serializable/ValueTupleDouble.cs
@@ -1,4 +1,4 @@
-using Xunit.Abstractions;
+using Xunit.Sdk;
namespace BenchmarkDotNet.Analyzers.Tests.Fixtures;
diff --git a/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Serializable/ValueTupleTriple.cs b/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Serializable/ValueTupleTriple.cs
index 0b19f5c211..82b871d3a3 100644
--- a/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Serializable/ValueTupleTriple.cs
+++ b/tests/BenchmarkDotNet.Analyzers.Tests/Fixtures/Serializable/ValueTupleTriple.cs
@@ -1,4 +1,4 @@
-using Xunit.Abstractions;
+using Xunit.Sdk;
namespace BenchmarkDotNet.Analyzers.Tests.Fixtures;
@@ -29,4 +29,4 @@ public static implicit operator ValueTupleTriple((T1, T2, T3) valueT
public override string ToString()
=> Value1 == null || Value2 == null || Value3 == null ? "" : $"{Value1} · {Value2} · {Value3}";
-}
\ No newline at end of file
+}
diff --git a/tests/BenchmarkDotNet.Exporters.Plotting.Tests/BenchmarkDotNet.Exporters.Plotting.Tests.csproj b/tests/BenchmarkDotNet.Exporters.Plotting.Tests/BenchmarkDotNet.Exporters.Plotting.Tests.csproj
index 9aa9ef524b..36f4d39330 100644
--- a/tests/BenchmarkDotNet.Exporters.Plotting.Tests/BenchmarkDotNet.Exporters.Plotting.Tests.csproj
+++ b/tests/BenchmarkDotNet.Exporters.Plotting.Tests/BenchmarkDotNet.Exporters.Plotting.Tests.csproj
@@ -2,12 +2,12 @@
net8.0;net472
+ Exe
true
false
-
@@ -18,12 +18,7 @@
-
-
-
- all
- runtime; build; native; contentfiles; analyzers; buildtransitive
-
+
diff --git a/tests/BenchmarkDotNet.Exporters.Plotting.Tests/ScottPlotExporterTests.cs b/tests/BenchmarkDotNet.Exporters.Plotting.Tests/ScottPlotExporterTests.cs
index bb481d3ea8..1d5118dc69 100644
--- a/tests/BenchmarkDotNet.Exporters.Plotting.Tests/ScottPlotExporterTests.cs
+++ b/tests/BenchmarkDotNet.Exporters.Plotting.Tests/ScottPlotExporterTests.cs
@@ -3,6 +3,9 @@
using BenchmarkDotNet.Loggers;
using BenchmarkDotNet.Tests.Mocks;
using System.Diagnostics.CodeAnalysis;
+using System.IO;
+using System.Linq;
+using Xunit;
namespace BenchmarkDotNet.Exporters.Plotting.Tests
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ConfigPerAssembly/BenchmarkDotNet.IntegrationTests.ConfigPerAssembly.csproj b/tests/BenchmarkDotNet.IntegrationTests.ConfigPerAssembly/BenchmarkDotNet.IntegrationTests.ConfigPerAssembly.csproj
index 5b849298b3..3b0d827f1c 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.ConfigPerAssembly/BenchmarkDotNet.IntegrationTests.ConfigPerAssembly.csproj
+++ b/tests/BenchmarkDotNet.IntegrationTests.ConfigPerAssembly/BenchmarkDotNet.IntegrationTests.ConfigPerAssembly.csproj
@@ -3,6 +3,7 @@
BenchmarkDotNet.IntegrationTests.ConfigPerAssembly
net472;net8.0
+ Exe
true
BenchmarkDotNet.IntegrationTests.ConfigPerAssembly
BenchmarkDotNet.IntegrationTests.ConfigPerAssembly
@@ -13,6 +14,9 @@
+
+
+
diff --git a/tests/BenchmarkDotNet.IntegrationTests.CustomPaths/BenchmarkDotNet.IntegrationTests.CustomPaths.csproj b/tests/BenchmarkDotNet.IntegrationTests.CustomPaths/BenchmarkDotNet.IntegrationTests.CustomPaths.csproj
index ffea2b8a5f..f5eadf834b 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.CustomPaths/BenchmarkDotNet.IntegrationTests.CustomPaths.csproj
+++ b/tests/BenchmarkDotNet.IntegrationTests.CustomPaths/BenchmarkDotNet.IntegrationTests.CustomPaths.csproj
@@ -3,6 +3,7 @@
BenchmarkDotNet.IntegrationTests.CustomPaths
net472
+ Exe
true
BenchmarkDotNet.IntegrationTests.CustomPaths
BenchmarkDotNet.IntegrationTests.CustomPaths
@@ -13,6 +14,9 @@
+
+
+
diff --git a/tests/BenchmarkDotNet.IntegrationTests.DisabledOptimizations/BenchmarkDotNet.IntegrationTests.DisabledOptimizations.csproj b/tests/BenchmarkDotNet.IntegrationTests.DisabledOptimizations/BenchmarkDotNet.IntegrationTests.DisabledOptimizations.csproj
index fdb5400397..2d7c912a5b 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.DisabledOptimizations/BenchmarkDotNet.IntegrationTests.DisabledOptimizations.csproj
+++ b/tests/BenchmarkDotNet.IntegrationTests.DisabledOptimizations/BenchmarkDotNet.IntegrationTests.DisabledOptimizations.csproj
@@ -3,18 +3,22 @@
BenchmarkDotNet.IntegrationTests.DisabledOptimizations
net472;net8.0
+ Exe
true
BenchmarkDotNet.IntegrationTests.DisabledOptimizations
BenchmarkDotNet.IntegrationTests.DisabledOptimizations
true
false
AnyCPU
-
+
false
+
+
+
diff --git a/tests/BenchmarkDotNet.IntegrationTests.EnabledOptimizations/BenchmarkDotNet.IntegrationTests.EnabledOptimizations.csproj b/tests/BenchmarkDotNet.IntegrationTests.EnabledOptimizations/BenchmarkDotNet.IntegrationTests.EnabledOptimizations.csproj
index 7bfa81d814..16a00547ad 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.EnabledOptimizations/BenchmarkDotNet.IntegrationTests.EnabledOptimizations.csproj
+++ b/tests/BenchmarkDotNet.IntegrationTests.EnabledOptimizations/BenchmarkDotNet.IntegrationTests.EnabledOptimizations.csproj
@@ -3,18 +3,22 @@
BenchmarkDotNet.IntegrationTests.EnabledOptimizations
net472;net8.0
+ Exe
true
BenchmarkDotNet.IntegrationTests.EnabledOptimizations
BenchmarkDotNet.IntegrationTests.EnabledOptimizations
true
false
AnyCPU
-
+
true
+
+
+
diff --git a/tests/BenchmarkDotNet.IntegrationTests.FSharp/BenchmarkDotNet.IntegrationTests.FSharp.fsproj b/tests/BenchmarkDotNet.IntegrationTests.FSharp/BenchmarkDotNet.IntegrationTests.FSharp.fsproj
index aa75712391..f407047971 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.FSharp/BenchmarkDotNet.IntegrationTests.FSharp.fsproj
+++ b/tests/BenchmarkDotNet.IntegrationTests.FSharp/BenchmarkDotNet.IntegrationTests.FSharp.fsproj
@@ -2,6 +2,7 @@
net472;net8.0
+ Exe
false
@@ -10,6 +11,9 @@
+
+
+
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks.csproj b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks.csproj
index d7e229b621..80a9ac2738 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks.csproj
+++ b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks.csproj
@@ -1,4 +1,4 @@
-
+
BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks
@@ -16,13 +16,10 @@
true
-
-
-
-
-
-
-
+
+
+
+
@@ -37,12 +34,8 @@
-
-
-
- all
- runtime; build; native; contentfiles; analyzers; buildtransitive
-
+
+
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/MultipleFrameworksTest.cs b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/MultipleFrameworksTest.cs
index 9cc9ffeae0..d94a580e6c 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/MultipleFrameworksTest.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/MultipleFrameworksTest.cs
@@ -2,6 +2,7 @@
using BenchmarkDotNet.Configs;
using BenchmarkDotNet.Extensions;
using BenchmarkDotNet.Jobs;
+using BenchmarkDotNet.Tests;
namespace BenchmarkDotNet.IntegrationTests.ManualRunning
{
@@ -9,15 +10,11 @@ public class MultipleFrameworksTest : BenchmarkTestExecutor
{
private const string TfmEnvVarName = "TfmEnvVarName";
- public MultipleFrameworksTest(ITestOutputHelper output) : base(output)
- {
- }
-
- [Theory]
- [InlineData(RuntimeMoniker.Net461)]
- [InlineData(RuntimeMoniker.Net48)]
- [InlineData(RuntimeMoniker.NetCoreApp20)]
- [InlineData(RuntimeMoniker.Net80)]
+ [Test]
+ [TUnit.Core.Arguments(RuntimeMoniker.Net462)]
+ [TUnit.Core.Arguments(RuntimeMoniker.Net48)]
+ [TUnit.Core.Arguments(RuntimeMoniker.Net80)]
+ [TUnit.Core.Arguments(RuntimeMoniker.Net10_0)]
public void EachFrameworkIsRebuilt(RuntimeMoniker runtime)
{
var config = ManualConfig.CreateEmpty().AddJob(Job.Dry.WithRuntime(runtime.GetRuntime()).WithEnvironmentVariable(TfmEnvVarName, runtime.ToString()));
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Properties/AssemblyInfo.cs b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Properties/AssemblyInfo.cs
new file mode 100644
index 0000000000..84dd4b071d
--- /dev/null
+++ b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Properties/AssemblyInfo.cs
@@ -0,0 +1,5 @@
+using System.Runtime.InteropServices;
+
+[assembly: Guid("f8203913-4b95-4fd9-b640-08d58dd563e2")]
+
+[assembly: NotInParallel]
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Shared/System.Runtime.CompilerServices/ModuleInitializerAttribute.cs b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Shared/System.Runtime.CompilerServices/ModuleInitializerAttribute.cs
new file mode 100644
index 0000000000..874ad6d08a
--- /dev/null
+++ b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Shared/System.Runtime.CompilerServices/ModuleInitializerAttribute.cs
@@ -0,0 +1,11 @@
+#if NETFRAMEWORK
+namespace System.Runtime.CompilerServices;
+
+[AttributeUsage(AttributeTargets.Method, Inherited = false)]
+public sealed class ModuleInitializerAttribute : Attribute
+{
+ public ModuleInitializerAttribute()
+ {
+ }
+}
+#endif
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Shared/TUnit/BenchmarkTestExecutor.cs b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Shared/TUnit/BenchmarkTestExecutor.cs
new file mode 100644
index 0000000000..a4a367b256
--- /dev/null
+++ b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Shared/TUnit/BenchmarkTestExecutor.cs
@@ -0,0 +1,93 @@
+using AwesomeAssertions;
+using BenchmarkDotNet.Columns;
+using BenchmarkDotNet.Configs;
+using BenchmarkDotNet.Jobs;
+using BenchmarkDotNet.IntegrationTests;
+using BenchmarkDotNet.Loggers;
+using BenchmarkDotNet.Reports;
+using BenchmarkDotNet.Running;
+using TUnit.Core.Interfaces;
+
+namespace BenchmarkDotNet.Tests;
+
+public class BenchmarkTestExecutor
+{
+ protected ITestOutput Output => TestContext.Current!.Output!;
+
+ ///
+ /// Runs Benchmarks with the most simple config (SingleRunFastConfig)
+ /// combined with any benchmark config applied to TBenchmark (via an attribute)
+ /// By default will verify if every benchmark was successfully executed
+ ///
+ /// type that defines Benchmarks
+ /// Optional custom config to be used instead of the default
+ /// Optional: disable validation (default = true/enabled)
+ /// The summary from the benchmark run
+ public Reports.Summary CanExecute(IConfig? config = null, bool fullValidation = true)
+ {
+ return CanExecute(typeof(TBenchmark), config, fullValidation);
+ }
+
+ ///
+ /// Runs Benchmarks with the most simple config (SingleRunFastConfig)
+ /// combined with any benchmark config applied to Type (via an attribute)
+ /// By default will verify if every benchmark was successfully executed
+ ///
+ /// type that defines Benchmarks
+ /// Optional custom config to be used instead of the default
+ /// Optional: disable validation (default = true/enabled)
+ /// The summary from the benchmark run
+ public Reports.Summary CanExecute(Type type, IConfig? config = null, bool fullValidation = true)
+ {
+ // Add logging, so the Benchmark execution is in the TestRunner output (makes Debugging easier)
+ if (config == null)
+ config = CreateSimpleConfig();
+
+ if (!config.GetLoggers().OfType().Any())
+ config = config.AddLogger(Output != null ? new OutputLogger(Output) : ConsoleLogger.Default);
+ if (!config.GetLoggers().OfType().Any())
+ config = config.AddLogger(ConsoleLogger.Default);
+
+ if (!config.GetColumnProviders().Any())
+ config = config.AddColumnProvider(DefaultColumnProviders.Instance);
+
+ // Make sure we ALWAYS combine the Config (default or passed in) with any Config applied to the Type/Class
+ var summary = BenchmarkRunner.Run(type, config);
+
+ if (fullValidation)
+ {
+ summary.HasCriticalValidationErrors.Should().BeFalse("The \"Summary\" should have NOT \"HasCriticalValidationErrors\"");
+ summary.Reports.Any().Should().BeTrue("The \"Summary\" should contain at least one \"BenchmarkReport\" in the \"Reports\" collection");
+
+ summary.CheckPlatformLinkerIssues();
+
+ summary.Reports.Should().OnlyContain(r => r.BuildResult.IsBuildSuccess,
+ "The following benchmarks have failed to build: " +
+ string.Join(", ", summary.Reports.Where(r => !r.BuildResult.IsBuildSuccess).Select(r => r.BenchmarkCase.DisplayInfo)));
+
+ summary.Reports.Should().OnlyContain(r => r.ExecuteResults != null,
+ "The following benchmarks have failed to execute: " +
+ string.Join(", ", summary.Reports.Where(r => r.ExecuteResults == null || r.ExecuteResults.Any(er => !er.IsSuccess)).Select(r => r.BenchmarkCase.DisplayInfo))); ;
+
+ summary.Reports.SelectMany(x => x.ExecuteResults).Should().OnlyContain(r => r.IsSuccess,
+ "All reports should have succeeded to execute");
+ }
+
+ return summary;
+ }
+
+ protected IConfig CreateSimpleConfig(OutputLogger? logger = null, Job? job = null)
+ {
+ var baseConfig = job == null ? (IConfig)new SingleRunFastConfig() : new SingleJobConfig(job);
+ return baseConfig
+ .AddLogger(logger ?? (Output != null ? new OutputLogger(Output) : ConsoleLogger.Default))
+ .AddColumnProvider(DefaultColumnProviders.Instance)
+ .AddAnalyser(DefaultConfig.Instance.GetAnalysers().ToArray());
+ }
+
+ protected static IReadOnlyList GetSingleStandardOutput(Summary summary)
+ => summary.Reports.Single().ExecuteResults.Single().StandardOutput;
+
+ protected static IReadOnlyList GetCombinedStandardOutput(Summary summary)
+ => summary.Reports.SelectMany(r => r.ExecuteResults).SelectMany(e => e.StandardOutput).ToArray();
+}
\ No newline at end of file
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Shared/TUnit/OutputLogger.cs b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Shared/TUnit/OutputLogger.cs
new file mode 100644
index 0000000000..5350d2d9f9
--- /dev/null
+++ b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning.MultipleFrameworks/Shared/TUnit/OutputLogger.cs
@@ -0,0 +1,39 @@
+using BenchmarkDotNet.Loggers;
+using System.Runtime.CompilerServices;
+using TUnit.Core.Interfaces;
+
+namespace BenchmarkDotNet.Tests;
+
+public class OutputLogger : AccumulationLogger
+{
+ private readonly ITestOutput Output;
+ private string currentLine = "";
+
+ public OutputLogger(ITestOutput output)
+ {
+ Output = output ?? throw new ArgumentNullException(nameof(Output));
+ }
+
+ [MethodImpl(MethodImplOptions.Synchronized)]
+ public override void Write(LogKind logKind, string text)
+ {
+ currentLine += text;
+ base.Write(logKind, text);
+ }
+
+ [MethodImpl(MethodImplOptions.Synchronized)]
+ public override void WriteLine()
+ {
+ Output.WriteLine(currentLine);
+ currentLine = "";
+ base.WriteLine();
+ }
+
+ [MethodImpl(MethodImplOptions.Synchronized)]
+ public override void WriteLine(LogKind logKind, string text)
+ {
+ Output.WriteLine(currentLine + text);
+ currentLine = "";
+ base.WriteLine(logKind, text);
+ }
+}
\ No newline at end of file
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/BenchmarkDotNet.IntegrationTests.ManualRunning.csproj b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/BenchmarkDotNet.IntegrationTests.ManualRunning.csproj
old mode 100755
new mode 100644
index 6a05e2c1b7..4cc3afcdd5
--- a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/BenchmarkDotNet.IntegrationTests.ManualRunning.csproj
+++ b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/BenchmarkDotNet.IntegrationTests.ManualRunning.csproj
@@ -3,6 +3,9 @@
BenchmarkDotNet.IntegrationTests.ManualRunning
net472;net8.0
+
+ $(MSBuildWarningsAsMessages);MSB3277
+ Exe
true
BenchmarkDotNet.IntegrationTests.ManualRunning
BenchmarkDotNet.IntegrationTests.ManualRunning
@@ -14,7 +17,6 @@
-
@@ -24,11 +26,13 @@
$(DefineConstants);$(ExtraDefineConstants)
-
+
-
-
-
+
+
+
+
+
@@ -43,12 +47,7 @@
-
-
-
- all
- runtime; build; native; contentfiles; analyzers; buildtransitive
-
+
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/DotMemoryTests.cs b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/DotMemoryTests.cs
index efb02f0aea..0020481687 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/DotMemoryTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/DotMemoryTests.cs
@@ -5,6 +5,7 @@
using BenchmarkDotNet.Jobs;
using BenchmarkDotNet.Portability;
using BenchmarkDotNet.Toolchains.InProcess.Emit;
+using Xunit;
namespace BenchmarkDotNet.IntegrationTests.ManualRunning
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/DotTraceTests.cs b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/DotTraceTests.cs
index dc11404f9f..4a240100c4 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/DotTraceTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/DotTraceTests.cs
@@ -5,6 +5,7 @@
using BenchmarkDotNet.Jobs;
using BenchmarkDotNet.Portability;
using BenchmarkDotNet.Toolchains.InProcess.Emit;
+using Xunit;
namespace BenchmarkDotNet.IntegrationTests.ManualRunning
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/MsBuildArgumentTests.cs b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/MsBuildArgumentTests.cs
index 6592e76047..434af9df6c 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/MsBuildArgumentTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests.ManualRunning/MsBuildArgumentTests.cs
@@ -2,6 +2,7 @@
using BenchmarkDotNet.Configs;
using BenchmarkDotNet.Environments;
using BenchmarkDotNet.Jobs;
+using Xunit;
namespace BenchmarkDotNet.IntegrationTests.ManualRunning
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests.Static/BenchmarkDotNet.IntegrationTests.Static.csproj b/tests/BenchmarkDotNet.IntegrationTests.Static/BenchmarkDotNet.IntegrationTests.Static.csproj
index 268340278e..4018d35038 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.Static/BenchmarkDotNet.IntegrationTests.Static.csproj
+++ b/tests/BenchmarkDotNet.IntegrationTests.Static/BenchmarkDotNet.IntegrationTests.Static.csproj
@@ -3,6 +3,7 @@
BenchmarkDotNet.IntegrationTests.Static
net472;net8.0
+ Exe
true
BenchmarkDotNet.IntegrationTests.Static
BenchmarkDotNet.IntegrationTests.Static
@@ -13,6 +14,9 @@
+
+
+
diff --git a/tests/BenchmarkDotNet.IntegrationTests.VisualBasic/BenchmarkDotNet.IntegrationTests.VisualBasic.vbproj b/tests/BenchmarkDotNet.IntegrationTests.VisualBasic/BenchmarkDotNet.IntegrationTests.VisualBasic.vbproj
index 65ac132061..af80ee9f6c 100644
--- a/tests/BenchmarkDotNet.IntegrationTests.VisualBasic/BenchmarkDotNet.IntegrationTests.VisualBasic.vbproj
+++ b/tests/BenchmarkDotNet.IntegrationTests.VisualBasic/BenchmarkDotNet.IntegrationTests.VisualBasic.vbproj
@@ -2,9 +2,13 @@
net472;net8.0
+ Exe
+
+
+
\ No newline at end of file
diff --git a/tests/BenchmarkDotNet.IntegrationTests/AllSetupAndCleanupTest.cs b/tests/BenchmarkDotNet.IntegrationTests/AllSetupAndCleanupTest.cs
index 54934cd6a2..94965c50f6 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/AllSetupAndCleanupTest.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/AllSetupAndCleanupTest.cs
@@ -2,7 +2,7 @@
using BenchmarkDotNet.Engines;
using BenchmarkDotNet.Jobs;
using BenchmarkDotNet.Reports;
-using BenchmarkDotNet.Tests.XUnit;
+using BenchmarkDotNet.Tests;
namespace BenchmarkDotNet.IntegrationTests
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests/AsyncBenchmarksTests.cs b/tests/BenchmarkDotNet.IntegrationTests/AsyncBenchmarksTests.cs
index 52345b585d..56d428fa6d 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/AsyncBenchmarksTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/AsyncBenchmarksTests.cs
@@ -61,14 +61,14 @@ public void TaskReturningMethodsAreAwaited()
[Fact]
public void TaskReturningMethodsAreAwaited_AlreadyComplete() => CanExecute();
- public static TheoryData GetToolchains() =>
+ public static TheoryData GetToolchains() => new(
[
new InProcessEmitToolchain(new() { ExecuteOnSeparateThread = false }),
new InProcessEmitToolchain(new() { ExecuteOnSeparateThread = true }),
new InProcessNoEmitToolchain(new() { ExecuteOnSeparateThread = false }),
new InProcessNoEmitToolchain(new() { ExecuteOnSeparateThread = true }),
Job.Default.GetToolchain()
- ];
+ ]);
[Theory]
[MemberData(nameof(GetToolchains), DisableDiscoveryEnumeration = true)]
diff --git a/tests/BenchmarkDotNet.IntegrationTests/BenchmarkDotNet.IntegrationTests.csproj b/tests/BenchmarkDotNet.IntegrationTests/BenchmarkDotNet.IntegrationTests.csproj
index 9da34e4662..cb53e6dc27 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/BenchmarkDotNet.IntegrationTests.csproj
+++ b/tests/BenchmarkDotNet.IntegrationTests/BenchmarkDotNet.IntegrationTests.csproj
@@ -4,6 +4,7 @@
BenchmarkDotNet.IntegrationTests
net472;net8.0
net8.0
+ Exe
true
BenchmarkDotNet.IntegrationTests
BenchmarkDotNet.IntegrationTests
@@ -16,7 +17,6 @@
-
@@ -33,20 +33,21 @@
-
-
+
-
+
+
+
+
+
+
+
-
-
- all
- runtime; build; native; contentfiles; analyzers; buildtransitive
-
+
diff --git a/tests/BenchmarkDotNet.IntegrationTests/CallerThreadTests.cs b/tests/BenchmarkDotNet.IntegrationTests/CallerThreadTests.cs
index fe0b3940cd..9073af2e4e 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/CallerThreadTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/CallerThreadTests.cs
@@ -19,12 +19,12 @@ namespace BenchmarkDotNet.IntegrationTests;
public class CallerThreadTests(ITestOutputHelper output) : BenchmarkTestExecutor(output)
{
- public static TheoryData GetToolchains() =>
+ public static TheoryData GetToolchains() => new(
[
new InProcessEmitToolchain(new() { ExecuteOnSeparateThread = false }),
new InProcessNoEmitToolchain(new() { ExecuteOnSeparateThread = false }),
Job.Default.GetToolchain()
- ];
+ ]);
[Theory]
[MemberData(nameof(GetToolchains), DisableDiscoveryEnumeration = true)]
diff --git a/tests/BenchmarkDotNet.IntegrationTests/CopyToOutputTests.cs b/tests/BenchmarkDotNet.IntegrationTests/CopyToOutputTests.cs
index bd8da25d01..3d88695806 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/CopyToOutputTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/CopyToOutputTests.cs
@@ -1,5 +1,6 @@
#if NETFRAMEWORK
using BenchmarkDotNet.IntegrationTests.CustomPaths;
+using Xunit;
namespace BenchmarkDotNet.IntegrationTests
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests/CustomBuildConfigurationTests.cs b/tests/BenchmarkDotNet.IntegrationTests/CustomBuildConfigurationTests.cs
index 6581960e2c..2e4e317692 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/CustomBuildConfigurationTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/CustomBuildConfigurationTests.cs
@@ -1,12 +1,10 @@
-using System.Reflection;
using BenchmarkDotNet.Attributes;
using BenchmarkDotNet.Configs;
using BenchmarkDotNet.Extensions;
using BenchmarkDotNet.Jobs;
using BenchmarkDotNet.Portability;
using BenchmarkDotNet.Tests.XUnit;
-#if !DEBUG
-#endif
+using System.Reflection;
namespace BenchmarkDotNet.IntegrationTests
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests/DisassemblyDiagnoserTests.cs b/tests/BenchmarkDotNet.IntegrationTests/DisassemblyDiagnoserTests.cs
index 5e804a3cde..6aef8a3e51 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/DisassemblyDiagnoserTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/DisassemblyDiagnoserTests.cs
@@ -1,6 +1,7 @@
using BenchmarkDotNet.Attributes;
using BenchmarkDotNet.Columns;
using BenchmarkDotNet.Configs;
+using BenchmarkDotNet.Detectors;
using BenchmarkDotNet.Diagnosers;
using BenchmarkDotNet.Disassemblers;
using BenchmarkDotNet.Engines;
@@ -85,6 +86,9 @@ public void Recursive()
[Trait(Constants.Category, Constants.BackwardCompatibilityCategory)]
public void CanDisassembleAllMethodCalls(Jit jit, Platform platform, IToolchain toolchain)
{
+ if (OsDetector.IsMacOS() && toolchain.IsInProcess)
+ Assert.Skip("https://github.com/dotnet/BenchmarkDotNet/issues/3076");
+
var disassemblyDiagnoser = new DisassemblyDiagnoser(
new DisassemblyDiagnoserConfig(printSource: true, maxDepth: 3));
@@ -105,6 +109,9 @@ public void CanDisassembleAllMethodCalls(Jit jit, Platform platform, IToolchain
[Trait(Constants.Category, Constants.BackwardCompatibilityCategory)]
public void CanDisassembleAllMethodCallsUsingFilters(Jit jit, Platform platform, IToolchain toolchain)
{
+ if (OsDetector.IsMacOS())
+ Assert.Skip("https://github.com/dotnet/BenchmarkDotNet/issues/3076");
+
var disassemblyDiagnoser = new DisassemblyDiagnoser(
new DisassemblyDiagnoserConfig(printSource: true, maxDepth: 1, filters: ["*WithCalls*"]));
@@ -131,6 +138,9 @@ public void CanDisassembleAllMethodCallsUsingFilters(Jit jit, Platform platform,
[Trait(Constants.Category, Constants.BackwardCompatibilityCategory)]
public void CanDisassembleGenericTypes(Jit jit, Platform platform, IToolchain toolchain)
{
+ if (OsDetector.IsMacOS())
+ Assert.Skip("https://github.com/dotnet/BenchmarkDotNet/issues/3076");
+
var disassemblyDiagnoser = new DisassemblyDiagnoser(
new DisassemblyDiagnoserConfig(printSource: true, maxDepth: 3));
@@ -152,6 +162,9 @@ [Benchmark] public void JustReturn() { }
[Trait(Constants.Category, Constants.BackwardCompatibilityCategory)]
public void CanDisassembleInlinableBenchmarks(Jit jit, Platform platform, IToolchain toolchain)
{
+ if (OsDetector.IsMacOS())
+ Assert.Skip("https://github.com/dotnet/BenchmarkDotNet/issues/3076");
+
var disassemblyDiagnoser = new DisassemblyDiagnoser(
new DisassemblyDiagnoserConfig(printSource: true, maxDepth: 3));
diff --git a/tests/BenchmarkDotNet.IntegrationTests/EngineTests.cs b/tests/BenchmarkDotNet.IntegrationTests/EngineTests.cs
index f37716cb04..84b5199206 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/EngineTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/EngineTests.cs
@@ -72,12 +72,12 @@ public class FooBench
public void Foo() => Thread.Sleep(10);
}
- public static TheoryData GetToolchains() =>
+ public static TheoryData GetToolchains() => new(
[
InProcessEmitToolchain.Default,
InProcessNoEmitToolchain.Default,
Job.Default.GetToolchain()
- ];
+ ]);
// #1120
[Theory]
diff --git a/tests/BenchmarkDotNet.IntegrationTests/GcModeTests.cs b/tests/BenchmarkDotNet.IntegrationTests/GcModeTests.cs
index 8d2558ebe3..ccd5f365fe 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/GcModeTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/GcModeTests.cs
@@ -1,7 +1,8 @@
-using System.Runtime;
using BenchmarkDotNet.Attributes;
using BenchmarkDotNet.Configs;
using BenchmarkDotNet.Jobs;
+using System.Runtime;
+
#if NETFRAMEWORK
using BenchmarkDotNet.Environments;
#endif
diff --git a/tests/BenchmarkDotNet.IntegrationTests/InProcessTest.cs b/tests/BenchmarkDotNet.IntegrationTests/InProcessTest.cs
index f6868a1681..3b33f7745c 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/InProcessTest.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/InProcessTest.cs
@@ -17,7 +17,6 @@
using System.Reflection;
using System.Runtime.CompilerServices;
-
namespace BenchmarkDotNet.IntegrationTests
{
public class InProcessTest : BenchmarkTestExecutor
diff --git a/tests/BenchmarkDotNet.IntegrationTests/MemoryDiagnoserTests.cs b/tests/BenchmarkDotNet.IntegrationTests/MemoryDiagnoserTests.cs
old mode 100755
new mode 100644
diff --git a/tests/BenchmarkDotNet.IntegrationTests/ReferencesTests.cs b/tests/BenchmarkDotNet.IntegrationTests/ReferencesTests.cs
index 9daa2db80a..3adec4f6cb 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/ReferencesTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/ReferencesTests.cs
@@ -1,4 +1,3 @@
-
namespace BenchmarkDotNet.IntegrationTests
{
public class ReferencesTests : BenchmarkTestExecutor
diff --git a/tests/BenchmarkDotNet.IntegrationTests/RunAsyncTests.cs b/tests/BenchmarkDotNet.IntegrationTests/RunAsyncTests.cs
index 5a1405bb78..62a21b6707 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/RunAsyncTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/RunAsyncTests.cs
@@ -9,14 +9,14 @@ namespace BenchmarkDotNet.IntegrationTests;
public class RunAsyncTests(ITestOutputHelper output) : BenchmarkTestExecutor(output)
{
- public static TheoryData GetToolchains() =>
+ public static TheoryData GetToolchains() => new(
[
new InProcessEmitToolchain(new() { ExecuteOnSeparateThread = false }),
new InProcessEmitToolchain(new() { ExecuteOnSeparateThread = true }),
new InProcessNoEmitToolchain(new() { ExecuteOnSeparateThread = false }),
new InProcessNoEmitToolchain(new() { ExecuteOnSeparateThread = true }),
Job.Default.GetToolchain()
- ];
+ ]);
[Theory]
[MemberData(nameof(GetToolchains), DisableDiscoveryEnumeration = true)]
diff --git a/tests/BenchmarkDotNet.IntegrationTests/Shared/BenchmarkTestExecutor.cs b/tests/BenchmarkDotNet.IntegrationTests/Shared/BenchmarkTestExecutor.cs
index e3413c5e4a..b608fdc1ec 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/Shared/BenchmarkTestExecutor.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/Shared/BenchmarkTestExecutor.cs
@@ -1,11 +1,11 @@
using BenchmarkDotNet.Columns;
using BenchmarkDotNet.Configs;
-using BenchmarkDotNet.IntegrationTests.Xunit;
using BenchmarkDotNet.Jobs;
using BenchmarkDotNet.Loggers;
using BenchmarkDotNet.Reports;
using BenchmarkDotNet.Running;
using BenchmarkDotNet.Tests.Loggers;
+using Xunit;
namespace BenchmarkDotNet.IntegrationTests
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests/Shared/Extensions.cs b/tests/BenchmarkDotNet.IntegrationTests/Shared/Extensions.cs
index e6f27f54eb..bbee466722 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/Shared/Extensions.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/Shared/Extensions.cs
@@ -1,6 +1,6 @@
using BenchmarkDotNet.Reports;
-namespace BenchmarkDotNet.IntegrationTests.Xunit
+namespace BenchmarkDotNet.IntegrationTests
{
public static class Extensions
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests/Shared/MisconfiguredEnvironmentException.cs b/tests/BenchmarkDotNet.IntegrationTests/Shared/MisconfiguredEnvironmentException.cs
index 8f5d236d9f..c397c9e339 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/Shared/MisconfiguredEnvironmentException.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/Shared/MisconfiguredEnvironmentException.cs
@@ -1,4 +1,4 @@
-namespace BenchmarkDotNet.IntegrationTests.Xunit
+namespace BenchmarkDotNet.IntegrationTests
{
public class MisconfiguredEnvironmentException : Exception
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests/TailCallDiagnoserTests.cs b/tests/BenchmarkDotNet.IntegrationTests/TailCallDiagnoserTests.cs
index c224cbd47f..8d34d90724 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/TailCallDiagnoserTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/TailCallDiagnoserTests.cs
@@ -11,6 +11,7 @@
using BenchmarkDotNet.Tests.XUnit;
using System.Collections.Generic;
using System.Linq;
+using Xunit;
namespace BenchmarkDotNet.IntegrationTests
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests/ThreadingDiagnoserTests.cs b/tests/BenchmarkDotNet.IntegrationTests/ThreadingDiagnoserTests.cs
index c1f0160278..d478fe14b7 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/ThreadingDiagnoserTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/ThreadingDiagnoserTests.cs
@@ -13,6 +13,8 @@
using BenchmarkDotNet.Toolchains.NativeAot;
using BenchmarkDotNet.Detectors;
using BenchmarkDotNet.IntegrationTests.Xunit;
+using BenchmarkDotNet.Portability;
+using Xunit;
namespace BenchmarkDotNet.IntegrationTests
{
diff --git a/tests/BenchmarkDotNet.IntegrationTests/WasmTests.cs b/tests/BenchmarkDotNet.IntegrationTests/WasmTests.cs
index a438cd5e56..3cce2158d2 100644
--- a/tests/BenchmarkDotNet.IntegrationTests/WasmTests.cs
+++ b/tests/BenchmarkDotNet.IntegrationTests/WasmTests.cs
@@ -98,4 +98,4 @@ public void Check()
}
}
}
-}
+}
\ No newline at end of file
diff --git a/tests/BenchmarkDotNet.Tests/BenchmarkDotNet.Tests.csproj b/tests/BenchmarkDotNet.Tests/BenchmarkDotNet.Tests.csproj
old mode 100755
new mode 100644
index a72dd579a3..c256243142
--- a/tests/BenchmarkDotNet.Tests/BenchmarkDotNet.Tests.csproj
+++ b/tests/BenchmarkDotNet.Tests/BenchmarkDotNet.Tests.csproj
@@ -3,6 +3,7 @@
BenchmarkDotNet.Tests
net8.0;net10.0;net472
+ Exe
BenchmarkDotNet.Tests
BenchmarkDotNet.Tests
true
@@ -11,7 +12,6 @@
-
@@ -20,13 +20,8 @@
-
-
-
-
- all
- runtime; build; native; contentfiles; analyzers; buildtransitive
-
+
+
diff --git a/tests/BenchmarkDotNet.Tests/Detectors/Cpu/LinuxCpuInfoParserTests.cs b/tests/BenchmarkDotNet.Tests/Detectors/Cpu/LinuxCpuInfoParserTests.cs
index 393bd2798b..e907ffa9aa 100644
--- a/tests/BenchmarkDotNet.Tests/Detectors/Cpu/LinuxCpuInfoParserTests.cs
+++ b/tests/BenchmarkDotNet.Tests/Detectors/Cpu/LinuxCpuInfoParserTests.cs
@@ -138,7 +138,7 @@ public void AmdRyzen9_7950X()
CPU max MHz: 5881.0000
CPU min MHz: 400.0000
BogoMIPS: 8983.23
- Flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall nx mmxext fxsr_opt pdpe1gb rdtscp lm constant_tsc rep_good amd_lbr_v2 nopl nonstop_tsc cpuid extd_apicid aperfmperf rapl
+ Flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall nx mmxext fxsr_opt pdpe1gb rdtscp lm constant_tsc rep_good amd_lbr_v2 nopl nonstop_tsc cpuid extd_apicid aperfmperf rapl
pni pclmulqdq monitor ssse3 fma cx16 sse4_1 sse4_2 x2apic movbe popcnt aes xsave avx f16c rdrand lahf_lm cmp_legacy svm extapic cr8_legacy abm sse4a misalignsse 3dnowprefetch osvw ibs skinit wdt tce topoext perfctr_core perfctr_nb
bpext perfctr_llc mwaitx cpb cat_l3 cdp_l3 hw_pstate ssbd mba perfmon_v2 ibrs ibpb stibp ibrs_enhanced vmmcall fsgsbase bmi1 avx2 smep bmi2 erms invpcid cqm rdt_a avx512f avx512dq rdseed adx smap avx512ifma clflushopt clwb avx512
cd sha_ni avx512bw avx512vl xsaveopt xsavec xgetbv1 xsaves cqm_llc cqm_occup_llc cqm_mbm_total cqm_mbm_local user_shstk avx512_bf16 clzero irperf xsaveerptr rdpru wbnoinvd cppc arat npt lbrv svm_lock nrip_save tsc_scale vmcb_clean
diff --git a/tests/BenchmarkDotNet.Tests/Detectors/Cpu/PowershellWmiCpuInfoParserTests.cs b/tests/BenchmarkDotNet.Tests/Detectors/Cpu/PowershellWmiCpuInfoParserTests.cs
index 307a994ef6..1c6bbe6b2b 100644
--- a/tests/BenchmarkDotNet.Tests/Detectors/Cpu/PowershellWmiCpuInfoParserTests.cs
+++ b/tests/BenchmarkDotNet.Tests/Detectors/Cpu/PowershellWmiCpuInfoParserTests.cs
@@ -35,13 +35,13 @@ public void RealTwoProcessorEightCoresTest()
Name:Intel(R) Xeon(R) CPU E5-2630 v3
NumberOfCores:8
NumberOfLogicalProcessors:16
-
-
+
+
MaxClockSpeed:2400
Name:Intel(R) Xeon(R) CPU E5-2630 v3
NumberOfCores:8
NumberOfLogicalProcessors:16
-
+
""";
CpuInfo? actual = PowershellWmiCpuInfoParser.Parse(cpuInfo);
diff --git a/tests/BenchmarkDotNet.Tests/Shared/Loggers/OutputLogger.cs b/tests/BenchmarkDotNet.Tests/Shared/Loggers/OutputLogger.cs
index 2a83781f14..e9020d6e24 100644
--- a/tests/BenchmarkDotNet.Tests/Shared/Loggers/OutputLogger.cs
+++ b/tests/BenchmarkDotNet.Tests/Shared/Loggers/OutputLogger.cs
@@ -1,5 +1,6 @@
using BenchmarkDotNet.Loggers;
using System.Runtime.CompilerServices;
+using Xunit;
namespace BenchmarkDotNet.Tests.Loggers
{
diff --git a/tests/BenchmarkDotNet.Tests/Shared/XUnit/SmartAssert.cs b/tests/BenchmarkDotNet.Tests/Shared/SmartAssert.cs
similarity index 96%
rename from tests/BenchmarkDotNet.Tests/Shared/XUnit/SmartAssert.cs
rename to tests/BenchmarkDotNet.Tests/Shared/SmartAssert.cs
index 3cbe6b3f82..c1cad4e86a 100644
--- a/tests/BenchmarkDotNet.Tests/Shared/XUnit/SmartAssert.cs
+++ b/tests/BenchmarkDotNet.Tests/Shared/SmartAssert.cs
@@ -1,6 +1,6 @@
using System.Text;
-namespace BenchmarkDotNet.Tests.XUnit
+namespace BenchmarkDotNet.Tests
{
public static class SmartAssert
{
diff --git a/tests/BenchmarkDotNet.Tests/Shared/XUnit/FactEnvSpecific.cs b/tests/BenchmarkDotNet.Tests/Shared/XUnit/FactEnvSpecific.cs
index 6c57f08078..a0e02d4c07 100644
--- a/tests/BenchmarkDotNet.Tests/Shared/XUnit/FactEnvSpecific.cs
+++ b/tests/BenchmarkDotNet.Tests/Shared/XUnit/FactEnvSpecific.cs
@@ -1,3 +1,5 @@
+using System.Runtime.CompilerServices;
+using Xunit;
namespace BenchmarkDotNet.Tests.XUnit;
@@ -14,4 +16,9 @@ public FactEnvSpecificAttribute(string reason, params EnvRequirement[] requireme
if (skip != null)
Skip = $"{skip} ({reason})";
}
+
+ public FactEnvSpecificAttribute([CallerFilePath] string? sourceFilePath = null, [CallerLineNumber] int sourceLineNumber = -1)
+ : base(sourceFilePath, sourceLineNumber)
+ {
+ }
}
\ No newline at end of file
diff --git a/tests/BenchmarkDotNet.Tests/Shared/XUnit/InlineDataEnvSpecific.cs b/tests/BenchmarkDotNet.Tests/Shared/XUnit/InlineDataEnvSpecific.cs
index 65acf07295..8f9419f5c0 100644
--- a/tests/BenchmarkDotNet.Tests/Shared/XUnit/InlineDataEnvSpecific.cs
+++ b/tests/BenchmarkDotNet.Tests/Shared/XUnit/InlineDataEnvSpecific.cs
@@ -1,24 +1,53 @@
using System.Reflection;
+using Xunit;
using Xunit.Sdk;
+using Xunit.v3;
namespace BenchmarkDotNet.Tests.XUnit;
-[DataDiscoverer("BenchmarkDotNet.Tests.XUnit.InlineDataEnvSpecificDiscoverer", "BenchmarkDotNet.IntegrationTests")]
[AttributeUsage(AttributeTargets.Method, AllowMultiple = true)]
public class InlineDataEnvSpecific : DataAttribute
{
- readonly object[] data;
+ ///
+ /// Gets the data to be passed to the test.
+ ///
+ // If the user passes null to the constructor, we assume what they meant was a
+ // single null value to be passed to the test.
+ public object?[] Data { get; }
- public InlineDataEnvSpecific(object data, string reason, params EnvRequirement[] requirements)
+ public InlineDataEnvSpecific(object? data, string reason, params EnvRequirement[] requirements)
: this([data], reason, requirements) { }
- public InlineDataEnvSpecific(object[] data, string reason, params EnvRequirement[] requirements)
+ public InlineDataEnvSpecific(object?[] data, string reason, params EnvRequirement[] requirements)
{
- this.data = data;
+ // If the user passes null to the constructor, we assume what they meant was a
+ // single null value to be passed to the test.
+ Data = data ?? [null];
string? skip = EnvRequirementChecker.GetSkip(requirements);
if (skip != null)
Skip = $"{skip} ({reason})";
}
- public override IEnumerable GetData(MethodInfo testMethod) => [data];
+ public override ValueTask> GetData(
+ MethodInfo testMethod,
+ DisposalTracker disposalTracker)
+ {
+ var traits = new Dictionary>(StringComparer.OrdinalIgnoreCase);
+ TestIntrospectionHelper.MergeTraitsInto(traits, Traits);
+
+ return new([
+ new TheoryDataRow(Data)
+ {
+ Explicit = ExplicitAsNullable,
+ Label = Label,
+ Skip = Skip,
+ TestDisplayName = TestDisplayName,
+ Timeout = TimeoutAsNullable,
+ Traits = traits,
+ }
+ ]);
+ }
+
+ public override bool SupportsDiscoveryEnumeration()
+ => true;
}
diff --git a/tests/BenchmarkDotNet.Tests/Shared/XUnit/InlineDataEnvSpecificDiscoverer.cs b/tests/BenchmarkDotNet.Tests/Shared/XUnit/InlineDataEnvSpecificDiscoverer.cs
deleted file mode 100644
index dba7caa4c2..0000000000
--- a/tests/BenchmarkDotNet.Tests/Shared/XUnit/InlineDataEnvSpecificDiscoverer.cs
+++ /dev/null
@@ -1,32 +0,0 @@
-using Xunit.Sdk;
-
-namespace BenchmarkDotNet.Tests.XUnit;
-
-public class InlineDataEnvSpecificDiscoverer : IDataDiscoverer
-{
- public IEnumerable GetData(IAttributeInfo dataAttribute, IMethodInfo testMethod)
- {
- // InlineDataEnvSpecific has two constructors:
- // 1. InlineDataEnvSpecific(object data, string reason, params EnvRequirement[] requirements)
- // 2. InlineDataEnvSpecific(object[] data, string reason, params EnvRequirement[] requirements)
- // GetConstructorArguments returns arguments from the constructor that was actually called
-
- var args = dataAttribute.GetConstructorArguments().ToArray();
- if (args.Length == 0)
- yield break;
-
- // First argument is either a single object or object[] - wrap accordingly
- if (args[0] is object[] dataArray)
- {
- // Array constructor was used
- yield return dataArray;
- }
- else
- {
- // Single object constructor was used - wrap in array
- yield return new[] { args[0] };
- }
- }
-
- public bool SupportsDiscoveryEnumeration(IAttributeInfo dataAttribute, IMethodInfo testMethod) => true;
-}
diff --git a/tests/BenchmarkDotNet.Tests/Shared/XUnit/TheoryEnvSpecific.cs b/tests/BenchmarkDotNet.Tests/Shared/XUnit/TheoryEnvSpecific.cs
index 3303797884..92f039f030 100644
--- a/tests/BenchmarkDotNet.Tests/Shared/XUnit/TheoryEnvSpecific.cs
+++ b/tests/BenchmarkDotNet.Tests/Shared/XUnit/TheoryEnvSpecific.cs
@@ -1,3 +1,5 @@
+using System.Runtime.CompilerServices;
+using Xunit;
namespace BenchmarkDotNet.Tests.XUnit;
@@ -14,4 +16,9 @@ public TheoryEnvSpecificAttribute(string reason, params EnvRequirement[] require
if (skip != null)
Skip = $"{skip} ({reason})";
}
+
+ public TheoryEnvSpecificAttribute([CallerFilePath] string? sourceFilePath = null, [CallerLineNumber] int sourceLineNumber = -1)
+ : base(sourceFilePath, sourceLineNumber)
+ {
+ }
}
\ No newline at end of file
diff --git a/tests/BenchmarkDotNet.Tests/TargetFrameworkVersionParsingTestscs.cs b/tests/BenchmarkDotNet.Tests/TargetFrameworkVersionParsingTests.cs
similarity index 100%
rename from tests/BenchmarkDotNet.Tests/TargetFrameworkVersionParsingTestscs.cs
rename to tests/BenchmarkDotNet.Tests/TargetFrameworkVersionParsingTests.cs
diff --git a/tests/Directory.Build.props b/tests/Directory.Build.props
index 95b878006d..68d9e50706 100644
--- a/tests/Directory.Build.props
+++ b/tests/Directory.Build.props
@@ -10,6 +10,10 @@
$([System.IO.Path]::GetDirectoryName($(MSBuildThisFileDirectory)))
+
+ true
+
+
diff --git a/tests/Directory.Build.targets b/tests/Directory.Build.targets
new file mode 100644
index 0000000000..be5cd7eabe
--- /dev/null
+++ b/tests/Directory.Build.targets
@@ -0,0 +1,14 @@
+
+
+
+ true
+
+
+
+
+
+
+
+