From 7b7cbfeeada07418ec8a63855cf3d56967c6e2d9 Mon Sep 17 00:00:00 2001 From: Krzysztof Cwalina Date: Wed, 2 May 2018 08:16:00 -0700 Subject: [PATCH] Ported StorageBench to BenchmarkDotNet --- tests/Benchmarks/{ => Azure}/StorageBench.cs | 59 ++++++-------------- 1 file changed, 17 insertions(+), 42 deletions(-) rename tests/Benchmarks/{ => Azure}/StorageBench.cs (71%) diff --git a/tests/Benchmarks/StorageBench.cs b/tests/Benchmarks/Azure/StorageBench.cs similarity index 71% rename from tests/Benchmarks/StorageBench.cs rename to tests/Benchmarks/Azure/StorageBench.cs index 2464ad3bda1..f614e5e8ef2 100644 --- a/tests/Benchmarks/StorageBench.cs +++ b/tests/Benchmarks/Azure/StorageBench.cs @@ -2,7 +2,7 @@ // The .NET Foundation licenses this file to you under the MIT license. // See the LICENSE file in the project root for more information. -using Microsoft.Xunit.Performance; +using BenchmarkDotNet.Attributes; using System; using System.Azure.Authentication; using System.Buffers; @@ -27,66 +27,41 @@ public class StorageBench static Sha256 sha; const int BufferSize = 256; - static StorageBench() + [GlobalSetup] + public void Setup() { var keyBytes = Key.ComputeKeyBytes(fakeKey); sha = Sha256.Create(keyBytes); } - [Benchmark] - static void Msdn() - { - foreach (var iteration in Benchmark.Iterations) - { - using (iteration.StartMeasurement()) - { - StorageBaselineFromMsdn(fakeKey, verb, canonicalizedResource, utc); - } - } - } + [Benchmark(Baseline = true)] + public void Msdn() + => StorageBaselineFromMsdn(fakeKey, verb, canonicalizedResource, utc); [Benchmark] - static void Primitive() - { - foreach (var iteration in Benchmark.Iterations) + public void Primitive() + { + if (!TryWritePrimitive(buffer, sha, verb, canonicalizedResource, utc, out int bytesWritten)) { - using (iteration.StartMeasurement()) - { - if (!TryWritePrimitive(buffer, sha, verb, canonicalizedResource, utc, out int bytesWritten)) - { - throw new Exception("TryWrite failed"); - } - } + throw new Exception("TryWrite failed"); } } [Benchmark] - static void Writer() + public void TryWrite() { - foreach (var iteration in Benchmark.Iterations) + if(!StorageAccessSignature.TryWrite(buffer, sha, "GET", canonicalizedResource, utc, out int bytesWritten)) { - using (iteration.StartMeasurement()) - { - if(!StorageAccessSignature.TryWrite(buffer, sha, "GET", canonicalizedResource, utc, out int bytesWritten)) - { - throw new Exception("TryWrite failed"); - } - } + throw new Exception("TryWrite failed"); } } [Benchmark] - static void WriterUtf8() + public void TryWriteUtf8() { - foreach (var iteration in Benchmark.Iterations) + if (!StorageAccessSignature.TryWrite(buffer, sha, verbU8, canonicalizedResourceU8, utc, out int bytesWritten)) { - using (iteration.StartMeasurement()) - { - if (!StorageAccessSignature.TryWrite(buffer, sha, verbU8, canonicalizedResourceU8, utc, out int bytesWritten)) - { - throw new Exception("TryWrite failed"); - } - } + throw new Exception("TryWrite failed"); } } @@ -114,7 +89,7 @@ static string StorageBaselineFromMsdn(string key, string verb, string canonicali } } - public static bool TryWritePrimitive(Span output, Sha256 hash, string verb, string canonicalizedResource, DateTime utc, out int bytesWritten) + static bool TryWritePrimitive(Span output, Sha256 hash, string verb, string canonicalizedResource, DateTime utc, out int bytesWritten) { int written, consumed; bytesWritten = 0;