no message

This commit is contained in:
2023-09-22 00:16:46 +03:00
parent d5b9da80de
commit 6df3eb05ee
5 changed files with 49 additions and 11 deletions

4
.idea/workspace.xml generated
View File

@@ -7,9 +7,11 @@
</component> </component>
<component name="ChangeListManager"> <component name="ChangeListManager">
<list default="true" id="e42177c3-2328-4b27-8a01-35779b2beb99" name="Default Changelist" comment=""> <list default="true" id="e42177c3-2328-4b27-8a01-35779b2beb99" name="Default Changelist" comment="">
<change afterPath="$PROJECT_DIR$/src/SapforTestingSystem/SapforTest/SapforTest.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" /> <change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/Common/ModesSupervisors/PackageModeSupervisor.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/Common/ModesSupervisors/PackageModeSupervisor.java" afterDir="false" /> <change beforePath="$PROJECT_DIR$/src/Common/ModesSupervisors/PackageModeSupervisor.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/Common/ModesSupervisors/PackageModeSupervisor.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/Common/Utils/Utils.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/Common/Utils/Utils.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/SapforTestingSystem/SapforTest/SapforTest.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/SapforTestingSystem/SapforTest/SapforTest.java" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/Visual_DVM_2021/Passes/All/StartSapforTests.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/Visual_DVM_2021/Passes/All/StartSapforTests.java" afterDir="false" />
</list> </list>
<option name="SHOW_DIALOG" value="false" /> <option name="SHOW_DIALOG" value="false" />
<option name="HIGHLIGHT_CONFLICTS" value="true" /> <option name="HIGHLIGHT_CONFLICTS" value="true" />

View File

@@ -3,10 +3,12 @@ import Common.Global;
import Common.Utils.InterruptThread; import Common.Utils.InterruptThread;
import Common.Utils.Utils; import Common.Utils.Utils;
import SapforTestingSystem.Json.Scenario_json; import SapforTestingSystem.Json.Scenario_json;
import SapforTestingSystem.SapforTest.SapforTest;
import org.apache.commons.io.FileUtils; import org.apache.commons.io.FileUtils;
import java.io.File; import java.io.File;
import java.nio.charset.Charset; import java.nio.charset.Charset;
import java.util.LinkedHashMap;
import java.util.Stack; import java.util.Stack;
import java.util.Vector; import java.util.Vector;
public class PackageModeSupervisor { public class PackageModeSupervisor {
@@ -24,6 +26,8 @@ public class PackageModeSupervisor {
File sapfor_drv; File sapfor_drv;
File scenarioFile; File scenarioFile;
//--->> //--->>
LinkedHashMap<String, SapforTest> allTests = new LinkedHashMap<>();
//--->>>
Vector<String> activeTests = new Vector<>(); Vector<String> activeTests = new Vector<>();
Stack<String> waitingTests = new Stack<>(); Stack<String> waitingTests = new Stack<>();
//--->> //--->>
@@ -34,13 +38,12 @@ public class PackageModeSupervisor {
String packed = FileUtils.readFileToString(scenarioFile, Charset.defaultCharset()); String packed = FileUtils.readFileToString(scenarioFile, Charset.defaultCharset());
scenario = Utils.gson.fromJson(packed, Scenario_json.class); scenario = Utils.gson.fromJson(packed, Scenario_json.class);
//--->> //--->>
/* for (String test : scenario.tests) {
for (String test : scenario.tests) allTests.put(test, new SapforTest(Global.Home, test));
waitingTests.push(test); waitingTests.push(test);
*/
} }
public boolean isFinished(String test){ }
public boolean isFinished(String test) {
return true; return true;
} }
//--->> //--->>
@@ -55,23 +58,32 @@ public class PackageModeSupervisor {
activeTests.remove(test); activeTests.remove(test);
} }
*/ */
return true; return false;
} }
public boolean startWaitingTests() throws Exception { public boolean startWaitingTests() throws Exception {
return true; return false;
}
public void finalize(){
Global.Log.Print("END");
} }
//--->> //--->>
public void Do() { public void Do() {
try { try {
Global.Log.Print("START");
interruptThread.start(); interruptThread.start();
//--->> //--->>
init(); init();
//--->> //--->>
while (checkActiveTests()&&startWaitingTests()){ while (checkActiveTests() && startWaitingTests()) {
Thread.sleep(1000); Thread.sleep(1000);
} }
finalize();
//--->>
} catch (Exception ex) { } catch (Exception ex) {
ex.printStackTrace(); ex.printStackTrace();
} }
finally {
System.exit(0);
}
} }
} }

View File

@@ -1052,6 +1052,18 @@ public class Utils {
public static Process startScript(File scriptDirectory, File targetDirectory, String name, String scriptText) throws Exception { public static Process startScript(File scriptDirectory, File targetDirectory, String name, String scriptText) throws Exception {
return startScript(scriptDirectory, targetDirectory, name, scriptText, null); return startScript(scriptDirectory, targetDirectory, name, scriptText, null);
} }
public static Process startScript_(File scriptDirectory, File targetDirectory, String name, String scriptText) throws Exception {
//->
File scriptFile = Paths.get(scriptDirectory.getAbsolutePath(), name + (Global.isWindows ? ".bat" : "")).toFile();
FileUtils.write(scriptFile, "cd " + Utils.DQuotes(targetDirectory.getAbsolutePath()) + "\n" + scriptText);
if (!scriptFile.setExecutable(true)) throw new PassException("Не удалось создать исполняемый файл для скрипта");
//->>
ProcessBuilder procBuilder = new ProcessBuilder(scriptFile.getAbsolutePath());
procBuilder.directory(scriptDirectory);
procBuilder.redirectErrorStream(true);
return null;
}
//</editor-fold> //</editor-fold>
//<editor-fold desc="чтение вывода процесса"> //<editor-fold desc="чтение вывода процесса">
public static String readLine(Process process) throws Exception { public static String readLine(Process process) throws Exception {

View File

@@ -1,4 +1,15 @@
package SapforTestingSystem.SapforTest; package SapforTestingSystem.SapforTest;
import GlobalData.Tasks.TaskState;
import java.io.File;
public class SapforTest { public class SapforTest {
public String description; public String description;
public File home;
public TaskState state;
//--
public SapforTest(String packageHome, String description_in) {
description = description_in;
state = TaskState.Waiting;
home = new File(packageHome, description);
}
} }

View File

@@ -232,7 +232,6 @@ public class StartSapforTests extends Pass_2021<Vector<SapforTasksPackage_2023>>
).toFile().getAbsolutePath(); ).toFile().getAbsolutePath();
//--- //---
Utils.CheckAndCleanDirectory(new File(sapforTasksPackage_2023.workspace)); Utils.CheckAndCleanDirectory(new File(sapforTasksPackage_2023.workspace));
Utils.CheckAndCleanDirectory(new File(sapforTasksPackage_2023.workspace, "state"));
sapfor = new File(sapforTasksPackage_2023.workspace, "SAPFOR_F.exe"); //развилка на линукс sapfor = new File(sapforTasksPackage_2023.workspace, "SAPFOR_F.exe"); //развилка на линукс
ShowMessage2("Копирование SAPFOR"); ShowMessage2("Копирование SAPFOR");
FileUtils.copyFile(Current.getSapfor().getFile(), sapfor); FileUtils.copyFile(Current.getSapfor().getFile(), sapfor);
@@ -282,10 +281,12 @@ public class StartSapforTests extends Pass_2021<Vector<SapforTasksPackage_2023>>
} }
@Override @Override
protected void performDone() throws Exception { protected void performDone() throws Exception {
//тут должен быть планировщик и очередь пакетов. отдельной нитью. //тут должен быть планировщик и очередь пакетов. отдельной нитью.
for (SapforTasksPackage_2023 sapforTasksPackage_2023 : target) { for (SapforTasksPackage_2023 sapforTasksPackage_2023 : target) {
File workspaceFile = new File(sapforTasksPackage_2023.workspace); File workspaceFile = new File(sapforTasksPackage_2023.workspace);
Utils.startScript(workspaceFile, workspaceFile, "start", "java -jar VisualSapfor.jar"); // Utils.startScript(workspaceFile, workspaceFile, "start", "java -jar VisualSapfor.jar");
Utils.startScript_(workspaceFile, workspaceFile, "start", "java -jar VisualSapfor.jar");
} }
} }
@Override @Override