aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Tango.Telemetry/Sources
diff options
context:
space:
mode:
authorRoy Ben Shabat <Roy.mail.net@gmail.com>2025-08-04 01:09:55 +0300
committerRoy Ben Shabat <Roy.mail.net@gmail.com>2025-08-04 01:09:55 +0300
commit8bbeffb422e8535c399f1eb76a55fdee5a1c65b6 (patch)
treef200faa0e11c23f9105c3f12e0a6a2ea51832214 /Software/Visual_Studio/Tango.Telemetry/Sources
parent0df9f37075dd697ac34f4ed2a2749f62aa27a654 (diff)
downloadTango-8bbeffb422e8535c399f1eb76a55fdee5a1c65b6.tar.gz
Tango-8bbeffb422e8535c399f1eb76a55fdee5a1c65b6.zip
Telemetry JobRuns.
Diffstat (limited to 'Software/Visual_Studio/Tango.Telemetry/Sources')
-rw-r--r--Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryDiagnosticsSource.cs14
-rw-r--r--Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsHistorySource.cs29
-rw-r--r--Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsStreamingSource.cs63
3 files changed, 88 insertions, 18 deletions
diff --git a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryDiagnosticsSource.cs b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryDiagnosticsSource.cs
index 5a2735131..37a8d224d 100644
--- a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryDiagnosticsSource.cs
+++ b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryDiagnosticsSource.cs
@@ -19,7 +19,6 @@ namespace Tango.Telemetry.Sources
public const int MIN_SAMPLING_INTERVAL_SECONDS = 1;
private IMachineOperator _machineOperator;
- private bool _isStarted;
private Timer _diagnosticsSamplingTimer;
private List<StartDiagnosticsResponse> _diagnosticsQueue;
@@ -31,6 +30,7 @@ namespace Tango.Telemetry.Sources
public string Name { get; private set; } = "Diagnostics";
public bool RequiresTelemetryDuplicationTracking { get => false; }
+ public bool IsStarted { get; private set; }
private TelemetryDiagnosticsSource() : base()
{
@@ -45,7 +45,7 @@ namespace Tango.Telemetry.Sources
private void DiagnosticsDataAvailable(object sender, StartDiagnosticsResponse diagnostics)
{
- if (_isStarted && diagnostics.Monitors != null)
+ if (IsStarted && diagnostics.Monitors != null)
{
_diagnosticsQueue.Add(diagnostics);
}
@@ -53,7 +53,7 @@ namespace Tango.Telemetry.Sources
public void Start()
{
- _isStarted = true;
+ IsStarted = true;
if (Config.DiagnosticsSamplingInterval.TotalSeconds < MIN_SAMPLING_INTERVAL_SECONDS)
{
@@ -76,12 +76,12 @@ namespace Tango.Telemetry.Sources
public void Stop()
{
- _isStarted = false;
+ IsStarted = false;
}
private void DiagnosticsSamplingTimer_Elapsed(object sender, ElapsedEventArgs e)
{
- if (!_isStarted || _writing) return;
+ if (!IsStarted || _writing) return;
try
{
@@ -103,7 +103,7 @@ namespace Tango.Telemetry.Sources
frame.Time = DateTime.UtcNow.Subtract(Config.DiagnosticsSamplingInterval);
- TelemetryAvailable?.Invoke(this, new TelemetryAvailableEventArgs(frame, TelemetrySourceTypes.Streaming));
+ TelemetryAvailable?.Invoke(this, new TelemetryAvailableEventArgs() { TelemetryObject = frame });
}
else
{
@@ -112,7 +112,7 @@ namespace Tango.Telemetry.Sources
TelemetryDiagnosticsFrame frame = new TelemetryDiagnosticsFrame();
frame.Monitors = new InsightsMonitors();
frame.Time = DateTime.UtcNow.Subtract(Config.DiagnosticsSamplingInterval);
- TelemetryAvailable?.Invoke(this, new TelemetryAvailableEventArgs(frame, TelemetrySourceTypes.Streaming));
+ TelemetryAvailable?.Invoke(this, new TelemetryAvailableEventArgs() { TelemetryObject = frame });
_emptyWritten = true;
}
}
diff --git a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsHistorySource.cs b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsHistorySource.cs
index e3934d832..b13402831 100644
--- a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsHistorySource.cs
+++ b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsHistorySource.cs
@@ -5,6 +5,7 @@ using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Tango.BL;
+using Tango.Telemetry.Mappers;
using Tango.Telemetry.Telemetries;
namespace Tango.Telemetry.Sources
@@ -13,13 +14,23 @@ namespace Tango.Telemetry.Sources
{
private bool _isBusy;
- public string Name { get; private set; } = "JobRuns History";
-
+ public string Name { get;} = "JobRuns History";
public bool RequiresTelemetryDuplicationTracking { get => true; }
+ public TelemetryHistorySourceDirection Direction { get => TelemetryHistorySourceDirection.Descending; }
- public Task<bool> CanRequestHistory(DateTime from)
+ public async Task<bool> CanRequestHistory(DateTime from)
{
- return Task.FromResult(!_isBusy);
+ if (_isBusy)
+ {
+ return false;
+ }
+ else
+ {
+ using (ObservablesContext db = ObservablesContext.CreateDefault())
+ {
+ return await db.JobRuns.CountAsync(x => x.LastUpdated < from) > 0;
+ }
+ }
}
public async Task<IEnumerable<ITelemetry>> RequestHistory(DateTime from)
@@ -31,8 +42,8 @@ namespace Tango.Telemetry.Sources
using (ObservablesContext db = ObservablesContext.CreateDefault())
{
var runs = await db.JobRuns
- .Where(x => x.LastUpdated > from)
- .OrderBy(x => x.LastUpdated)
+ .OrderByDescending(x => x.LastUpdated)
+ .Where(x => x.LastUpdated < from)
.Take(Config.MaxJobRunsPerRequest)
.ToListAsync();
@@ -40,11 +51,7 @@ namespace Tango.Telemetry.Sources
foreach (var run in runs)
{
- TelemetryJobRun tRun = new TelemetryJobRun();
- tRun.ID = run.Guid;
- tRun.Time = run.LastUpdated;
- tRun.Name = run.JobName;
- //Fill the object..
+ var tRun = JobRunMapper.MapJobRun(run);
tRuns.Add(tRun);
}
diff --git a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsStreamingSource.cs b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsStreamingSource.cs
new file mode 100644
index 000000000..b3199eb36
--- /dev/null
+++ b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsStreamingSource.cs
@@ -0,0 +1,63 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using Tango.Core;
+using Tango.Integration.Operation;
+using Tango.Telemetry.Mappers;
+
+namespace Tango.Telemetry.Sources
+{
+ public class TelemetryJobRunsStreamingSource : ExtendedObject, ITelemetryStreamingSource
+ {
+ private IMachineOperator _machineOperator;
+
+ public string Name { get; } = "JobRuns Streaming";
+
+ public bool RequiresTelemetryDuplicationTracking { get; } = true;
+ public bool IsStarted { get; private set; }
+
+ public event EventHandler<TelemetryAvailableEventArgs> TelemetryAvailable;
+
+ public TelemetryJobRunsStreamingSource(IMachineOperator machineOperator)
+ {
+ _machineOperator = machineOperator;
+ }
+
+ private void JobRunsLogger_JobRunAvailable(object sender, Integration.JobRuns.JobRunAvailableEventArgs e)
+ {
+ Task.Factory.StartNew(() =>
+ {
+ if (IsStarted)
+ {
+ var tRun = JobRunMapper.MapJobRun(e.JobRun);
+ TelemetryAvailable?.Invoke(this, new TelemetryAvailableEventArgs() { TelemetryObject = tRun });
+ }
+ });
+ }
+
+ public void Dispose()
+ {
+ Stop();
+ }
+
+ public void Start()
+ {
+ if (!IsStarted)
+ {
+ _machineOperator.JobRunsLogger.JobRunAvailable += JobRunsLogger_JobRunAvailable;
+ IsStarted = true;
+ }
+ }
+
+ public void Stop()
+ {
+ if (IsStarted)
+ {
+ _machineOperator.JobRunsLogger.JobRunAvailable -= JobRunsLogger_JobRunAvailable;
+ IsStarted = false;
+ }
+ }
+ }
+}