blob: cb8a792888bb875ca14826093bb8c046e3711633 (
plain)
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
|
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Tango.BL.Enumerations;
using Tango.Telemetry.Destinations;
using Tango.Telemetry.Sources;
namespace Tango.Telemetry.Tester.IOT.CLI
{
class Program
{
static void Main(string[] args)
{
TelemetryPublisher publisher = new TelemetryPublisher(new TelemetryPublisherConfiguration()
{
Environment = "DEV",
SerialNumber = "dev-machine",
MachineType = MachineTypes.TS1800,
HistorySourcesRequestInterval = TimeSpan.FromSeconds(1),
EnableBackoff = false,
}, null);
(publisher.StorageManager as TelemetryLiteDBStorageManager).EnableCheckPointsRecovery = false;
publisher.RegisterSource(new JobRunsTestSource());
publisher.RegisterDestination(new TelemetryAzureHubDestination("HostName=iot-twine-dev-weu.azure-devices.net;DeviceId=telemetry-dev-01;SharedAccessKey=cZhCMhiVL+TF7p13fpX+lFmyxoy8ZqCkbxUwumWw18Q="));
publisher.PublishResultAvailable += Publisher_PublishResultAvailable;
publisher.Start().GetAwaiter().GetResult();
Console.Clear();
Console.WriteLine("=== Telemetry IoT Hub Test Utility ===");
Console.WriteLine($"Publisher started. Streaming every {publisher.Config.HistorySourcesRequestInterval.TotalSeconds} seconds.");
Console.WriteLine("Press any key to stop streaming data...");
Console.ReadKey();
Console.WriteLine("Disposing publisher...");
publisher.Dispose();
}
private static void Publisher_PublishResultAvailable(object sender, TelemetryPublishResultAvailableEventArgs e)
{
Console.ForegroundColor = ConsoleColor.DarkGray;
Console.WriteLine($"Package publish result available:\n{e.PublishResult.ToString()}");
if (e.PublishResult.DestinationsResults.Any(d => d.Status == TelemetryPublishResult.DestinationStatus.Failed))
{
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine("One or more destinations failed to receive the package.");
}
else
{
Console.ForegroundColor = ConsoleColor.Green;
Console.WriteLine("Package successfully published.");
}
Console.ResetColor();
Console.WriteLine("Press any key to stop streaming data...");
}
}
[TelemetryName("JobRun")]
public class JobRunTestTelemetry : TelemetryBase
{
public String JobName { get; set; }
public String Thread { get; set; }
public double Length { get; set; }
}
public class JobRunsTestSource : ITelemetryHistorySource
{
private int counter = 1;
public string Name { get; } = "Persons Source";
public bool RequiresTelemetryDuplicationTracking { get; } = false;
public Task<bool> CanRequestHistory(DateTime from)
{
return Task.FromResult(true);
}
public void Dispose()
{
}
public Task<IEnumerable<ITelemetry>> RequestHistory(DateTime from)
{
return Task.
FromResult<IEnumerable<ITelemetry>>(new List<JobRunTestTelemetry>()
{
new JobRunTestTelemetry()
{
Time = DateTime.UtcNow,
JobName = $"Job For Materialized {counter++}",
Length = 1000 + counter,
Thread = $"Coats Thread {counter}"
}
});
}
}
}
|