blob: ba90cc805fefc7c5d629b7b582dacfc278d56a0f (
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
|
using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Diagnostics;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Tango.BL;
using Tango.BL.Builders;
using Tango.BL.Entities;
using Tango.Core;
using Tango.Integration.Operation;
namespace Tango.JobRunsGenerator
{
class Program
{
static void Main(string[] args)
{
DataSource dataSource = new DataSource();
dataSource.Catalog = "Tango_DEV";
dataSource.Address = "twine.database.windows.net";
dataSource.IntegratedSecurity = false;
dataSource.UserName = "Roy";
dataSource.Password = "Aa123456";
using (ObservablesContext db = ObservablesContext.CreateDefault(dataSource))
{
var count = db.JobRuns.Where(x => x.JobGuid != null).Count();
int index = 0;
int saveIndex = 0;
var runsGroup = db.JobRuns.Where(x => x.JobGuid != null).GroupBy(x => x.JobGuid).ToList();
foreach (var runGroup in runsGroup)
{
var runs = runGroup;
var firstRun = runs.First();
var job = new JobBuilder(db).Set(x => x.Guid == firstRun.JobGuid).WithSegments().WithBrushStops().WithRML().Build();
if (job == null)
{
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine($"Job '{firstRun.JobGuid}' was not found on the database!");
Console.ForegroundColor = ConsoleColor.Gray;
continue;
}
var machine = new MachineBuilder(db).Set(job.MachineGuid).WithConfiguration().Build();
foreach (var segment in job.Segments)
{
foreach (var stop in segment.BrushStops)
{
stop.SetLiquidVolumes(machine.Configuration, job.Rml, job.Rml.GetActiveProcessGroup().ProcessParametersTables.First());
}
}
foreach (var run in runs)
{
Console.WriteLine($"Fixing job {job.Name}... ({index++}/{count})");
run.MachineGuid = job.MachineGuid;
run.JobSource = job.Source;
if (run.JobLength == 0) run.JobLength = job.LengthIncludingNumberOfUnits;
if (run.JobName == null) run.JobName = job.Name;
if (run.JobString == null) run.JobString = job.ToJobFileWhenLoaded().ToString();
if (run.LiquidQuantityString == null) run.LiquidQuantities = MachineOperator.CreateJobRunLiquidQuantities(job, machine.Configuration, job.Rml.GetActiveProcessGroup().ProcessParametersTables.First(), run.EndPosition, job.LengthIncludingNumberOfUnits, 20);
if (run.UserGuid != null) run.UserGuid = job.UserGuid;
if (run.UploadingStartDate == null) run.UploadingStartDate = run.StartDate;
if (run.HeatingStartDate == null) run.HeatingStartDate = run.StartDate;
if (run.ActualStartDate == null) run.ActualStartDate = run.StartDate;
run.IsGradient = job.Segments.Any(x => x.BrushStops.Count > 1);
saveIndex++;
if (saveIndex > 100)
{
saveIndex = 0;
Console.WriteLine("Saving changes...");
db.SaveChanges();
}
}
}
Console.WriteLine("Saving changes...");
db.SaveChanges();
Console.WriteLine("Done!");
Console.ReadLine();
}
}
}
}
|