2023-09-17 22:13:42 +03:00
|
|
|
package GlobalData.Tasks.RunTask;
|
2023-10-04 22:01:09 +03:00
|
|
|
import Common.Constants;
|
2023-09-17 22:13:42 +03:00
|
|
|
import Common.Current;
|
|
|
|
|
import Common.Global;
|
|
|
|
|
import Common.Utils.StringTemplate;
|
|
|
|
|
import Common.Utils.Utils;
|
|
|
|
|
import GlobalData.Compiler.CompilerType;
|
|
|
|
|
import GlobalData.RunConfiguration.RunConfiguration;
|
|
|
|
|
import GlobalData.Tasks.CompilationTask.CompilationTask;
|
|
|
|
|
import GlobalData.Tasks.Task;
|
|
|
|
|
import GlobalData.Tasks.TaskState;
|
|
|
|
|
import ProjectData.Project.db_project_info;
|
2023-11-17 00:04:21 +03:00
|
|
|
import TestingSystem.DVM.Tasks.TestRunTaskInterface;
|
2023-09-17 22:13:42 +03:00
|
|
|
import com.sun.org.glassfish.gmbal.Description;
|
|
|
|
|
import org.apache.commons.io.FileUtils;
|
|
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
|
import java.nio.file.Paths;
|
|
|
|
|
import java.util.List;
|
|
|
|
|
public class RunTask extends Task {
|
2023-09-29 21:46:08 +03:00
|
|
|
public int compilation_task_id = Constants.Nan; //нужна для бинарника
|
|
|
|
|
public int run_configuration_id = Constants.Nan;
|
2023-09-17 22:13:42 +03:00
|
|
|
@Description("DEFAULT ''")
|
|
|
|
|
public String last_sts_name = "";
|
|
|
|
|
@Description("DEFAULT 0")
|
|
|
|
|
public double CleanTime;
|
|
|
|
|
@Description("IGNORE")
|
|
|
|
|
public boolean hasDvmSts = false;
|
|
|
|
|
@Description("IGNORE")
|
|
|
|
|
public boolean hasGCOV = false;
|
|
|
|
|
//-------------------------------------
|
|
|
|
|
@Description("DEFAULT ''")
|
|
|
|
|
public String matrix = "";
|
|
|
|
|
//-------------------------------------
|
|
|
|
|
@Override
|
|
|
|
|
public void DropResults() throws Exception {
|
|
|
|
|
super.DropResults();
|
|
|
|
|
Utils.forceDeleteWithCheck(getLocalStsFile());
|
|
|
|
|
CleanTime = 0;
|
|
|
|
|
Global.db.Update(this);
|
|
|
|
|
}
|
|
|
|
|
@Override
|
|
|
|
|
public File getHome() {
|
|
|
|
|
return Global.RunTasksDirectory;
|
|
|
|
|
}
|
|
|
|
|
@Override
|
|
|
|
|
public String getFullCommand() {
|
|
|
|
|
return getRunConfiguration().getLaunchScriptText(getCompilationTask().binary_name, matrix);
|
|
|
|
|
}
|
|
|
|
|
//---------------------------------------
|
|
|
|
|
@Override
|
|
|
|
|
public boolean isVisible() {
|
|
|
|
|
return
|
|
|
|
|
Current.CheckID(Current.Machine, machine_id) &&
|
|
|
|
|
Current.CheckID(Current.User, user_id) &&
|
|
|
|
|
Current.CheckID(Current.RunConfiguration, run_configuration_id) &&
|
|
|
|
|
Current.HasProject() &&
|
|
|
|
|
belongsToProject(Current.getProject()) &&
|
|
|
|
|
Current.HasCompilationTask() &&
|
|
|
|
|
compilation_task_id == Current.getCompilationTask().id;
|
|
|
|
|
}
|
|
|
|
|
public RunConfiguration getRunConfiguration() {
|
|
|
|
|
return Global.db.runConfigurations.Data.get(run_configuration_id);
|
|
|
|
|
}
|
|
|
|
|
public CompilationTask getCompilationTask() {
|
|
|
|
|
return Global.db.compilationTasks.Data.get(compilation_task_id);
|
|
|
|
|
}
|
|
|
|
|
public void UpdateLastStsName(String file_name) {
|
|
|
|
|
if (!last_sts_name.equals(file_name)) {
|
|
|
|
|
last_sts_name = file_name;
|
|
|
|
|
try {
|
|
|
|
|
Global.db.Update(this);
|
|
|
|
|
} catch (Exception ex) {
|
|
|
|
|
Global.Log.PrintException(ex);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public File getLocalStsFile() {
|
|
|
|
|
return Paths.get(getLocalWorkspace().getAbsolutePath(), last_sts_name).toFile();
|
|
|
|
|
}
|
|
|
|
|
public File getLocalStsTextFile() {
|
|
|
|
|
return Paths.get(getLocalWorkspace().getAbsolutePath(), "statistic.txt").toFile();
|
|
|
|
|
}
|
|
|
|
|
public String getLocalStsText() {
|
|
|
|
|
return getTextResult(getLocalStsTextFile());
|
|
|
|
|
}
|
|
|
|
|
public void parseCleanTime() {
|
|
|
|
|
StringTemplate template = new StringTemplate("Time in seconds =", "");
|
|
|
|
|
String p = template.check_and_get_param(Utils.ReadAllText(getOutputFile()));
|
|
|
|
|
try {
|
|
|
|
|
if (p != null) CleanTime = Double.parseDouble(p);
|
|
|
|
|
} catch (Exception ex) {
|
|
|
|
|
Global.Log.PrintException(ex);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
@Override
|
|
|
|
|
public void AnalyzeOutFile(db_project_info project) throws Exception {
|
|
|
|
|
List<String> lines = FileUtils.readLines(getOutputFile());
|
|
|
|
|
if (lines.stream().anyMatch(TestRunTaskInterface::isCrushedLine)
|
|
|
|
|
) {
|
|
|
|
|
state = TaskState.Crushed;
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
//->>
|
|
|
|
|
//тест на корректность.
|
|
|
|
|
if (!lines.isEmpty() && lines.get(0).toUpperCase().contains("START OF ")) {
|
|
|
|
|
int complete = 0;
|
|
|
|
|
int errors = 0;
|
|
|
|
|
for (int i = 1; i < lines.size(); ++i) {
|
|
|
|
|
String line_ = lines.get(i).toUpperCase();
|
|
|
|
|
if (line_.endsWith("COMPLETE")) {
|
|
|
|
|
complete++;
|
|
|
|
|
} else if (line_.endsWith("ERROR")) {
|
|
|
|
|
errors++;
|
|
|
|
|
} else if (line_.contains("END OF")) {
|
|
|
|
|
if (errors > 0) state = TaskState.DoneWithErrors;
|
|
|
|
|
else if (complete > 0) state = TaskState.Done;
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
//тест на производительность.
|
|
|
|
|
StringTemplate stringTemplate = new StringTemplate("Verification =", "");
|
|
|
|
|
for (String line : lines) {
|
|
|
|
|
String param = stringTemplate.check_and_get_param(line);
|
|
|
|
|
if (param != null) {
|
|
|
|
|
switch (param) {
|
|
|
|
|
case "SUCCESSFUL":
|
|
|
|
|
state = TaskState.Done;
|
|
|
|
|
return;
|
|
|
|
|
case "UNSUCCESSFUL":
|
|
|
|
|
state = TaskState.DoneWithErrors;
|
|
|
|
|
return;
|
|
|
|
|
default:
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
@Override
|
|
|
|
|
public void AnalyzeErrorsFile(db_project_info project) throws Exception {
|
|
|
|
|
List<String> lines = FileUtils.readLines(getErrorsFile());
|
|
|
|
|
if (lines.stream().anyMatch(TestRunTaskInterface::isCrushedLine))
|
|
|
|
|
state = TaskState.Crushed;
|
|
|
|
|
}
|
|
|
|
|
@Override
|
|
|
|
|
public void Reset() {
|
|
|
|
|
super.Reset();
|
|
|
|
|
CleanTime = 0.0;
|
|
|
|
|
hasDvmSts = false;
|
|
|
|
|
hasGCOV = false;
|
|
|
|
|
}
|
|
|
|
|
public boolean hasDVMPar() {
|
|
|
|
|
RunConfiguration config = getRunConfiguration();
|
|
|
|
|
return
|
2023-09-29 21:46:08 +03:00
|
|
|
config.compiler_id != Constants.Nan &&
|
2023-09-17 22:13:42 +03:00
|
|
|
config.getCompiler().type.equals(CompilerType.dvm) &&
|
|
|
|
|
!config.getParList().isEmpty()
|
|
|
|
|
;
|
|
|
|
|
}
|
|
|
|
|
}
|