-
Notifications
You must be signed in to change notification settings - Fork 9
Expand file tree
/
Copy pathRealTimeTestRunner.cs
More file actions
76 lines (65 loc) · 2.86 KB
/
RealTimeTestRunner.cs
File metadata and controls
76 lines (65 loc) · 2.86 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
using Oracle.ManagedDataAccess.Client;
using System;
using System.Data;
using System.IO;
using System.Xml.Serialization;
namespace utPLSQL
{
public class RealTimeTestRunner : TestRunner<@event>
{
private string id;
public override void RunTests(string type, string owner, string name, string subType)
{
string testsToRun = null;
if (type.Equals("USER"))
{
testsToRun = name;
}
else if (type.Equals("PACKAGE"))
{
testsToRun = $"{owner}.{name}";
}
else if (type.Equals("_ALL"))
{
testsToRun = owner;
}
if (testsToRun != null)
{
id = Guid.NewGuid().ToString().Replace("-", "");
string procedure = @"DECLARE
l_reporter ut_realtime_reporter := ut_realtime_reporter();
BEGIN
l_reporter.set_reporter_id(:id);
l_reporter.output_buffer.init();
ut_runner.run(a_paths => ut_varchar2_list(:test),
a_reporters => ut_reporters(l_reporter));
END;";
OracleCommand cmd = new OracleCommand(procedure, produceConnection);
cmd.Parameters.Add("id", OracleDbType.Varchar2, ParameterDirection.Input).Value = id;
cmd.Parameters.Add("test", OracleDbType.Varchar2, ParameterDirection.Input).Value = testsToRun;
cmd.ExecuteNonQuery();
}
}
public override void ConsumeResult(Action<@event> action)
{
string procedure = @"DECLARE
l_reporter ut_realtime_reporter := ut_realtime_reporter();
BEGIN
l_reporter.set_reporter_id(:id);
:lines_cursor := l_reporter.get_lines_cursor();
END;";
OracleCommand cmd = new OracleCommand(procedure, consumeConnection);
cmd.Parameters.Add("id", OracleDbType.Varchar2, ParameterDirection.Input).Value = id;
cmd.Parameters.Add("lines_cursor", OracleDbType.RefCursor, ParameterDirection.Output);
OracleDataReader reader = cmd.ExecuteReader();
while (reader.Read())
{
string xml = reader.GetString(0);
var serializer = new XmlSerializer(typeof(@event));
var @event = (@event)serializer.Deserialize(new StringReader(xml));
action.Invoke(@event);
}
reader.Close();
}
}
}