++
рефакторинг бд файлов тестов.
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);
|
||||
//--
|
||||
|
||||
Reference in New Issue
Block a user