forked from yevhen/Streamstone
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathS09_Handling_duplicates.cs
33 lines (29 loc) · 1.17 KB
/
S09_Handling_duplicates.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
using System;
using System.Threading.Tasks;
using Streamstone;
namespace Example.Scenarios
{
public class S09_Handling_duplicates : Scenario
{
public override async Task RunAsync()
{
var result = await Stream.WriteAsync(new Stream(Partition), default, new EventData(EventId.From("42")));
try
{
var events = new[]
{
new EventData(EventId.From("56")),
new EventData(EventId.From("42")) // conflicting (duplicate) event
};
await Stream.WriteAsync(result.Stream, default, events);
}
catch (DuplicateEventException e)
{
Console.WriteLine("Duplicate event detection is based on ID of the event.");
Console.WriteLine("An ID of conflicting event will be reported back as a property of DuplicateEventException.");
Console.WriteLine("Here the conflicting event is: {0}", e.Id);
Console.WriteLine("The caller can use this information to remove conflicting event from the batch and retry (or cancel)");
}
}
}
}