++
рефакторинг бд файлов тестов.
This commit is contained in:
@@ -6,11 +6,9 @@ import Common.Visual.Windows.Dialog.VDirectoryChooser;
|
||||
import _VisualDVM.Constants;
|
||||
import _VisualDVM.Global;
|
||||
import _VisualDVM.Passes.PassCode;
|
||||
import _VisualDVM.ProjectData.Files.ProjectFile;
|
||||
import _VisualDVM.TestingSystem.Common.Group.Group;
|
||||
import _VisualDVM.TestingSystem.Common.Test.Json.TestFileJson;
|
||||
import _VisualDVM.TestingSystem.Common.Test.Json.TestFilesJson;
|
||||
import _VisualDVM.TestingSystem.Common.Test.Test;
|
||||
import _VisualDVM.TestingSystem.Common.TestFile.TestFile;
|
||||
import _VisualDVM.Utils;
|
||||
import org.apache.commons.io.FileUtils;
|
||||
|
||||
@@ -23,7 +21,7 @@ public class CreateTestFromDirectory extends Pass<Test> {
|
||||
boolean from_files_chooser = false;
|
||||
Vector<File> files = null;
|
||||
//--
|
||||
Vector<ProjectFile> project_files = new Vector<>();
|
||||
Vector<TestFile> testFiles = new Vector<>();
|
||||
@Override
|
||||
public String getIconPath() {
|
||||
return "/icons/OpenProject.png";
|
||||
@@ -106,7 +104,7 @@ public class CreateTestFromDirectory extends Pass<Test> {
|
||||
return false;
|
||||
}
|
||||
//---
|
||||
project_files = new Vector<>();
|
||||
testFiles = new Vector<>();
|
||||
//--
|
||||
for (File file : files) {
|
||||
//-----
|
||||
@@ -118,22 +116,22 @@ public class CreateTestFromDirectory extends Pass<Test> {
|
||||
}
|
||||
} else if (file.isFile() && !Utils_.ContainsCyrillic(file.getName()) && !Utils_.ContainsForbiddenName(file.getName())) {
|
||||
//если файл. все недопустимые файлы просто игнорируются.
|
||||
ProjectFile projectFile = new ProjectFile(file);
|
||||
if (isNotExcluded(projectFile)) {
|
||||
switch (projectFile.fileType) {
|
||||
TestFile testFile = new TestFile(file);
|
||||
if (isNotExcluded(testFile)) {
|
||||
switch (testFile.fileType) {
|
||||
case program:
|
||||
if (projectFile.languageName.equals(group.language)) {
|
||||
if (testFile.languageName.equals(group.language)) {
|
||||
active_programs++;
|
||||
project_files.add(projectFile);
|
||||
testFiles.add(testFile);
|
||||
} else
|
||||
other_project_files++;
|
||||
break;
|
||||
case header:
|
||||
headers++;
|
||||
project_files.add(projectFile);
|
||||
testFiles.add(testFile);
|
||||
break;
|
||||
case none:
|
||||
project_files.add(projectFile);
|
||||
testFiles.add(testFile);
|
||||
other_project_files++;
|
||||
break;
|
||||
default:
|
||||
@@ -153,7 +151,7 @@ public class CreateTestFromDirectory extends Pass<Test> {
|
||||
Log.Writeln_("Папка не содержит ни одной программы на языке " + group.language.getDescription() + ".");
|
||||
return false;
|
||||
}
|
||||
if (project_files.isEmpty()) {
|
||||
if (testFiles.isEmpty()) {
|
||||
Log.Writeln_("В папке не найдено файлов с допустимыми расширениями для языка " +
|
||||
group.language.getDescription() + "\n" +
|
||||
group.language.PrintExtensions()
|
||||
@@ -162,16 +160,10 @@ public class CreateTestFromDirectory extends Pass<Test> {
|
||||
//----
|
||||
if (!initTarget()) return false;
|
||||
//----
|
||||
TestFilesJson filesJson = new TestFilesJson();
|
||||
Vector<String> filesNames = new Vector<>();
|
||||
for (ProjectFile projectFile : project_files) {
|
||||
filesNames.add(projectFile.file.getName());
|
||||
filesJson.values.add(new TestFileJson(projectFile));
|
||||
}
|
||||
target.packedFilesJson = Utils_.gson.toJson(filesJson);
|
||||
target.files = new Vector<>(testFiles);
|
||||
return true;
|
||||
}
|
||||
public boolean isNotExcluded(ProjectFile projectFile) {
|
||||
public boolean isNotExcluded(TestFile testFile) {
|
||||
return true;
|
||||
}
|
||||
//-
|
||||
@@ -183,10 +175,13 @@ public class CreateTestFromDirectory extends Pass<Test> {
|
||||
//- создать бд.
|
||||
FileUtils.forceMkdir(tempProject);
|
||||
//--
|
||||
for (ProjectFile projectFile : project_files) {
|
||||
File dst = new File(tempProject, projectFile.file.getName());
|
||||
FileUtils.copyFile(projectFile.file, dst);
|
||||
for (TestFile testFile : testFiles) {
|
||||
File src = new File(dir, testFile.name);
|
||||
File dst = new File(tempProject, testFile.name);
|
||||
FileUtils.copyFile(src, dst);
|
||||
}
|
||||
target.files = new Vector<>();
|
||||
target.files.addAll(testFiles);
|
||||
//---
|
||||
Utils.ClearProjectData(tempProject);
|
||||
//--
|
||||
|
||||
@@ -4,19 +4,19 @@ import Common.Passes.PassException;
|
||||
import Common.Utils.Utils_;
|
||||
import _VisualDVM.Global;
|
||||
import _VisualDVM.ProjectData.Files.FileType;
|
||||
import _VisualDVM.ProjectData.Files.ProjectFile;
|
||||
import _VisualDVM.TestingSystem.Common.Group.Group;
|
||||
import _VisualDVM.TestingSystem.Common.Test.Json.TestFileJson;
|
||||
import _VisualDVM.TestingSystem.Common.Test.Json.TestFilesJson;
|
||||
import _VisualDVM.TestingSystem.Common.Test.Test;
|
||||
import _VisualDVM.TestingSystem.Common.TestFile.TestFile;
|
||||
import _VisualDVM.Utils;
|
||||
import org.apache.commons.io.FileUtils;
|
||||
|
||||
import java.io.File;
|
||||
import java.util.Vector;
|
||||
public class CreateTestFromFile extends Pass<Test> {
|
||||
//----
|
||||
Group group;
|
||||
ProjectFile projectFile;
|
||||
TestFile testFile;
|
||||
File file;
|
||||
//----
|
||||
@Override
|
||||
protected boolean needsAnimation() {
|
||||
@@ -32,20 +32,20 @@ public class CreateTestFromFile extends Pass<Test> {
|
||||
}
|
||||
@Override
|
||||
protected boolean canStart(Object... args) throws Exception {
|
||||
projectFile = null;
|
||||
File file_in = (File) args[0];
|
||||
testFile = null;
|
||||
file = (File) args[0];
|
||||
group = (Group) args[1];
|
||||
//--
|
||||
if (Utils_.ContainsCyrillic(file_in.getName()) || Utils_.ContainsForbiddenName(file_in.getName())) {
|
||||
Log.Writeln_("Имя файла " + Utils_.Brackets(file_in.getName())
|
||||
if (Utils_.ContainsCyrillic(file.getName()) || Utils_.ContainsForbiddenName(file.getName())) {
|
||||
Log.Writeln_("Имя файла " + Utils_.Brackets(file.getName())
|
||||
+ " содержит запрещённые символы " +
|
||||
Utils_.printAllForbiddenCharacters() + ", или кириллицу.");
|
||||
return false;
|
||||
}
|
||||
//--
|
||||
projectFile = new ProjectFile(file_in);
|
||||
if (!projectFile.fileType.equals(FileType.program) || !projectFile.languageName.equals(group.language)) {
|
||||
Log.Writeln_("Не удалось распознать файл " + Utils_.Brackets(file_in.getName()) +
|
||||
testFile = new TestFile(file);
|
||||
if (!testFile.fileType.equals(FileType.program) || !testFile.languageName.equals(group.language)) {
|
||||
Log.Writeln_("Не удалось распознать файл " + Utils_.Brackets(file.getName()) +
|
||||
" как программу на языке " + group.language.getDescription());
|
||||
return false;
|
||||
}
|
||||
@@ -54,10 +54,10 @@ public class CreateTestFromFile extends Pass<Test> {
|
||||
target.sender_address = Global.mainModule.getAccount().email;
|
||||
target.sender_name = Global.mainModule.getAccount().name;
|
||||
target.group_id = group.id;
|
||||
target.description = Utils_.getNameWithoutExtension(file_in.getName());
|
||||
TestFilesJson filesJson = new TestFilesJson();
|
||||
filesJson.values.add(new TestFileJson(new ProjectFile(file_in)));
|
||||
target.packedFilesJson = Utils_.gson.toJson(filesJson);
|
||||
target.description = Utils_.getNameWithoutExtension(file.getName());
|
||||
target.files = new Vector<>();
|
||||
target.files.add(testFile);
|
||||
//--
|
||||
return true;
|
||||
}
|
||||
public File packTestCode() throws Exception {
|
||||
@@ -68,8 +68,8 @@ public class CreateTestFromFile extends Pass<Test> {
|
||||
//- создать бд.
|
||||
FileUtils.forceMkdir(tempProject);
|
||||
//--
|
||||
File dst = new File(tempProject, projectFile.file.getName());
|
||||
FileUtils.copyFile(projectFile.file, dst);
|
||||
File dst = new File(tempProject, testFile.name);
|
||||
FileUtils.copyFile(file, dst);
|
||||
//---
|
||||
Utils.ClearProjectData(tempProject);
|
||||
//--
|
||||
@@ -81,7 +81,7 @@ public class CreateTestFromFile extends Pass<Test> {
|
||||
}
|
||||
@Override
|
||||
protected void body() throws Exception {
|
||||
ShowMessage1(projectFile.file.getName());
|
||||
ShowMessage1(testFile.name);
|
||||
packTestCode();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,9 +2,9 @@ package _VisualDVM.Passes.All;
|
||||
import _VisualDVM.Current;
|
||||
import _VisualDVM.Global;
|
||||
import _VisualDVM.ProjectData.Files.FileState;
|
||||
import _VisualDVM.ProjectData.Files.ProjectFile;
|
||||
import _VisualDVM.ProjectData.Project.db_project_info;
|
||||
import _VisualDVM.TestingSystem.Common.Group.Group;
|
||||
import _VisualDVM.TestingSystem.Common.TestFile.TestFile;
|
||||
//добавить в текущую группу новый тест из текущего проекта.
|
||||
public class CreateTestFromProject extends CreateTestFromDirectory {
|
||||
db_project_info project;
|
||||
@@ -37,8 +37,8 @@ public class CreateTestFromProject extends CreateTestFromDirectory {
|
||||
return false;
|
||||
}
|
||||
@Override
|
||||
public boolean isNotExcluded(ProjectFile projectFile) {
|
||||
return project.db.files.containsKey(projectFile.file.getName()) &&
|
||||
!project.db.files.get(projectFile.file.getName()).state.equals(FileState.Excluded);
|
||||
public boolean isNotExcluded(TestFile testFile) {
|
||||
return project.db.files.containsKey(testFile.name) &&
|
||||
!project.db.files.get(testFile.name).state.equals(FileState.Excluded);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,6 +3,7 @@ import _VisualDVM.Global;
|
||||
import _VisualDVM.Passes.PassCode;
|
||||
import _VisualDVM.Passes.Server.TestingServerPass;
|
||||
import _VisualDVM.Repository.Server.ServerCode;
|
||||
import _VisualDVM.ServerObjectsCache.VisualCaches;
|
||||
|
||||
import java.io.Serializable;
|
||||
//заменить текущий тест на текущий проект.
|
||||
@@ -27,6 +28,12 @@ public class ReplaceTestProject extends CreateTestFromProject {
|
||||
Global.mainModule.getPass(PassCode.SynchronizeTests).Do();
|
||||
}
|
||||
@Override
|
||||
protected void showDone() throws Exception {
|
||||
super.showFinish();
|
||||
VisualCaches.RefreshCache(target);
|
||||
Global.testingServer.db.tests.getUI().Show(target.getPK());
|
||||
}
|
||||
@Override
|
||||
protected boolean initTarget() throws Exception {
|
||||
if (Global.testingServer.db.tests.getUI().CheckCurrent(Log)) {
|
||||
target = Global.testingServer.db.tests.getUI().getCurrent();
|
||||
|
||||
Reference in New Issue
Block a user