Changed to Year-Week
Update build pipeline
This commit is contained in:
@ -109,7 +109,7 @@ public class FileRead : Shared.FileRead, IFileRead
|
||||
results.Item4.Add(_Logistics.FileInfo);
|
||||
else
|
||||
{
|
||||
IProcessData iProcessData = new ProcessData(this, _Logistics, _FileConnectorConfiguration.TargetFileLocation, _URL, results.Item4);
|
||||
IProcessData iProcessData = new ProcessData(this, _Logistics, _Calendar, _FileConnectorConfiguration.TargetFileLocation, _URL, results.Item4);
|
||||
if (iProcessData.Details.Count == 0)
|
||||
results = new(string.Concat("B) No Data - ", dateTime.Ticks), Array.Empty<Test>(), Array.Empty<JsonElement>(), results.Item4);
|
||||
else
|
||||
|
@ -6,8 +6,8 @@ using log4net;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Collections.ObjectModel;
|
||||
using System.Globalization;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Text.Json;
|
||||
using System.Text.Json.Serialization;
|
||||
|
||||
@ -22,7 +22,7 @@ public class ProcessData : IProcessData
|
||||
|
||||
private readonly ILog _Log;
|
||||
|
||||
public ProcessData(IFileRead fileRead, Logistics logistics, string targetFileLocation, string url, List<FileInfo> fileInfoCollection)
|
||||
public ProcessData(IFileRead fileRead, Logistics logistics, Calendar calendar, string targetFileLocation, string url, List<FileInfo> fileInfoCollection)
|
||||
{
|
||||
if (fileRead.IsEAFHosted)
|
||||
{ }
|
||||
@ -31,7 +31,7 @@ public class ProcessData : IProcessData
|
||||
fileInfoCollection.Clear();
|
||||
_Details = new List<object>();
|
||||
_Log = LogManager.GetLogger(typeof(ProcessData));
|
||||
WriteFiles(fileRead, logistics, targetFileLocation, fileInfoCollection);
|
||||
WriteFiles(fileRead, logistics, calendar, targetFileLocation, fileInfoCollection);
|
||||
}
|
||||
|
||||
string IProcessData.GetCurrentReactor(IFileRead fileRead, Logistics logistics, Dictionary<string, string> reactors) =>
|
||||
@ -59,97 +59,6 @@ public class ProcessData : IProcessData
|
||||
return results;
|
||||
}
|
||||
|
||||
private void WriteFiles(IFileRead fileRead, Logistics logistics, string destinationDirectory, List<FileInfo> fileInfoCollection)
|
||||
{
|
||||
bool keepRelations = true;
|
||||
const string taskWorkItemType = "Task";
|
||||
string json = File.ReadAllText(logistics.ReportFullPath);
|
||||
WorkItem[]? workItems = JsonSerializer.Deserialize<WorkItem[]>(json);
|
||||
if (workItems is null)
|
||||
throw new Exception(nameof(workItems));
|
||||
_Details.Add(workItems);
|
||||
if (!Directory.Exists(destinationDirectory))
|
||||
_ = Directory.CreateDirectory(destinationDirectory);
|
||||
ReadOnlyDictionary<int, Record> keyValuePairs = GetWorkItems(workItems, keepRelations);
|
||||
ReadOnlyCollection<string> bugUserStoryTaskWorkItemTypes = new(new string[] { "Bug", "User Story", "Task" });
|
||||
ReadOnlyDictionary<int, string> collection = MoveCurrentAndGetExpectedDirectoriesAndFileCopy(taskWorkItemType, destinationDirectory, json, bugUserStoryTaskWorkItemTypes, keyValuePairs);
|
||||
WriteFiles(fileRead, fileInfoCollection, taskWorkItemType, destinationDirectory, keyValuePairs, collection);
|
||||
}
|
||||
|
||||
private static ReadOnlyDictionary<int, Record> GetWorkItems(WorkItem[] workItems, bool keepRelations)
|
||||
{
|
||||
ReadOnlyDictionary<int, Record> results;
|
||||
Dictionary<int, WorkItem> keyValuePairs = new();
|
||||
foreach (WorkItem workItem in workItems)
|
||||
keyValuePairs.Add(workItem.Id, workItem);
|
||||
results = GetKeyValuePairs(new(keyValuePairs), keepRelations);
|
||||
return results;
|
||||
}
|
||||
|
||||
private static ReadOnlyDictionary<int, string> MoveCurrentAndGetExpectedDirectoriesAndFileCopy(string taskWorkItemType, string destinationDirectory, string json, ReadOnlyCollection<string> bugUserStoryTaskWorkItemTypes, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
{
|
||||
ReadOnlyDictionary<int, string> results;
|
||||
string? directory;
|
||||
ReadOnlyDictionary<int, string> collection = GetCurrentDirectories(destinationDirectory, bugUserStoryTaskWorkItemTypes);
|
||||
results = GetExpectedDirectoriesAndFileCopy(taskWorkItemType, destinationDirectory, json, bugUserStoryTaskWorkItemTypes, keyValuePairs);
|
||||
foreach (KeyValuePair<int, string> keyValuePair in collection)
|
||||
{
|
||||
if (!results.TryGetValue(keyValuePair.Key, out directory))
|
||||
MoveToUnknown(destinationDirectory, keyValuePair.Key, keyValuePair.Value);
|
||||
else
|
||||
{
|
||||
if (keyValuePair.Value == directory)
|
||||
continue;
|
||||
else
|
||||
MoveToNew(destinationDirectory, keyValuePair.Key, keyValuePair.Value, directory);
|
||||
}
|
||||
}
|
||||
return results;
|
||||
}
|
||||
|
||||
private static FileInfo GetFileInfoAndMaybeWriteFile(string directory, WorkItem workItem)
|
||||
{
|
||||
FileInfo result;
|
||||
if (!Directory.Exists(directory))
|
||||
_ = Directory.CreateDirectory(directory);
|
||||
string json = JsonSerializer.Serialize(workItem, WorkItemSourceGenerationContext.Default.WorkItem);
|
||||
string singletonDirectory = Path.Combine(directory, $"{workItem.Id}");
|
||||
if (Directory.Exists(singletonDirectory))
|
||||
{
|
||||
List<string> files = Directory.GetFiles(singletonDirectory, "*", SearchOption.AllDirectories).ToList();
|
||||
string checkFile = Path.Combine(singletonDirectory, ".json");
|
||||
if (files.Remove(checkFile))
|
||||
File.Delete(checkFile);
|
||||
if (files.Count == 0)
|
||||
Directory.Delete(singletonDirectory);
|
||||
}
|
||||
result = new(Path.Combine(directory, $"{workItem.Id}.json"));
|
||||
string old = result.Exists ? File.ReadAllText(result.FullName) : string.Empty;
|
||||
if (old != json)
|
||||
File.WriteAllText(result.FullName, json);
|
||||
return result;
|
||||
}
|
||||
|
||||
private static void WriteFiles(IFileRead fileRead, List<FileInfo> fileInfoCollection, string taskWorkItemType, string destinationDirectory, ReadOnlyDictionary<int, Record> keyValuePairs, ReadOnlyDictionary<int, string> collection)
|
||||
{
|
||||
string? directory;
|
||||
FileInfo fileInfo;
|
||||
WorkItem workItem;
|
||||
foreach (KeyValuePair<int, Record> keyValuePair in keyValuePairs)
|
||||
{
|
||||
workItem = keyValuePair.Value.WorkItem;
|
||||
if (!collection.TryGetValue(keyValuePair.Key, out directory))
|
||||
{
|
||||
if (workItem.WorkItemType != taskWorkItemType || workItem.Parent is not null)
|
||||
continue;
|
||||
directory = GetDirectory(destinationDirectory, workItem);
|
||||
}
|
||||
fileInfo = GetFileInfoAndMaybeWriteFile(directory, workItem);
|
||||
if (!fileRead.IsEAFHosted)
|
||||
fileInfoCollection.Add(fileInfo);
|
||||
}
|
||||
}
|
||||
|
||||
private static ReadOnlyDictionary<int, Record> GetKeyValuePairs(ReadOnlyDictionary<int, WorkItem> keyValuePairs, bool keepRelations)
|
||||
{
|
||||
Dictionary<int, Record> results = new();
|
||||
@ -183,120 +92,144 @@ public class ProcessData : IProcessData
|
||||
return new(results);
|
||||
}
|
||||
|
||||
private static ReadOnlyDictionary<int, string> GetCurrentDirectories(string destinationDirectory, ReadOnlyCollection<string> bugUserStoryTaskWorkItemTypes)
|
||||
private static ReadOnlyDictionary<int, Record> GetWorkItems(WorkItem[] workItems, bool keepRelations)
|
||||
{
|
||||
Dictionary<int, string> results = new();
|
||||
int id;
|
||||
string idCheck;
|
||||
string? fileName;
|
||||
string[] directories;
|
||||
string[] split = new string[] { "-" };
|
||||
foreach (string w in bugUserStoryTaskWorkItemTypes)
|
||||
{
|
||||
directories = Directory.GetDirectories(destinationDirectory, $"*-{w.Replace(" ", "-")}", SearchOption.AllDirectories);
|
||||
foreach (string directory in directories)
|
||||
{
|
||||
fileName = Path.GetFileName(directory);
|
||||
if (string.IsNullOrEmpty(fileName))
|
||||
continue;
|
||||
idCheck = fileName.Split(split, StringSplitOptions.None)[0];
|
||||
if (!int.TryParse(idCheck, out id))
|
||||
continue;
|
||||
if (!results.ContainsKey(id))
|
||||
results.Add(id, directory);
|
||||
else
|
||||
MoveToDuplicate(destinationDirectory, directory);
|
||||
}
|
||||
}
|
||||
return new(results);
|
||||
ReadOnlyDictionary<int, Record> results;
|
||||
Dictionary<int, WorkItem> keyValuePairs = new();
|
||||
foreach (WorkItem workItem in workItems)
|
||||
keyValuePairs.Add(workItem.Id, workItem);
|
||||
results = GetKeyValuePairs(new(keyValuePairs), keepRelations);
|
||||
return results;
|
||||
}
|
||||
|
||||
private static void FileCopy(string destinationDirectory, string json, List<string> distinct)
|
||||
private static void WriteFiles(IFileRead fileRead, DirectoryInfo tasksDirectory, Record[] records)
|
||||
{
|
||||
string old;
|
||||
string json;
|
||||
string checkFile;
|
||||
string checkDirectory;
|
||||
foreach (string iterationPath in distinct)
|
||||
WorkItem workItem;
|
||||
foreach (Record record in records)
|
||||
{
|
||||
checkDirectory = Path.Combine(destinationDirectory, iterationPath);
|
||||
if (!Directory.Exists(checkDirectory))
|
||||
_ = Directory.CreateDirectory(checkDirectory);
|
||||
checkFile = Path.Combine(checkDirectory, "[].json");
|
||||
workItem = record.WorkItem;
|
||||
json = JsonSerializer.Serialize(workItem, WorkItemSourceGenerationContext.Default.WorkItem);
|
||||
checkFile = Path.Combine(tasksDirectory.FullName, $"{workItem.Id}.json");
|
||||
old = File.Exists(checkFile) ? File.ReadAllText(checkFile) : string.Empty;
|
||||
if (old != json)
|
||||
File.WriteAllText(checkFile, json);
|
||||
if (!fileRead.IsEAFHosted || old == json)
|
||||
continue;
|
||||
File.WriteAllText(checkFile, json);
|
||||
}
|
||||
}
|
||||
|
||||
private static ReadOnlyDictionary<int, string> GetExpectedDirectoriesAndFileCopy(string taskWorkItemType, string destinationDirectory, string json, ReadOnlyCollection<string> bugUserStoryTaskWorkItemTypes, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
private static string GetTaskText(string directory) =>
|
||||
string.Join(Environment.NewLine, new string[]
|
||||
{
|
||||
"{",
|
||||
"\"version\": \"2.0.0\",",
|
||||
"\"tasks\": [",
|
||||
"{",
|
||||
"\"label\": \"File-Folder-Helper AOT s X Day-Helper-2025-02-04\",",
|
||||
"\"type\": \"shell\",",
|
||||
"\"command\": \"L:/DevOps/Mesa_FI/File-Folder-Helper/bin/Release/net8.0/win-x64/publish/File-Folder-Helper.exe\",",
|
||||
"\"args\": [",
|
||||
"\"s\",",
|
||||
"\"X\",",
|
||||
$"\"{directory.Replace('\\', '/')}\",",
|
||||
"\"Day-Helper-2025-02-04\",",
|
||||
"],",
|
||||
"\"problemMatcher\": []",
|
||||
"}",
|
||||
"]",
|
||||
"}",
|
||||
});
|
||||
|
||||
private static void WriteFiles(IFileRead fileRead, Calendar calendar, string destinationDirectory, bool keepRelations, WorkItem[] workItems)
|
||||
{
|
||||
Dictionary<int, string> results = new();
|
||||
string directory;
|
||||
string json;
|
||||
string text;
|
||||
string jsonOld;
|
||||
string jsonFile;
|
||||
string textFile;
|
||||
string weekOfYear;
|
||||
WorkItem workItem;
|
||||
string iterationPath;
|
||||
List<string> distinct = new();
|
||||
DirectoryInfo directory;
|
||||
DirectoryInfo kanbnDirectory;
|
||||
DirectoryInfo tasksDirectory;
|
||||
DirectoryInfo visualStudioCodeDirectory;
|
||||
ReadOnlyDictionary<int, Record> keyValuePairs = GetWorkItems(workItems, keepRelations);
|
||||
foreach (KeyValuePair<int, Record> keyValuePair in keyValuePairs)
|
||||
{
|
||||
workItem = keyValuePair.Value.WorkItem;
|
||||
iterationPath = workItem.IterationPath.Replace(" ", "-");
|
||||
if (!distinct.Contains(iterationPath))
|
||||
distinct.Add(iterationPath);
|
||||
if (!bugUserStoryTaskWorkItemTypes.Contains(workItem.WorkItemType))
|
||||
continue;
|
||||
if (workItem.WorkItemType == taskWorkItemType && workItem.Parent is not null)
|
||||
continue;
|
||||
directory = GetDirectory(destinationDirectory, workItem);
|
||||
results.Add(workItem.Id, directory);
|
||||
json = JsonSerializer.Serialize(workItem, WorkItemSourceGenerationContext.Default.WorkItem);
|
||||
weekOfYear = calendar.GetWeekOfYear(workItem.CreatedDate, CalendarWeekRule.FirstDay, DayOfWeek.Sunday).ToString("00");
|
||||
directory = new(Path.Combine(destinationDirectory, "{}", $"{workItem.CreatedDate:yyyy}", $"{workItem.CreatedDate:yyyy}_Week_{weekOfYear}", $"{workItem.Id}"));
|
||||
text = GetTaskText(directory.FullName);
|
||||
visualStudioCodeDirectory = new(Path.Combine(directory.FullName, ".vscode"));
|
||||
if (!visualStudioCodeDirectory.Exists)
|
||||
_ = Directory.CreateDirectory(visualStudioCodeDirectory.FullName);
|
||||
textFile = Path.Combine(visualStudioCodeDirectory.FullName, "tasks.json");
|
||||
if (fileRead.IsEAFHosted && !File.Exists(textFile))
|
||||
File.WriteAllText(textFile, text);
|
||||
kanbnDirectory = new(Path.Combine(directory.FullName, ".kanbn"));
|
||||
tasksDirectory = new(Path.Combine(kanbnDirectory.FullName, "tasks"));
|
||||
if (!tasksDirectory.Exists)
|
||||
_ = Directory.CreateDirectory(tasksDirectory.FullName);
|
||||
jsonFile = Path.Combine(kanbnDirectory.FullName, $"{workItem.Id}.json");
|
||||
jsonOld = File.Exists(jsonFile) ? File.ReadAllText(jsonFile) : string.Empty;
|
||||
if (fileRead.IsEAFHosted && jsonOld != json)
|
||||
File.WriteAllText(jsonFile, json);
|
||||
if (keyValuePair.Value.Children is not null && keyValuePair.Value.Children.Length > 0)
|
||||
WriteFiles(fileRead, tasksDirectory, keyValuePair.Value.Children);
|
||||
if (visualStudioCodeDirectory.LastWriteTime != workItem.CreatedDate)
|
||||
Directory.SetLastWriteTime(visualStudioCodeDirectory.FullName, workItem.CreatedDate);
|
||||
if (kanbnDirectory.LastWriteTime != workItem.CreatedDate)
|
||||
Directory.SetLastWriteTime(kanbnDirectory.FullName, workItem.CreatedDate);
|
||||
if (directory.LastWriteTime != workItem.CreatedDate)
|
||||
Directory.SetLastWriteTime(directory.FullName, workItem.CreatedDate);
|
||||
if (visualStudioCodeDirectory.CreationTime != workItem.CreatedDate)
|
||||
Directory.SetCreationTime(visualStudioCodeDirectory.FullName, workItem.CreatedDate);
|
||||
if (kanbnDirectory.CreationTime != workItem.CreatedDate)
|
||||
Directory.SetCreationTime(kanbnDirectory.FullName, workItem.CreatedDate);
|
||||
if (directory.CreationTime != workItem.CreatedDate)
|
||||
Directory.SetCreationTime(directory.FullName, workItem.CreatedDate);
|
||||
}
|
||||
if (distinct.Count > 0)
|
||||
FileCopy(destinationDirectory, json, distinct);
|
||||
return new(results);
|
||||
}
|
||||
|
||||
private static void MoveToUnknown(string destinationDirectory, int id, string directory)
|
||||
private static void WriteFiles(IFileRead fileRead, Calendar calendar, string destinationDirectory, WorkItem[] workItems)
|
||||
{
|
||||
if (string.IsNullOrEmpty(destinationDirectory))
|
||||
throw new ArgumentException($"'{nameof(destinationDirectory)}' {id} cannot be null or empty.", nameof(destinationDirectory));
|
||||
if (string.IsNullOrEmpty(directory))
|
||||
throw new ArgumentException($"'{nameof(directory)}' cannot be null or empty.", nameof(directory));
|
||||
}
|
||||
|
||||
private static void MoveToNew(string destinationDirectory, int id, string oldDirectory, string newDirectory)
|
||||
{
|
||||
if (Directory.Exists(newDirectory))
|
||||
MoveToDuplicate(destinationDirectory, id, oldDirectory);
|
||||
else
|
||||
string old;
|
||||
string json;
|
||||
string directory;
|
||||
string checkFile;
|
||||
string weekOfYear;
|
||||
foreach (WorkItem workItem in workItems)
|
||||
{
|
||||
string directory = Path.GetDirectoryName(newDirectory) ?? throw new NotImplementedException();
|
||||
weekOfYear = calendar.GetWeekOfYear(workItem.CreatedDate, CalendarWeekRule.FirstDay, DayOfWeek.Sunday).ToString("00");
|
||||
directory = Path.Combine(destinationDirectory, "[]", $"{workItem.CreatedDate:yyyy}", $"{workItem.CreatedDate:yyyy}_Week_{weekOfYear}", $"{workItem.Id}");
|
||||
if (!Directory.Exists(directory))
|
||||
_ = Directory.CreateDirectory(directory);
|
||||
Directory.Move(oldDirectory, newDirectory);
|
||||
json = JsonSerializer.Serialize(workItem, WorkItemSourceGenerationContext.Default.WorkItem);
|
||||
checkFile = Path.Combine(directory, $"{workItem.Id}.json");
|
||||
old = File.Exists(checkFile) ? File.ReadAllText(checkFile) : string.Empty;
|
||||
if (!fileRead.IsEAFHosted || old == json)
|
||||
continue;
|
||||
File.WriteAllText(checkFile, json);
|
||||
}
|
||||
}
|
||||
|
||||
private static string GetDirectory(string destinationDirectory, WorkItem workItem)
|
||||
private void WriteFiles(IFileRead fileRead, Logistics logistics, Calendar calendar, string destinationDirectory, List<FileInfo> fileInfoCollection)
|
||||
{
|
||||
string result;
|
||||
string workItemType = workItem.WorkItemType.Replace(" ", "-");
|
||||
string iterationPath = workItem.IterationPath.Replace(" ", "-");
|
||||
result = Path.Combine(destinationDirectory, iterationPath, $"{workItem.Id}-{workItemType}");
|
||||
return result;
|
||||
}
|
||||
|
||||
private static void MoveToDuplicate(string destinationDirectory, string directory)
|
||||
{
|
||||
if (string.IsNullOrEmpty(destinationDirectory))
|
||||
throw new ArgumentException($"'{nameof(destinationDirectory)}' cannot be null or empty.", nameof(destinationDirectory));
|
||||
if (string.IsNullOrEmpty(directory))
|
||||
throw new ArgumentException($"'{nameof(directory)}' cannot be null or empty.", nameof(directory));
|
||||
}
|
||||
|
||||
private static void MoveToDuplicate(string destinationDirectory, int id, string oldDirectory)
|
||||
{
|
||||
if (string.IsNullOrEmpty(destinationDirectory))
|
||||
throw new ArgumentException($"'{nameof(destinationDirectory)}' {id} cannot be null or empty.", nameof(destinationDirectory));
|
||||
if (string.IsNullOrEmpty(oldDirectory))
|
||||
throw new ArgumentException($"'{nameof(oldDirectory)}' cannot be null or empty.", nameof(oldDirectory));
|
||||
if (fileInfoCollection is null)
|
||||
throw new ArgumentNullException(nameof(fileInfoCollection));
|
||||
bool keepRelations = true;
|
||||
string json = File.ReadAllText(logistics.ReportFullPath);
|
||||
WorkItem[]? workItems = JsonSerializer.Deserialize<WorkItem[]>(json);
|
||||
if (workItems is null)
|
||||
throw new Exception(nameof(workItems));
|
||||
_Details.Add(workItems);
|
||||
if (!Directory.Exists(destinationDirectory))
|
||||
_ = Directory.CreateDirectory(destinationDirectory);
|
||||
WriteFiles(fileRead, calendar, destinationDirectory, workItems);
|
||||
WriteFiles(fileRead, calendar, destinationDirectory, keepRelations, workItems);
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user