Dual write PDSF for Metrology Viewer
Version Error Message Tests passed mesfs.infineon.com Infineon.EAF.Runtime 2.49.3 pool name Kanban net8.0 v2_52_0-Tests editorconfig yml ec fix yml explicit contents dotnet_diagnostic Removed Open Insight API IFX Directory Removed Open Insight API IFX Directory from Save CA1862 and GetWeekOfYear for WritePDSF gitignore cellInstanceVersion.EdaConnection.PortNumber Removed Open Insight API IFX Directory from Save Added Climatec to Test.cs GetJobIdDirectory Remove and 5-Other-Small NETFRAMEWORK mesfs.infineon.com Infineon.EAF.Runtime 2.49.3 pool name Kanban
This commit is contained in:
		| @ -6,6 +6,7 @@ using Adaptation.Shared.Methods; | ||||
| using Adaptation.Shared.Metrology; | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Collections.ObjectModel; | ||||
| using System.Globalization; | ||||
| using System.IO; | ||||
| using System.Linq; | ||||
| @ -17,28 +18,33 @@ namespace Adaptation.FileHandlers.OpenInsight; | ||||
| public class FileRead : Shared.FileRead, IFileRead | ||||
| { | ||||
|  | ||||
|     private int _LastIndex; | ||||
|     private readonly string _IqsConnectionString; | ||||
|     private readonly string _OpenInsightFilePattern; | ||||
|     private readonly string _OpenInsightApiECDirectory; | ||||
|     private readonly string _OpenInsightApiIFXDirectory; | ||||
|     private readonly string _OpenInsightMetrologyViewerAPI; | ||||
|     private readonly string _OpenInsightMetrologyViewerFileShare; | ||||
|     private readonly ReadOnlyCollection<ModelObjectParameterDefinition> _IQSCopyCollection; | ||||
|  | ||||
|     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<string>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : | ||||
|         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) | ||||
|     { | ||||
|         _LastIndex = -1; | ||||
|         _MinFileLength = 10; | ||||
|         _NullData = string.Empty; | ||||
|         _Logistics = new(this); | ||||
|         _NullData = string.Empty; | ||||
|         if (_FileParameter is null) | ||||
|             throw new Exception(cellInstanceConnectionName); | ||||
|         if (_ModelObjectParameterDefinitions is null) | ||||
|             throw new Exception(cellInstanceConnectionName); | ||||
|         if (!_IsDuplicator) | ||||
|             throw new Exception(cellInstanceConnectionName); | ||||
|         _IQSCopyCollection = new(GetProperties(cellInstanceConnectionName, modelObjectParameters, "IQS.Copy.")); | ||||
|         _IqsConnectionString = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "IQS.ConnectionString"); | ||||
|         _OpenInsightApiECDirectory = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "API.EC.Directory"); | ||||
|         _OpenInsightApiIFXDirectory = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "API.IFX.Directory"); | ||||
|         _OpenInsightFilePattern = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "OpenInsight.FilePattern"); | ||||
|         _OpenInsightApiIFXDirectory = _OpenInsightApiIFXDirectory.Replace("\"", string.Empty); | ||||
|         _OpenInsightMetrologyViewerAPI = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "OpenInsight.MetrologyViewerAPI"); | ||||
|         _OpenInsightMetrologyViewerFileShare = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "OpenInsight.MetrologyViewerFileShare"); | ||||
|     } | ||||
|  | ||||
|     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) | ||||
| @ -149,13 +155,17 @@ public class FileRead : Shared.FileRead, IFileRead | ||||
|                 _ = Directory.CreateDirectory(duplicateDirectory); | ||||
|         } | ||||
|         string duplicateFile = Path.Combine(duplicateDirectory, Path.GetFileName(reportFullPath)); | ||||
|         if (descriptions.Any() && tests.Any()) | ||||
|         if (descriptions.Count != 0 && tests.Length != 0) | ||||
|         { | ||||
|             string lines = GetLines(_Logistics, descriptions); | ||||
|             if (!string.IsNullOrEmpty(lines)) | ||||
|             { | ||||
|                 _LastIndex += 1; | ||||
|                 long? subGroupId; | ||||
|                 if (_LastIndex >= _IQSCopyCollection.Count) | ||||
|                     _LastIndex = 0; | ||||
|                 long breakAfter = dateTime.AddSeconds(_BreakAfterSeconds).Ticks; | ||||
|                 ModelObjectParameterDefinition modelObjectParameterDefinition = _IQSCopyCollection[_LastIndex]; | ||||
|                 long preWait = _FileConnectorConfiguration?.FileHandleWaitTime is null ? dateTime.AddMilliseconds(1234).Ticks : dateTime.AddMilliseconds(_FileConnectorConfiguration.FileHandleWaitTime.Value).Ticks; | ||||
|                 if (string.IsNullOrEmpty(descriptions[0].Reactor) || string.IsNullOrEmpty(descriptions[0].PSN)) | ||||
|                     subGroupId = null; | ||||
| @ -165,8 +175,24 @@ public class FileRead : Shared.FileRead, IFileRead | ||||
|                     collection.Add(new(new ScopeInfo(tests[0], _OpenInsightFilePattern), lines)); | ||||
|                 else | ||||
|                     collection.Add(new(new ScopeInfo(tests[0], $"{subGroupId.Value} {_OpenInsightFilePattern}"), lines)); | ||||
|                 if (_StaticRuns.TryGetValue(_Logistics.Sequence, out List<string> values)) | ||||
|                 { | ||||
|                     if (values.Count != 1) | ||||
|                         throw new Exception($"{nameof(_StaticRuns)} {values.Count} != 1 {_Logistics.Sequence}!"); | ||||
|                     values[0] = $"{values[0]}|{subGroupId}"; | ||||
|                 } | ||||
|                 string weekOfYear = _Calendar.GetWeekOfYear(_Logistics.DateTimeFromSequence, CalendarWeekRule.FirstDay, DayOfWeek.Sunday).ToString("00"); | ||||
|                 FromIQS.Save(_OpenInsightApiECDirectory, _OpenInsightApiIFXDirectory, _Logistics, reportFullPath, logistics, descriptions.First(), lines, subGroupId, weekOfYear); | ||||
|                 FromIQS.Save(_OpenInsightApiECDirectory, _Logistics, reportFullPath, logistics, descriptions.First(), lines, subGroupId, weekOfYear); | ||||
|                 try | ||||
|                 { FromIQS.SaveCopy(_FileConnectorConfiguration.SourceFileLocation, _IqsConnectionString, modelObjectParameterDefinition.Name, modelObjectParameterDefinition.Value.Split('|')); } | ||||
|                 catch (Exception exception) | ||||
|                 { | ||||
|                     string subject = string.Concat("Exception:", _CellInstanceConnectionName); | ||||
|                     string body = string.Concat(exception.Message, Environment.NewLine, Environment.NewLine, exception.StackTrace); | ||||
|                     try | ||||
|                     { _SMTP.SendHighPriorityEmailMessage(subject, body); } | ||||
|                     catch (Exception) { } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) | ||||
|  | ||||
| @ -17,7 +17,7 @@ public class FromIQS | ||||
| #nullable enable | ||||
|  | ||||
|     private static string GetCommandText(Logistics logistics, SECS.Description description, string dateTime, long? subGroupId) | ||||
|     { | ||||
|     { // cSpell:disable | ||||
|         StringBuilder result = new(); | ||||
|         _ = result | ||||
|                 .AppendLine(" select iq.ev_count, iq.cl_count, iq.sl_count, iq.se_sgrp, iq.se_sgtm, iq.se_tsno, iq.td_test, iq.pr_name, iq.jd_name, iq.pl_name, iq.pd_name, iq.td_name, iq.se_val ") | ||||
| @ -58,7 +58,7 @@ public class FromIQS | ||||
|                 .AppendLine("   on se.f_lot = pl.f_lot ") | ||||
|                 .AppendLine(" join [spcepiworld].[dbo].[part_dat] pd ") | ||||
|                 .AppendLine("   on se.f_part = pd.f_part ") | ||||
|                 .AppendLine(" join [spcepiworld].[dbo].[test_dat] td  ") | ||||
|                 .AppendLine(" join [spcepiworld].[dbo].[test_dat] td ") | ||||
|                 .AppendLine("   on se.f_test = td.f_test ") | ||||
|                 .AppendLine(" where se.f_flag = 0 "); | ||||
|         if (subGroupId is not null) | ||||
| @ -75,7 +75,7 @@ public class FromIQS | ||||
|                 .AppendLine(" order by iq.ev_count desc, iq.cl_count desc, iq.sl_count desc, iq.se_sgrp, iq.se_tsno, iq.td_test ") | ||||
|                 .AppendLine("   for json path "); | ||||
|         return result.ToString(); | ||||
|     } | ||||
|     } // cSpell:restore | ||||
|  | ||||
|     private static StringBuilder GetForJsonPath(string connectionString, string commandText) | ||||
|     { | ||||
| @ -135,17 +135,17 @@ public class FromIQS | ||||
|         else | ||||
|         { | ||||
|             JsonElement[]? jsonElements = JsonSerializer.Deserialize<JsonElement[]>(stringBuilder.ToString()); | ||||
|             if (jsonElements is null || !jsonElements.Any() || jsonElements[0].ValueKind != JsonValueKind.Object) | ||||
|             if (jsonElements is null || jsonElements.Length == 0 || jsonElements[0].ValueKind != JsonValueKind.Object) | ||||
|                 commandText = stringBuilder.ToString(); | ||||
|             else | ||||
|             { | ||||
|                 JsonProperty[] jsonProperties = jsonElements[0].EnumerateObject().ToArray(); | ||||
|                 if (!jsonProperties.Any() || jsonProperties[3].Name != "se_sgrp" || !long.TryParse(jsonProperties[3].Value.ToString(), out long subGroupId)) | ||||
|                 if (jsonProperties.Length == 0 || jsonProperties[3].Name != "se_sgrp" || !long.TryParse(jsonProperties[3].Value.ToString(), out long subGroupId)) | ||||
|                     commandText = stringBuilder.ToString(); | ||||
|                 else | ||||
|                 { | ||||
|                     result = subGroupId; | ||||
|                     if (jsonProperties.Any() && jsonProperties[0].Name == "ev_count" && int.TryParse(jsonProperties[0].Value.ToString(), out int evCount)) | ||||
|                     if (jsonProperties.Length != 0 && jsonProperties[0].Name == "ev_count" && int.TryParse(jsonProperties[0].Value.ToString(), out int evCount)) | ||||
|                         count = evCount; | ||||
|                 } | ||||
|             } | ||||
| @ -204,40 +204,119 @@ public class FromIQS | ||||
|         return result; | ||||
|     } | ||||
|  | ||||
|     internal static void Save(string openInsightApiECDirectory, string openInsightApiIFXDirectory, Logistics logistics, string reportFullPath, string logisticLines, SECS.Description description, string lines, long? subGroupId, string weekOfYear) | ||||
|     internal static void Save(string openInsightApiECDirectory, Logistics logistics, string reportFullPath, string logisticLines, SECS.Description description, string lines, long? subGroupId, string weekOfYear) | ||||
|     { | ||||
|         string checkFile; | ||||
|         string fileName = Path.GetFileName(reportFullPath); | ||||
|         string json = GetJson(logistics, logisticLines, description); | ||||
|         string? ecPathRoot = Path.GetPathRoot(openInsightApiECDirectory); | ||||
|         string? ifxPathRoot = Path.GetPathRoot(openInsightApiIFXDirectory); | ||||
|         bool ecExists = ecPathRoot is not null && Directory.Exists(ecPathRoot); | ||||
|         bool ifxExists = ifxPathRoot is not null && Directory.Exists(ifxPathRoot); | ||||
|         string weekYear = $"{logistics.DateTimeFromSequence:yyyy}_Week_{weekOfYear}"; | ||||
|         string ecDirectory = Path.Combine(openInsightApiECDirectory, weekYear, $"-{description.PSN}", $"-{description.Reactor}", $"-{description.RDS}", $"-{subGroupId}"); | ||||
|         string ifxDirectory = Path.Combine(openInsightApiIFXDirectory, weekYear, $"-{description.PSN}", $"-{description.Reactor}", $"-{description.RDS}", $"-{subGroupId}"); | ||||
|         if (ecExists && !Directory.Exists(ecDirectory)) | ||||
|             _ = Directory.CreateDirectory(ecDirectory); | ||||
|         if (ifxExists && !Directory.Exists(ifxDirectory)) | ||||
|             _ = Directory.CreateDirectory(ifxDirectory); | ||||
|         checkFile = Path.Combine(ecDirectory, fileName); | ||||
|         if (ecExists && !File.Exists(checkFile)) | ||||
|             File.Copy(reportFullPath, checkFile); | ||||
|         checkFile = Path.Combine(ifxDirectory, fileName); | ||||
|         if (ifxExists && !File.Exists(checkFile)) | ||||
|             File.Copy(reportFullPath, checkFile); | ||||
|         checkFile = Path.Combine(ecDirectory, $"{logistics.DateTimeFromSequence.Ticks}.txt"); | ||||
|         if (ecExists && !File.Exists(checkFile)) | ||||
|             File.WriteAllText(checkFile, lines); | ||||
|         checkFile = Path.Combine(ifxDirectory, $"{logistics.DateTimeFromSequence.Ticks}.txt"); | ||||
|         if (ifxExists && !File.Exists(checkFile)) | ||||
|             File.WriteAllText(checkFile, lines); | ||||
|         checkFile = Path.Combine(ecDirectory, $"{logistics.DateTimeFromSequence.Ticks}.json"); | ||||
|         if (ecExists && !File.Exists(checkFile)) | ||||
|             File.WriteAllText(checkFile, json); | ||||
|         checkFile = Path.Combine(ifxDirectory, $"{logistics.DateTimeFromSequence.Ticks}.json"); | ||||
|         if (ifxExists && !File.Exists(checkFile)) | ||||
|             File.WriteAllText(checkFile, json); | ||||
|     } | ||||
|  | ||||
|     private static string GetCommandText(string[] iqsCopyValues) | ||||
|     { // cSpell:disable | ||||
|         StringBuilder result = new(); | ||||
|         if (iqsCopyValues.Length != 4) | ||||
|             throw new NotSupportedException(); | ||||
|         string find = iqsCopyValues[1]; | ||||
|         string replace = iqsCopyValues[3]; | ||||
|         _ = result | ||||
|             .AppendLine(" select pd.f_name [Part Name], ") | ||||
|             .AppendLine("        null [Part Revision], ") | ||||
|             .Append(" '").Append(replace).AppendLine("' [Test Name], ") | ||||
|             .AppendLine("        null [Description], ") | ||||
|             .AppendLine("        null [Lot Number], ") | ||||
|             .AppendLine("        null [Job Name], ") | ||||
|             .AppendLine("        null [Process Name], ") | ||||
|             .AppendLine("        case when sl.f_url = 0 then null else sl.f_url end [Reasonable Limit (Upper)], ") | ||||
|             .AppendLine("        case when sl.f_url = 0 then 0 else 1 end [Alarm Reasonable Limit (Upper)], ") | ||||
|             .AppendLine("        case when sl.f_usl = 0 then null else sl.f_usl end [Specification Limit (Upper)], ") | ||||
|             .AppendLine("        case when sl.f_usl = 0 then 0 else 1 end [Alarm Specification Limit (Upper)], ") | ||||
|             .AppendLine("        case when sl.f_ugb = 0 then null else sl.f_ugb end [Warning Limit (Upper)], ") | ||||
|             .AppendLine("        case when sl.f_ugb = 0 then 0 else 1 end [Alarm Warning Limit (Upper)], ") | ||||
|             .AppendLine("        case when sl.f_tar = 0 then null else sl.f_tar end [Specification Limit (Target)], ") | ||||
|             .AppendLine("        case when sl.f_lgb = 0 then null else sl.f_lgb end [Warning Limit (Lower)], ") | ||||
|             .AppendLine("        case when sl.f_lgb = 0 then 0 else 1 end [Alarm Warning Limit (Lower)], ") | ||||
|             .AppendLine("        case when sl.f_lsl = 0 then null else sl.f_lsl end [Specification Limit (Lower)], ") | ||||
|             .AppendLine("        case when sl.f_lsl = 0 then 0 else 1 end [Alarm Specification Limit (Lower)], ") | ||||
|             .AppendLine("        case when sl.f_lrl = 0 then null else sl.f_lrl end [Reasonable Limit (Lower)], ") | ||||
|             .AppendLine("        case when sl.f_lrl = 0 then 0 else 1 end [Alarm Reasonable Limit (Lower)], ") | ||||
|             .AppendLine("        td.f_name [Original Test Name], ") | ||||
|             .AppendLine("        td.f_test [Test Id], ") | ||||
|             .AppendLine("        ( ") | ||||
|             .AppendLine("          select count(sl_b.f_spec) ") | ||||
|             .AppendLine("          from [spcepiworld].[dbo].[spec_lim] sl_b ") | ||||
|             .AppendLine("          join [spcepiworld].[dbo].[part_dat] pd_b ") | ||||
|             .AppendLine("          on sl_b.f_part = pd_b.f_part ") | ||||
|             .AppendLine("          join [spcepiworld].[dbo].[test_dat] td_b ") | ||||
|             .AppendLine("          on sl_b.f_test = td_b.f_test ") | ||||
|             .AppendLine("          where sl_b.f_prcs = 0 ") | ||||
|             .Append(" and td_b.f_name = '").Append(replace).AppendLine("' ") | ||||
|             .AppendLine("          and pd_b.f_name = pd.f_name ") | ||||
|             .AppendLine("          and sl_b.f_url = sl.f_url ") | ||||
|             .AppendLine("          and sl_b.f_usl = sl.f_usl ") | ||||
|             .AppendLine("          and sl_b.f_ugb = sl.f_ugb ") | ||||
|             .AppendLine("          and sl_b.f_tar = sl.f_tar ") | ||||
|             .AppendLine("          and sl_b.f_lgb = sl.f_lgb ") | ||||
|             .AppendLine("          and sl_b.f_lsl = sl.f_lsl ") | ||||
|             .AppendLine("          and sl_b.f_lrl = sl.f_lrl ") | ||||
|             .AppendLine("          group by sl_b.f_spec ") | ||||
|             .AppendLine("        ) count ") | ||||
|             .AppendLine(" from [spcepiworld].[dbo].[spec_lim] sl ") | ||||
|             .AppendLine(" join [spcepiworld].[dbo].[part_dat] pd ") | ||||
|             .AppendLine("   on sl.f_part = pd.f_part ") | ||||
|             .AppendLine(" join [spcepiworld].[dbo].[test_dat] td ") | ||||
|             .AppendLine("   on sl.f_test = td.f_test ") | ||||
|             .AppendLine(" where sl.f_prcs = 0 ") | ||||
|             .Append("   and td.f_name = '").Append(find).AppendLine("' ") | ||||
|             .AppendLine("   and isnull(( ") | ||||
|             .AppendLine("        select count(sl_b.f_spec) ") | ||||
|             .AppendLine("        from [spcepiworld].[dbo].[spec_lim] sl_b ") | ||||
|             .AppendLine("        join [spcepiworld].[dbo].[part_dat] pd_b ") | ||||
|             .AppendLine("        on sl_b.f_part = pd_b.f_part ") | ||||
|             .AppendLine("        join [spcepiworld].[dbo].[test_dat] td_b ") | ||||
|             .AppendLine("        on sl_b.f_test = td_b.f_test ") | ||||
|             .AppendLine("        where sl_b.f_prcs = 0 ") | ||||
|             .Append(" and td_b.f_name = '").Append(replace).AppendLine("' ") | ||||
|             .AppendLine("        and pd_b.f_name = pd.f_name ") | ||||
|             .AppendLine("        and sl_b.f_url = sl.f_url ") | ||||
|             .AppendLine("        and sl_b.f_usl = sl.f_usl ") | ||||
|             .AppendLine("        and sl_b.f_ugb = sl.f_ugb ") | ||||
|             .AppendLine("        and sl_b.f_tar = sl.f_tar ") | ||||
|             .AppendLine("        and sl_b.f_lgb = sl.f_lgb ") | ||||
|             .AppendLine("        and sl_b.f_lsl = sl.f_lsl ") | ||||
|             .AppendLine("        and sl_b.f_lrl = sl.f_lrl ") | ||||
|             .AppendLine("        group by sl_b.f_spec ") | ||||
|             .AppendLine("   ), 0) = 0 ") | ||||
|             .AppendLine(" for json path "); | ||||
|         return result.ToString(); | ||||
|     } // cSpell:restore | ||||
|  | ||||
|     internal static void SaveCopy(string fileConnectorConfigurationSourceFileLocation, string connectionString, string name, string[] iqsCopyValues) | ||||
|     { | ||||
|         string checkFile = Path.Combine(fileConnectorConfigurationSourceFileLocation, $"{name}.json"); | ||||
|         if (!File.Exists(checkFile)) | ||||
|         { | ||||
|             string commandText = GetCommandText(iqsCopyValues); | ||||
|             StringBuilder stringBuilder = GetForJsonPath(connectionString, commandText); | ||||
|             if (stringBuilder.Length != 0) | ||||
|                 File.WriteAllText(checkFile, stringBuilder.ToString()); | ||||
|             else | ||||
|                 File.WriteAllText(Path.Combine(fileConnectorConfigurationSourceFileLocation, $"{name}.sql"), commandText); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| #nullable disable | ||||
|  | ||||
		Reference in New Issue
	
	Block a user