Compare commits
6 Commits
f073663d1b
...
planner
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
a8b15d0eeb | ||
|
|
0e9404982f | ||
| 59060075e8 | |||
| d64f11e856 | |||
| b30f2b8eea | |||
| a70c93e66d |
8
.idea/workspace.xml
generated
8
.idea/workspace.xml
generated
@@ -9,9 +9,11 @@
|
|||||||
<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 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$/properties" beforeDir="false" afterPath="$PROJECT_DIR$/properties" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/properties" beforeDir="false" afterPath="$PROJECT_DIR$/properties" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/src/_VisualDVM/Constants.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/_VisualDVM/Constants.java" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/src/_VisualDVM/TestingSystem/DVM/DVMTasks/DVMCompilationTask.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/_VisualDVM/TestingSystem/DVM/DVMTasks/DVMCompilationTask.java" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/src/_VisualDVM/Visual/Menus/MainMenuBar/VisualiserSettingsMenu/VersionsComparisonMenu.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/_VisualDVM/Visual/Menus/MainMenuBar/VisualiserSettingsMenu/VersionsComparisonMenu.java" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/src/_VisualDVM/TestingSystem/DVM/DVMTasks/DVMRunTask.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/_VisualDVM/TestingSystem/DVM/DVMTasks/DVMRunTask.java" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/src/_VisualDVM/Visual/Windows/ComparisonForm.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/_VisualDVM/Visual/Windows/ComparisonForm.java" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/src/_VisualDVM/TestingSystem/DVM/DVMTasks/DVMTask.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/_VisualDVM/TestingSystem/DVM/DVMTasks/DVMTask.java" afterDir="false" />
|
||||||
|
<change beforePath="$PROJECT_DIR$/src/_VisualDVM/TestingSystem/DVM/RemoteDVMTestingPlanner.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/_VisualDVM/TestingSystem/DVM/RemoteDVMTestingPlanner.java" afterDir="false" />
|
||||||
|
<change beforePath="$PROJECT_DIR$/src/_VisualDVM/TestingSystem/DVM/json/RunTask_json.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/_VisualDVM/TestingSystem/DVM/json/RunTask_json.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" />
|
||||||
|
|||||||
10
properties
10
properties
@@ -27,15 +27,15 @@
|
|||||||
"LocalMakePathWindows": "C:\\MinGW\\msys\\1.0\\bin\\make.exe",
|
"LocalMakePathWindows": "C:\\MinGW\\msys\\1.0\\bin\\make.exe",
|
||||||
"PrecompilationFlags": " ",
|
"PrecompilationFlags": " ",
|
||||||
"CheckTestingIntervalSeconds": 10,
|
"CheckTestingIntervalSeconds": 10,
|
||||||
"AutoCheckTesting": false,
|
"AutoCheckTesting": true,
|
||||||
"EmailOnTestingProgress": true,
|
"EmailOnTestingProgress": true,
|
||||||
"CompleteCompilationOptions": true,
|
"CompleteCompilationOptions": true,
|
||||||
"CompleteRunEnvironments": true,
|
"CompleteRunEnvironments": true,
|
||||||
"CreateEthalonTasks": true,
|
"CreateEthalonTasks": true,
|
||||||
"ErasePackageWorkspace": true,
|
"ErasePackageWorkspace": false,
|
||||||
"lastMachineId": 13,
|
"lastMachineId": 1,
|
||||||
"lastUserId": 24,
|
"lastUserId": 17,
|
||||||
"lastCompilerId": 52,
|
"lastCompilerId": 15,
|
||||||
"RegisterOn": false,
|
"RegisterOn": false,
|
||||||
"SpacesOn": false,
|
"SpacesOn": false,
|
||||||
"EmptyLinesOn": false,
|
"EmptyLinesOn": false,
|
||||||
|
|||||||
@@ -3,8 +3,8 @@ import Common.Utils.Vector_;
|
|||||||
|
|
||||||
import java.util.Vector;
|
import java.util.Vector;
|
||||||
public class Constants {
|
public class Constants {
|
||||||
public static final int version = 1265;
|
public static final int version = 1266;
|
||||||
public static final int planner_version = 24;
|
public static final int planner_version = 26;
|
||||||
public static final int testingMaxKernels = 64;
|
public static final int testingMaxKernels = 64;
|
||||||
//--
|
//--
|
||||||
public static final String ApplicationFileName = "VisualSapfor.jar";
|
public static final String ApplicationFileName = "VisualSapfor.jar";
|
||||||
@@ -105,6 +105,7 @@ public class Constants {
|
|||||||
"starter.cpp",
|
"starter.cpp",
|
||||||
"launcher.cpp",
|
"launcher.cpp",
|
||||||
//--
|
//--
|
||||||
|
"json.hpp",
|
||||||
"Array.h",
|
"Array.h",
|
||||||
"CompilationSupervisor.h",
|
"CompilationSupervisor.h",
|
||||||
"CompilationTask.h",
|
"CompilationTask.h",
|
||||||
|
|||||||
@@ -200,13 +200,18 @@ public class DVMPackage extends TestingPackage<DVMPackage_json> {
|
|||||||
return flags_in;
|
return flags_in;
|
||||||
}
|
}
|
||||||
public static String completeEnvironments(String environmentsSet_in) {
|
public static String completeEnvironments(String environmentsSet_in) {
|
||||||
|
if (environmentsSet_in.isEmpty()){
|
||||||
|
return "DVMH_NO_DIRECT_COPY=" + Utils_.DQuotes("1")+" "+ "DVMH_SET_AFFINITY="+Utils_.DQuotes("0");
|
||||||
|
}
|
||||||
|
//-
|
||||||
|
String res = environmentsSet_in;
|
||||||
if (!environmentsSet_in.contains("DVMH_NO_DIRECT_COPY")){
|
if (!environmentsSet_in.contains("DVMH_NO_DIRECT_COPY")){
|
||||||
if (environmentsSet_in.isEmpty())
|
res+=" DVMH_NO_DIRECT_COPY=" + Utils_.DQuotes("1");
|
||||||
return "DVMH_NO_DIRECT_COPY=" + Utils_.DQuotes("1");
|
}
|
||||||
else
|
if (!environmentsSet_in.contains("DVMH_SET_AFFINITY")){
|
||||||
return environmentsSet_in + " " + "DVMH_NO_DIRECT_COPY=" + Utils_.DQuotes("1");
|
res+=" DVMH_SET_AFFINITY=" + Utils_.DQuotes("0");
|
||||||
} else
|
}
|
||||||
return environmentsSet_in;
|
return res;
|
||||||
}
|
}
|
||||||
@Override
|
@Override
|
||||||
public Class getJsonClass() {
|
public Class getJsonClass() {
|
||||||
|
|||||||
@@ -19,13 +19,4 @@ public class DVMCompilationTask extends DVMTask {
|
|||||||
maxtime = configuration.c_maxtime;
|
maxtime = configuration.c_maxtime;
|
||||||
}
|
}
|
||||||
//--
|
//--
|
||||||
@Override
|
|
||||||
public Vector<String> pack(Object arg) {
|
|
||||||
Vector<String> res = new Vector<>();
|
|
||||||
res.add(String.valueOf(id)); //1
|
|
||||||
res.add(String.valueOf(maxtime)); //2
|
|
||||||
res.add(String.valueOf(test_id)); //3
|
|
||||||
res.add(arg.toString().replace("\n", "|")); //4
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -90,19 +90,6 @@ public class DVMRunTask extends DVMTask {
|
|||||||
args = rt.args;
|
args = rt.args;
|
||||||
}
|
}
|
||||||
//-
|
//-
|
||||||
@Override
|
|
||||||
public Vector<String> pack(Object arg) {
|
|
||||||
Vector<String> res = new Vector<>();
|
|
||||||
res.add(String.valueOf(id)); //1
|
|
||||||
res.add(String.valueOf(maxtime)); //2
|
|
||||||
res.add(String.valueOf(dvmcompilationtask_id)); //3
|
|
||||||
res.add(matrix); //4
|
|
||||||
res.add(environments); //5
|
|
||||||
res.add(usr_par.replace("\n", "|")); //6
|
|
||||||
res.add(args); //7
|
|
||||||
res.add(String.valueOf(kernels)); //8
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
public String getEnvironments() {
|
public String getEnvironments() {
|
||||||
return environments.replace("\n", ";");
|
return environments.replace("\n", ";");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -83,9 +83,6 @@ public class DVMTask extends iDBObject {
|
|||||||
"results",
|
"results",
|
||||||
String.valueOf(id)).toFile();
|
String.valueOf(id)).toFile();
|
||||||
}
|
}
|
||||||
public Vector<String> pack(Object arg) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
public String getResultFile(File resultFile) {
|
public String getResultFile(File resultFile) {
|
||||||
String res = "";
|
String res = "";
|
||||||
if (dvm_package_id == CommonConstants.Nan) res = "задача ещё не выполнялась";
|
if (dvm_package_id == CommonConstants.Nan) res = "задача ещё не выполнялась";
|
||||||
|
|||||||
@@ -7,6 +7,10 @@ import _VisualDVM.Passes.All.UnzipFolderPass;
|
|||||||
import _VisualDVM.TestingSystem.Common.TasksPackageState;
|
import _VisualDVM.TestingSystem.Common.TasksPackageState;
|
||||||
import _VisualDVM.TestingSystem.DVM.DVMTasks.DVMCompilationTask;
|
import _VisualDVM.TestingSystem.DVM.DVMTasks.DVMCompilationTask;
|
||||||
import _VisualDVM.TestingSystem.DVM.DVMTasks.DVMRunTask;
|
import _VisualDVM.TestingSystem.DVM.DVMTasks.DVMRunTask;
|
||||||
|
import _VisualDVM.TestingSystem.DVM.json.DVMCompilationPackage_json;
|
||||||
|
import _VisualDVM.TestingSystem.DVM.json.CompilationTask_json;
|
||||||
|
import _VisualDVM.TestingSystem.DVM.json.DVMRunPackage_json;
|
||||||
|
import _VisualDVM.TestingSystem.DVM.json.RunTask_json;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
@@ -71,19 +75,26 @@ public class RemoteDVMTestingPlanner extends DVMTestingPlanner {
|
|||||||
//создать папку для пакета.
|
//создать папку для пакета.
|
||||||
user.connection.RMDIR(packageRemoteWorkspace.full_name);
|
user.connection.RMDIR(packageRemoteWorkspace.full_name);
|
||||||
user.connection.sftpChannel.mkdir(packageRemoteWorkspace.full_name);
|
user.connection.sftpChannel.mkdir(packageRemoteWorkspace.full_name);
|
||||||
|
//--
|
||||||
|
DVMCompilationPackage_json compilationPackage_json = new DVMCompilationPackage_json();
|
||||||
|
DVMRunPackage_json runPackage_json = new DVMRunPackage_json();
|
||||||
//положить туда запакованные тексты задач.
|
//положить туда запакованные тексты задач.
|
||||||
Vector<String> compilationLines = new Vector<>();
|
|
||||||
Vector<String> runLines = new Vector<>();
|
|
||||||
for (DVMCompilationTask compilationTask : testingPackage.package_json.compilationTasks) {
|
for (DVMCompilationTask compilationTask : testingPackage.package_json.compilationTasks) {
|
||||||
String makefileText = generateMakefile(tests.get(compilationTask.test_id), compilationTask.language, testingPackage.drv, compilationTask.flags);
|
String makefileText = generateMakefile(tests.get(compilationTask.test_id), compilationTask.language, testingPackage.drv, compilationTask.flags);
|
||||||
compilationLines.addAll(compilationTask.pack(makefileText));
|
//--
|
||||||
for (DVMRunTask runTask : compilationTask.runTasks)
|
compilationPackage_json.tasks.add(new CompilationTask_json(compilationTask, makefileText));
|
||||||
runLines.addAll(runTask.pack(null));
|
//--
|
||||||
|
for (DVMRunTask runTask : compilationTask.runTasks) {
|
||||||
|
//--
|
||||||
|
runPackage_json.tasks.add(new RunTask_json(runTask));
|
||||||
}
|
}
|
||||||
RemoteFile compilationPackage = new RemoteFile(packageRemoteWorkspace, "compilationTasks");
|
}
|
||||||
RemoteFile runPackage = new RemoteFile(packageRemoteWorkspace, "runTasks");
|
//--
|
||||||
user.connection.writeToFile(String.join("\n", compilationLines) + "\n", compilationPackage);
|
RemoteFile compilationFile_json = new RemoteFile(packageRemoteWorkspace, "compilationTasks.json");
|
||||||
user.connection.writeToFile(String.join("\n", runLines) + "\n", runPackage);
|
RemoteFile runFile_json = new RemoteFile(packageRemoteWorkspace, "runTasks.json");
|
||||||
|
//--
|
||||||
|
user.connection.writeToFile(Utils_.gson.toJson(compilationPackage_json),compilationFile_json);
|
||||||
|
user.connection.writeToFile(Utils_.gson.toJson(runPackage_json), runFile_json);
|
||||||
// --
|
// --
|
||||||
user.connection.MKDIR(new RemoteFile(packageRemoteWorkspace, "state"));
|
user.connection.MKDIR(new RemoteFile(packageRemoteWorkspace, "state"));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,15 @@
|
|||||||
|
package _VisualDVM.TestingSystem.DVM.json;
|
||||||
|
import _VisualDVM.TestingSystem.DVM.DVMTasks.DVMCompilationTask;
|
||||||
|
import com.google.gson.annotations.Expose;
|
||||||
|
public class CompilationTask_json extends Task_json {
|
||||||
|
@Expose
|
||||||
|
public String test_name; //-
|
||||||
|
@Expose
|
||||||
|
public String makefile_text; //res.add(arg.toString().replace("\n", "|")); //4 todo в планировщике убрать шифровку
|
||||||
|
//--
|
||||||
|
public CompilationTask_json(DVMCompilationTask task, String makefile_text_in){
|
||||||
|
super(task);
|
||||||
|
test_name = String.valueOf(task.test_id);
|
||||||
|
makefile_text = makefile_text_in;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
package _VisualDVM.TestingSystem.DVM.json;
|
||||||
|
public class DVMCompilationPackage_json extends DVMPackage_json<CompilationTask_json> {
|
||||||
|
}
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
package _VisualDVM.TestingSystem.DVM.json;
|
||||||
|
import com.google.gson.annotations.Expose;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Vector;
|
||||||
|
public class DVMPackage_json<T extends Task_json> {
|
||||||
|
@Expose
|
||||||
|
public List<T> tasks = new Vector<>();
|
||||||
|
}
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
package _VisualDVM.TestingSystem.DVM.json;
|
||||||
|
public class DVMRunPackage_json extends DVMPackage_json<RunTask_json>{
|
||||||
|
}
|
||||||
26
src/_VisualDVM/TestingSystem/DVM/json/RunTask_json.java
Normal file
26
src/_VisualDVM/TestingSystem/DVM/json/RunTask_json.java
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
package _VisualDVM.TestingSystem.DVM.json;
|
||||||
|
import _VisualDVM.TestingSystem.DVM.DVMTasks.DVMRunTask;
|
||||||
|
import com.google.gson.annotations.Expose;
|
||||||
|
public class RunTask_json extends Task_json {
|
||||||
|
@Expose
|
||||||
|
public int cores;
|
||||||
|
@Expose
|
||||||
|
public int compilation_task_id;
|
||||||
|
@Expose
|
||||||
|
public String matrix;
|
||||||
|
@Expose
|
||||||
|
public String args;
|
||||||
|
@Expose
|
||||||
|
public String environments;
|
||||||
|
@Expose
|
||||||
|
public String usr_par; //- usr_par.replace("\n", "|") todo в планировщике убрать шифровку.
|
||||||
|
public RunTask_json(DVMRunTask task){
|
||||||
|
super(task);
|
||||||
|
cores = task.kernels;
|
||||||
|
compilation_task_id = task.dvmcompilationtask_id;
|
||||||
|
matrix = task.matrix;
|
||||||
|
args = task.args;
|
||||||
|
environments = task.environments;
|
||||||
|
usr_par = task.usr_par;
|
||||||
|
}
|
||||||
|
}
|
||||||
13
src/_VisualDVM/TestingSystem/DVM/json/Task_json.java
Normal file
13
src/_VisualDVM/TestingSystem/DVM/json/Task_json.java
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package _VisualDVM.TestingSystem.DVM.json;
|
||||||
|
import _VisualDVM.TestingSystem.DVM.DVMTasks.DVMTask;
|
||||||
|
import com.google.gson.annotations.Expose;
|
||||||
|
public class Task_json {
|
||||||
|
@Expose
|
||||||
|
public int id; //-
|
||||||
|
@Expose
|
||||||
|
public int maxtime;
|
||||||
|
public Task_json(DVMTask task){
|
||||||
|
id = task.id;
|
||||||
|
maxtime = task.maxtime;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -56,7 +56,7 @@ public:
|
|||||||
environments = Utils::getValue<string>(data, "environments");
|
environments = Utils::getValue<string>(data, "environments");
|
||||||
usr_par = Utils::getValue<string>(data, "usr_par");
|
usr_par = Utils::getValue<string>(data, "usr_par");
|
||||||
args = Utils::getValue<string>(data, "args");
|
args = Utils::getValue<string>(data, "args");
|
||||||
kernels = Utils::getValue<int>(data, "kernels");
|
kernels = Utils::getValue<int>(data, "cores");
|
||||||
//todo setStartCommand
|
//todo setStartCommand
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
25
|
27
|
||||||
|
|||||||
Reference in New Issue
Block a user