2023-11-19 02:12:44 +03:00
|
|
|
|
package TestingSystem.SAPFOR.Json;
|
2023-12-18 15:44:48 +03:00
|
|
|
|
import GlobalData.Tasks.TaskState;
|
|
|
|
|
|
import TestingSystem.SAPFOR.SapforPackage.SapforPackage;
|
|
|
|
|
|
import TestingSystem.SAPFOR.SapforTask.MatchState;
|
2023-12-16 03:57:01 +03:00
|
|
|
|
import TestingSystem.SAPFOR.SapforTask.SapforTask;
|
2023-12-18 15:44:48 +03:00
|
|
|
|
import TestingSystem.SAPFOR.SapforTasksPackage.UI.*;
|
2023-09-29 00:45:45 +03:00
|
|
|
|
import com.google.gson.annotations.Expose;
|
|
|
|
|
|
|
2023-12-18 15:44:48 +03:00
|
|
|
|
import javax.swing.tree.DefaultMutableTreeNode;
|
|
|
|
|
|
import java.io.File;
|
2023-12-16 03:57:01 +03:00
|
|
|
|
import java.io.Serializable;
|
2023-12-18 15:44:48 +03:00
|
|
|
|
import java.util.Comparator;
|
|
|
|
|
|
import java.util.LinkedHashMap;
|
2023-09-29 00:45:45 +03:00
|
|
|
|
import java.util.List;
|
|
|
|
|
|
import java.util.Vector;
|
2023-12-16 03:57:01 +03:00
|
|
|
|
public class SapforTasksPackage_json implements Serializable {
|
2023-10-14 02:30:31 +03:00
|
|
|
|
@Expose
|
|
|
|
|
|
public int kernels = 1;
|
2023-09-30 18:19:31 +03:00
|
|
|
|
@Expose
|
|
|
|
|
|
public String sapfor_drv = ""; //файл с сапфором. Имя уникально для сценария.
|
2023-09-29 00:45:45 +03:00
|
|
|
|
@Expose
|
2023-10-21 02:47:21 +03:00
|
|
|
|
public List<SapforTest_json> tests = new Vector<>();
|
2023-09-29 00:45:45 +03:00
|
|
|
|
@Expose
|
2023-10-08 01:57:25 +03:00
|
|
|
|
public List<SapforConfiguration_json> configurations = new Vector<>();
|
2023-12-16 03:57:01 +03:00
|
|
|
|
//---
|
|
|
|
|
|
@Expose
|
|
|
|
|
|
public List<SapforTask> tasks = new Vector<>();
|
2023-12-18 15:44:48 +03:00
|
|
|
|
//-
|
|
|
|
|
|
public PackageSummary root = null;
|
|
|
|
|
|
public PackageSummary comparison_root = null;
|
|
|
|
|
|
public LinkedHashMap<String, SapforTask> allTasks = new LinkedHashMap<>();
|
|
|
|
|
|
public LinkedHashMap<TaskState, LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>>> sortedTasks = new LinkedHashMap<>();
|
|
|
|
|
|
//-- задачи, отсортированные для сравнения.
|
|
|
|
|
|
public LinkedHashMap<MatchState, LinkedHashMap<TaskState, LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>>>> comparisonSortedTasks = new LinkedHashMap<>();
|
|
|
|
|
|
//----
|
|
|
|
|
|
//---------
|
|
|
|
|
|
public void DropComparison() {
|
|
|
|
|
|
comparison_root = null;
|
|
|
|
|
|
comparisonSortedTasks.clear();
|
|
|
|
|
|
for (SapforTask task : allTasks.values())
|
|
|
|
|
|
task.match = MatchState.NotMatch;
|
|
|
|
|
|
}
|
|
|
|
|
|
public void SortTasks() {
|
|
|
|
|
|
sortedTasks.clear();
|
|
|
|
|
|
//--
|
|
|
|
|
|
for (TaskState state : TaskState.values()) {
|
|
|
|
|
|
LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>> configuration_tasks = new LinkedHashMap<>();
|
|
|
|
|
|
sortedTasks.put(state, configuration_tasks);
|
|
|
|
|
|
//--
|
|
|
|
|
|
for (SapforTask task : tasks) {
|
|
|
|
|
|
if (task.state.equals(state)) {
|
|
|
|
|
|
LinkedHashMap<String, Vector<SapforTask>> groups_tasks = null;
|
|
|
|
|
|
if (configuration_tasks.containsKey(task.sapfor_configuration_id)) {
|
|
|
|
|
|
groups_tasks = configuration_tasks.get(task.sapfor_configuration_id);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
groups_tasks = new LinkedHashMap<>();
|
|
|
|
|
|
configuration_tasks.put(task.sapfor_configuration_id, groups_tasks);
|
|
|
|
|
|
}
|
|
|
|
|
|
Vector<SapforTask> tasks_ = null;
|
|
|
|
|
|
if (groups_tasks.containsKey(task.group_description)) {
|
|
|
|
|
|
tasks_ = groups_tasks.get(task.group_description);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
tasks_ = new Vector<>();
|
|
|
|
|
|
groups_tasks.put(task.group_description, tasks_);
|
|
|
|
|
|
}
|
|
|
|
|
|
tasks_.add(task);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
//--
|
|
|
|
|
|
}
|
|
|
|
|
|
//--
|
|
|
|
|
|
for (TaskState state : TaskState.values()) {
|
|
|
|
|
|
LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>> configuration_tasks = sortedTasks.get(state);
|
|
|
|
|
|
for (int configuration_id : configuration_tasks.keySet()) {
|
|
|
|
|
|
LinkedHashMap<String, Vector<SapforTask>> groups_tasks = configuration_tasks.get(configuration_id);
|
|
|
|
|
|
for (String group : groups_tasks.keySet()) {
|
|
|
|
|
|
Vector<SapforTask> tasks_ = groups_tasks.get(group);
|
|
|
|
|
|
tasks_.sort(Comparator.comparing(SapforTask::getUniqueKey));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
public void SortTasksForComparison() {
|
|
|
|
|
|
comparisonSortedTasks.clear();
|
|
|
|
|
|
//раскидать задачи по состояниям, конфигам, группам
|
|
|
|
|
|
for (MatchState matchState : MatchState.values()) {
|
|
|
|
|
|
LinkedHashMap<TaskState, LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>>> state_tasks = new LinkedHashMap<>();
|
|
|
|
|
|
comparisonSortedTasks.put(matchState, state_tasks);
|
|
|
|
|
|
//--
|
|
|
|
|
|
for (TaskState state : TaskState.values()) {
|
|
|
|
|
|
LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>> configuration_tasks = new LinkedHashMap<>();
|
|
|
|
|
|
state_tasks.put(state, configuration_tasks);
|
|
|
|
|
|
//--
|
|
|
|
|
|
for (SapforTask task : tasks) {
|
|
|
|
|
|
if (task.match.equals(matchState) && task.state.equals(state)) {
|
|
|
|
|
|
LinkedHashMap<String, Vector<SapforTask>> groups_tasks = null;
|
|
|
|
|
|
if (configuration_tasks.containsKey(task.sapfor_configuration_id)) {
|
|
|
|
|
|
groups_tasks = configuration_tasks.get(task.sapfor_configuration_id);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
groups_tasks = new LinkedHashMap<>();
|
|
|
|
|
|
configuration_tasks.put(task.sapfor_configuration_id, groups_tasks);
|
|
|
|
|
|
}
|
|
|
|
|
|
Vector<SapforTask> tasks = null;
|
|
|
|
|
|
if (groups_tasks.containsKey(task.group_description)) {
|
|
|
|
|
|
tasks = groups_tasks.get(task.group_description);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
tasks = new Vector<>();
|
|
|
|
|
|
groups_tasks.put(task.group_description, tasks);
|
|
|
|
|
|
}
|
|
|
|
|
|
tasks.add(task);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
//--
|
|
|
|
|
|
}
|
|
|
|
|
|
//рассортировать задачи в группах по ключам.
|
|
|
|
|
|
for (MatchState matchState : MatchState.values()) {
|
|
|
|
|
|
LinkedHashMap<TaskState, LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>>> state_tasks = comparisonSortedTasks.get(matchState);
|
|
|
|
|
|
for (TaskState state : TaskState.values()) {
|
|
|
|
|
|
LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>> configuration_tasks = state_tasks.get(state);
|
|
|
|
|
|
for (int configuration_id : configuration_tasks.keySet()) {
|
|
|
|
|
|
LinkedHashMap<String, Vector<SapforTask>> groups_tasks = configuration_tasks.get(configuration_id);
|
|
|
|
|
|
for (String group : groups_tasks.keySet()) {
|
|
|
|
|
|
Vector<SapforTask> tasks_ = groups_tasks.get(group);
|
|
|
|
|
|
tasks_.sort(Comparator.comparing(SapforTask::getUniqueKey));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
public void buildTree(SapforPackage package_in) {
|
|
|
|
|
|
root = new PackageSummary();
|
|
|
|
|
|
//---
|
|
|
|
|
|
for (TaskState state : sortedTasks.keySet()) {
|
|
|
|
|
|
//--
|
|
|
|
|
|
StateSummary stateSummary = new StateSummary(state);
|
|
|
|
|
|
//--
|
|
|
|
|
|
LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>> tasksByConfigurations = sortedTasks.get(state);
|
|
|
|
|
|
for (int configuration_id : tasksByConfigurations.keySet()) {
|
|
|
|
|
|
//--
|
|
|
|
|
|
DefaultMutableTreeNode configurationNode = null;
|
|
|
|
|
|
//--
|
|
|
|
|
|
LinkedHashMap<String, Vector<SapforTask>> groups_tasks = tasksByConfigurations.get(configuration_id);
|
|
|
|
|
|
for (String group : groups_tasks.keySet()) {
|
|
|
|
|
|
//--
|
|
|
|
|
|
GroupSummary groupSummary = new GroupSummary(group);
|
|
|
|
|
|
//--
|
|
|
|
|
|
for (SapforTask task : groups_tasks.get(group)) {
|
|
|
|
|
|
//--
|
|
|
|
|
|
stateSummary.count++;
|
|
|
|
|
|
root.count++;
|
|
|
|
|
|
//--
|
|
|
|
|
|
if (configurationNode == null) {
|
|
|
|
|
|
configurationNode = new ConfigurationSummary(configuration_id, task);
|
|
|
|
|
|
}
|
|
|
|
|
|
//--
|
|
|
|
|
|
groupSummary.add(task.getVersionsTree(new File(package_in.getLocalWorkspace(), String.valueOf(configuration_id))));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (configurationNode != null)
|
|
|
|
|
|
configurationNode.add(groupSummary);
|
|
|
|
|
|
}
|
|
|
|
|
|
stateSummary.add(configurationNode);
|
|
|
|
|
|
}
|
|
|
|
|
|
if (stateSummary.count > 0) {
|
|
|
|
|
|
root.add(stateSummary);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
public void buildComparisonTree(SapforPackage package_in) {
|
|
|
|
|
|
comparison_root = new PackageSummary();
|
|
|
|
|
|
for (MatchState match_state : comparisonSortedTasks.keySet()) {
|
|
|
|
|
|
//--
|
|
|
|
|
|
MatchesSummary matchesSummary = new MatchesSummary(match_state);
|
|
|
|
|
|
//---
|
|
|
|
|
|
LinkedHashMap<TaskState, LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>>> task_states = comparisonSortedTasks.get(match_state);
|
|
|
|
|
|
//---
|
|
|
|
|
|
for (TaskState state : task_states.keySet()) {
|
|
|
|
|
|
//--
|
|
|
|
|
|
StateSummary stateSummary = new StateSummary(state);
|
|
|
|
|
|
//--
|
|
|
|
|
|
LinkedHashMap<Integer, LinkedHashMap<String, Vector<SapforTask>>> tasksByConfigurations = task_states.get(state);
|
|
|
|
|
|
for (int configuration_id : tasksByConfigurations.keySet()) {
|
|
|
|
|
|
//--
|
|
|
|
|
|
DefaultMutableTreeNode configurationNode = null;
|
|
|
|
|
|
//--
|
|
|
|
|
|
LinkedHashMap<String, Vector<SapforTask>> groups_tasks = tasksByConfigurations.get(configuration_id);
|
|
|
|
|
|
for (String group : groups_tasks.keySet()) {
|
|
|
|
|
|
//--
|
|
|
|
|
|
GroupSummary groupSummary = new GroupSummary(group);
|
|
|
|
|
|
//--
|
|
|
|
|
|
for (SapforTask task : groups_tasks.get(group)) {
|
|
|
|
|
|
//--
|
|
|
|
|
|
stateSummary.count++;
|
|
|
|
|
|
matchesSummary.count++;
|
|
|
|
|
|
comparison_root.count++;
|
|
|
|
|
|
//--
|
|
|
|
|
|
if (configurationNode == null) {
|
|
|
|
|
|
configurationNode = new ConfigurationSummary(configuration_id, task);
|
|
|
|
|
|
}
|
|
|
|
|
|
//--
|
|
|
|
|
|
groupSummary.add(task.getVersionsTree(new File(package_in.getLocalWorkspace(), String.valueOf(configuration_id))));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (configurationNode != null)
|
|
|
|
|
|
configurationNode.add(groupSummary);
|
|
|
|
|
|
}
|
|
|
|
|
|
stateSummary.add(configurationNode);
|
|
|
|
|
|
}
|
|
|
|
|
|
if (stateSummary.count > 0) {
|
|
|
|
|
|
matchesSummary.add(stateSummary);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
//---
|
|
|
|
|
|
if (matchesSummary.count > 0) {
|
|
|
|
|
|
comparison_root.add(matchesSummary);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2023-09-29 00:45:45 +03:00
|
|
|
|
}
|