-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSparseTableTest.cs
More file actions
156 lines (126 loc) · 5.3 KB
/
SparseTableTest.cs
File metadata and controls
156 lines (126 loc) · 5.3 KB
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
using System;
using System.IO;
using System.Text;
using CpForCompetitiveProgrammingSparseTable;
using Microsoft.VisualStudio.TestTools.UnitTesting;
namespace UnitTestSparseTableTest
{
class Settings
{
public bool ShowAll { get; set; }
public bool OnlyFailed { get; set; }
public bool OnlyPassed { get; set; }
public long IterationCount { get; set; }
public long SubIterationCount { get; set; }
public int MinRandom { get; set; }
public int MaxRandom { get; set; }
}
[TestClass]
public class UnitTestForSparseTableTest
{
private readonly Settings _settings = new Settings
{
ShowAll = false,
OnlyFailed = true,
OnlyPassed = false,
IterationCount = 100,
SubIterationCount = 100,
MinRandom = -100,
MaxRandom = 100
};
private int _totalTestCase;
private int _passed;
private int _falied;
[TestMethod]
public void Test()
{
StringBuilder sb = new StringBuilder();
sb.Append(Environment.NewLine);
sb.Append(Environment.NewLine);
Random random = new Random(9997);
for (int k = 0; k < _settings.IterationCount; ++k)
{
int n = random.Next(1, 1000);
int[] array = new int[n];
for (int j = 0; j < n; j++)
{
var next = random.Next(_settings.MinRandom, _settings.MaxRandom);
array[j] = next;
}
var table = SparseTable.BuildSparseTable(array);
for (int i = 0; i < _settings.SubIterationCount; i++)
{
try
{
++_totalTestCase;
var ka = random.Next(0, n);
var kb = random.Next(0, n);
var a = Math.Min(ka, kb);
var b = Math.Max(ka, kb);
//TEST CASE RUN
var got = SparseTable.Solve(a, b, table);
int expected = SparseTable.SolveBf(array, a, b);
try
{
Assert.AreEqual(expected, got);
++_passed;
if (_settings.ShowAll || _settings.OnlyPassed)
{
sb.Append(Environment.NewLine);
sb.Append($"NEW TEST CASE: N = {n} ,A = {a},B = {b}");
sb.Append(Environment.NewLine);
sb.Append("MESSAGE");
sb.Append(Environment.NewLine);
foreach (var wval in array)
{
sb.Append(wval + " ");
}
sb.Append(Environment.NewLine);
sb.Append(Environment.NewLine);
sb.Append($"got : {got} vs expected: {expected}");
sb.Append($" --> PASSED TEST CASE");
sb.Append(Environment.NewLine);
}
}
catch (Exception e)
{
++_falied;
sb.Append(Environment.NewLine);
sb.Append($"NEW TEST CASE: N = {n} ,A = {a},B = {b}");
sb.Append(Environment.NewLine);
sb.Append("MESSAGE");
sb.Append(Environment.NewLine);
foreach (var wval in array)
{
sb.Append(wval + " ");
}
sb.Append(Environment.NewLine);
sb.Append(Environment.NewLine);
sb.Append($"got : {got} vs expected: {expected}");
sb.Append($" --> Failed TEST CASE");
sb.Append(Environment.NewLine);
}
}
catch (Exception exception)
{
++_falied;
sb.Append(Environment.NewLine);
sb.Append($"NEW TEST CASE: N = {n}");
sb.Append(Environment.NewLine);
sb.Append("MESSAGE");
sb.Append(Environment.NewLine);
foreach (var wval in array)
{
sb.Append(wval + " ");
}
sb.Append(Environment.NewLine);
sb.Append($" --> Exception in TEST CASE : Exception : {exception.Message}, {exception.StackTrace}");
sb.Append(Environment.NewLine);
}
}
}
sb.Insert(0, $"Total Test cases run = {_totalTestCase}, Passed = {_passed}, Failed = {_falied}");
File.WriteAllText("unit-test-input.txt", sb.ToString());
}
}
}