mirror of https://github.com/Squidex/squidex.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
70 lines
2.4 KiB
70 lines
2.4 KiB
// ==========================================================================
|
|
// HandleEventsWithManyWriters.cs
|
|
// Squidex Headless CMS
|
|
// ==========================================================================
|
|
// Copyright (c) Squidex Group
|
|
// All rights reserved.
|
|
// ==========================================================================
|
|
|
|
using System;
|
|
using System.Threading.Tasks;
|
|
using Benchmarks.Tests.TestData;
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
using Squidex.Infrastructure.CQRS.Events;
|
|
using Squidex.Infrastructure.CQRS.Events.Actors;
|
|
using Squidex.Infrastructure.States;
|
|
|
|
namespace Benchmarks.Tests
|
|
{
|
|
public sealed class HandleEventsWithManyWriters : Benchmark
|
|
{
|
|
private const int NumCommits = 200;
|
|
private const int NumStreams = 10;
|
|
private IServiceProvider services;
|
|
private IEventStore eventStore;
|
|
private EventConsumerActor eventConsumerActor;
|
|
private EventDataFormatter eventDataFormatter;
|
|
private MyEventConsumer eventConsumer;
|
|
|
|
public override void RunInitialize()
|
|
{
|
|
services = Services.Create();
|
|
|
|
eventConsumer = new MyEventConsumer(NumStreams * NumCommits);
|
|
|
|
eventStore = services.GetRequiredService<IEventStore>();
|
|
|
|
eventDataFormatter = services.GetRequiredService<EventDataFormatter>();
|
|
eventConsumerActor = services.GetRequiredService<EventConsumerActor>();
|
|
|
|
eventConsumerActor.ActivateAsync(services.GetRequiredService<StateHolder<EventConsumerState>>()).Wait();
|
|
eventConsumerActor.Activate(eventConsumer);
|
|
}
|
|
|
|
public override long Run()
|
|
{
|
|
Parallel.For(0, NumStreams, streamId =>
|
|
{
|
|
var eventOffset = -1;
|
|
var streamName = streamId.ToString();
|
|
|
|
for (var commitId = 0; commitId < NumCommits; commitId++)
|
|
{
|
|
var eventData = eventDataFormatter.ToEventData(new Envelope<IEvent>(new MyEvent()), Guid.NewGuid());
|
|
|
|
eventStore.AppendEventsAsync(Guid.NewGuid(), streamName, eventOffset - 1, new[] { eventData }).Wait();
|
|
eventOffset++;
|
|
}
|
|
});
|
|
|
|
eventConsumer.WaitAndVerify();
|
|
|
|
return NumStreams * NumCommits;
|
|
}
|
|
|
|
public override void RunCleanup()
|
|
{
|
|
services.Cleanup();
|
|
}
|
|
}
|
|
}
|
|
|