Skip to content

Commit

Permalink
Add stress test for strong-typed logging (#2892)
Browse files Browse the repository at this point in the history
* Add stress test for strong-typed logging

* simplify proj

* ...

* eol

* ref type

* tweak

Co-authored-by: Cijo Thomas <[email protected]>
  • Loading branch information
reyang and cijothomas authored Feb 15, 2022
1 parent 8dc2d4a commit 9232e56
Show file tree
Hide file tree
Showing 5 changed files with 233 additions and 0 deletions.
27 changes: 27 additions & 0 deletions test/OpenTelemetry.Tests.Stress.Logs/DummyProcessor.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
// <copyright file="DummyProcessor.cs" company="OpenTelemetry Authors">
// Copyright The OpenTelemetry Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// </copyright>

using OpenTelemetry;
using OpenTelemetry.Logs;

namespace OpenTelemetry.Tests.Stress;

internal class DummyProcessor : BaseProcessor<LogRecord>
{
public override void OnEnd(LogRecord record)
{
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<OutputType>Exe</OutputType>
<TargetFrameworks>netcoreapp3.1;net5.0;net6.0;net462</TargetFrameworks>
<IsPackable>false</IsPackable>
</PropertyGroup>

<ItemGroup>
<Compile Include="$(RepoRoot)\test\OpenTelemetry.Tests.Stress\Skeleton.cs" />
<ProjectReference Include="$(RepoRoot)\src\OpenTelemetry.Exporter.Prometheus\OpenTelemetry.Exporter.Prometheus.csproj" />
<PackageReference Include="Microsoft.Extensions.Logging" Version="[6.0.0,)" />
</ItemGroup>

<ItemGroup>
<Compile Include="$(RepoRoot)\test\OpenTelemetry.Tests\Shared\Utils.cs" Link="Includes\Utils.cs" />
</ItemGroup>

</Project>
120 changes: 120 additions & 0 deletions test/OpenTelemetry.Tests.Stress.Logs/Payload.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
// <copyright file="Payload.cs" company="OpenTelemetry Authors">
// Copyright The OpenTelemetry Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// </copyright>

namespace OpenTelemetry.Tests.Stress;

internal class Payload
{
public int Field001 = 0;
public float Field002 = 2.718281828f;
public double Field003 = 3.141592653589793d;
public string Field004 = "Hello, World!";
public bool Field005 = true;
public int Field006 = 6;
public int Field007 = 7;
public int Field008 = 8;
public int Field009 = 9;
public int Field010 = 10;
public int Field011 = 11;
public int Field012 = 12;
public int Field013 = 13;
public int Field014 = 14;
public int Field015 = 15;
public int Field016 = 16;
public int Field017 = 17;
public int Field018 = 18;
public int Field019 = 19;
public int Field020 = 20;
public int Field021 = 21;
public int Field022 = 22;
public int Field023 = 23;
public int Field024 = 24;
public int Field025 = 25;
public int Field026 = 26;
public int Field027 = 27;
public int Field028 = 28;
public int Field029 = 29;
public int Field030 = 30;
public int Field031 = 31;
public int Field032 = 32;
public int Field033 = 33;
public int Field034 = 34;
public int Field035 = 35;
public int Field036 = 36;
public int Field037 = 37;
public int Field038 = 38;
public int Field039 = 39;
public int Field040 = 40;
public int Field041 = 41;
public int Field042 = 42;
public int Field043 = 43;
public int Field044 = 44;
public int Field045 = 45;
public int Field046 = 46;
public int Field047 = 47;
public int Field048 = 48;
public int Field049 = 49;
public int Field050 = 50;
public int Field051 = 51;
public int Field052 = 52;
public int Field053 = 53;
public int Field054 = 54;
public int Field055 = 55;
public int Field056 = 56;
public int Field057 = 57;
public int Field058 = 58;
public int Field059 = 59;
public int Field060 = 60;
public int Field061 = 61;
public int Field062 = 62;
public int Field063 = 63;
public int Field064 = 64;
public int Field065 = 65;
public int Field066 = 66;
public int Field067 = 67;
public int Field068 = 68;
public int Field069 = 69;
public int Field070 = 70;
public int Field071 = 71;
public int Field072 = 72;
public int Field073 = 73;
public int Field074 = 74;
public int Field075 = 75;
public int Field076 = 76;
public int Field077 = 77;
public int Field078 = 78;
public int Field079 = 79;
public int Field080 = 80;
public int Field081 = 81;
public int Field082 = 82;
public int Field083 = 83;
public int Field084 = 84;
public int Field085 = 85;
public int Field086 = 86;
public int Field087 = 87;
public int Field088 = 88;
public int Field089 = 89;
public int Field090 = 90;
public int Field091 = 91;
public int Field092 = 92;
public int Field093 = 93;
public int Field094 = 94;
public int Field095 = 95;
public int Field096 = 96;
public int Field097 = 97;
public int Field098 = 98;
public int Field099 = 99;
}
53 changes: 53 additions & 0 deletions test/OpenTelemetry.Tests.Stress.Logs/Program.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
// <copyright file="Program.cs" company="OpenTelemetry Authors">
// Copyright The OpenTelemetry Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// </copyright>

using System.Runtime.CompilerServices;
using Microsoft.Extensions.Logging;
using OpenTelemetry.Logs;

namespace OpenTelemetry.Tests.Stress;

public partial class Program
{
private static ILogger logger;
private static Payload payload = new Payload();

public static void Main()
{
using var loggerFactory = LoggerFactory.Create(builder =>
{
builder.AddOpenTelemetry(options =>
{
options.AddProcessor(new DummyProcessor());
});
});

logger = loggerFactory.CreateLogger<Program>();

Stress(prometheusPort: 9184);
}

[MethodImpl(MethodImplOptions.AggressiveInlining)]
protected static void Run()
{
logger.Log(
logLevel: LogLevel.Information,
eventId: 2,
state: payload,
exception: null,
formatter: (state, ex) => string.Empty);
}
}
14 changes: 14 additions & 0 deletions test/OpenTelemetry.Tests.Stress.Logs/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
# OpenTelemetry Stress Tests for Logs

This is Stress Test specifically for logging, and is
based on the [OpenTelemetry.Tests.Stress](../OpenTelemetry.Tests.Stress/README.md).

* [Running the stress test](#running-the-stress-test)

## Running the stress test

Open a console, run the following command from the current folder:

```sh
dotnet run --framework net6.0 --configuration Release
```

0 comments on commit 9232e56

Please sign in to comment.