-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathGenerator.cs
96 lines (79 loc) · 2.74 KB
/
Generator.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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
using BenchmarkLogGenerator.Data;
using BenchmarkLogGenerator.Flows;
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
namespace BenchmarkLogGenerator
{
using Step = Scheduler.Step;
using Event = Scheduler.Event;
public static class Gen
{
public static void TraceInfo(string node, string level, string component, string cid, string message, string properties)
{
/* - TODO check if we need to generate the strings as invariant format */
var gen = Generator.Current;
var now = gen.Now;
Generator.Current.LogWriter.Write(
now,
Generator.Current.Source,
node,
level,
component,
cid,
message,
properties);
}
public static void CloseTracer()
{
Generator.Current.LogWriter.Close();
}
public static Step Sleep(TimeSpan duration)
{
return Generator.Current.Scheduler.DelayFlow(duration);
}
public static Event Spawn(IEnumerable<Step> steps)
{
return Generator.Current.Scheduler.ScheduleNewFlow(steps);
}
}
public sealed class Generator
{
public Scheduler Scheduler { get; private set; }
public int Seed { get; set; }
public int SessionCount { get; set; }
public Random Rng { get; private set; }
public LogWriter LogWriter { get; private set; }
public string Source;
public DateTime Now
{
get { return Scheduler.Now; }
}
[ThreadStatic] static Generator s_current;
public static Generator Current => s_current;
public static void Run(int index, LogWriter writer, int logsPerSessionFactor, int numSessionsFactor)
{
var gen = new Generator(index, writer);
gen.SetOnThread();
Gen.Spawn(IngestionFlow.Generate(index, logsPerSessionFactor, numSessionsFactor, gen.Source));
gen.Scheduler.Run();
Gen.CloseTracer();
}
public Generator(int seed, LogWriter writer)
{
Scheduler = new Scheduler(new DateTime(2014, 3, 8, 0, 0, 0, DateTimeKind.Utc));
Rng = new Random(5546548 + seed % 100);
Seed = seed;
Source = Names.Sources[seed % 1610] + seed;
LogWriter = writer;
LogWriter.Source = Source;
}
private void SetOnThread()
{
s_current = this;
}
}
}