рефакторинг бд файлов тестов.
This commit is contained in:
2025-03-20 17:48:18 +03:00
parent 3f4ef5f198
commit 0b5f8c6ec7
22 changed files with 374 additions and 359 deletions

View File

@@ -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);
//--

View File

@@ -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();
}
}

View File

@@ -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);
}
}

View File

@@ -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();