рефакторинг.

реализовал добавление выделенных файлов в текущую группу, в качестве тестов.
This commit is contained in:
2023-12-02 15:19:05 +03:00
parent f71037eb26
commit 7304832b61
10 changed files with 158 additions and 69 deletions

View File

@@ -4,10 +4,9 @@ import Visual_DVM_2021.Passes.PassCode_2021;
public class TestsMenuBar extends DataMenuBar {
public TestsMenuBar() {
super("тесты",
//PassCode_2021.PublishTest,
PassCode_2021.CreateTestFromProject,
PassCode_2021.CreateTestFromDirectory,
PassCode_2021.CreateTestFromFile,
PassCode_2021.PublishTestsFromFiles, ///----------------------------
PassCode_2021.EditTest,
PassCode_2021.DownloadTest,
PassCode_2021.DeleteTest);

View File

@@ -1,8 +1,7 @@
package Common.UI.Menus_2023.VersionsMenuBar;
import Common.UI.Menus_2023.VisualiserMenuBar;
import Visual_DVM_2021.Passes.PassCode_2021;
public class VersionsMenuBar extends VisualiserMenuBar {
public VersionsMenuBar(){
addPasses(PassCode_2021.CreateTestsGroupFromSelectedVersions);
// addPasses(PassCode_2021.CreateTestsGroupFromSelectedVersions);
}
}

View File

@@ -1,16 +1,16 @@
package Visual_DVM_2021.Passes.All;
import Common.Constants;
import Common.Current;
import Common.Utils.Files.VDirectoryChooser;
import Common.Utils.Utils;
import GlobalData.Settings.SettingName;
import Visual_DVM_2021.Passes.PassCode_2021;
import Visual_DVM_2021.Passes.Pass_2021;
import Visual_DVM_2021.Passes.PublishTests;
import java.io.File;
import java.util.Arrays;
public class CreateGroupFromDirectory extends PublishTests {
@Override
protected PassCode_2021 getCreateTestCode() {
return null;
}
@Override
protected String getNoFilesMessage() {
return "ни одного файла";
}
/*
File dir = null;
VDirectoryChooser directoryChooser = new VDirectoryChooser("Выбор домашней папки группы");
@Override
@@ -66,4 +66,5 @@ public class CreateGroupFromDirectory extends PublishTests {
}
return true;
}
*/
}

View File

@@ -1,29 +1,27 @@
package Visual_DVM_2021.Passes.All;
import Common.Constants;
import Common.Current;
import Common.Utils.Files.VFileChooser;
import Common.Utils.Utils;
import GlobalData.Settings.SettingName;
import ProjectData.Files.FileType;
import ProjectData.Files.ProjectFile;
import ProjectData.LanguageName;
import Repository.Component.Sapfor.Sapfor;
import TestingSystem.Common.Group.Group;
import TestingSystem.Common.Test.Test;
import Visual_DVM_2021.Passes.PassCode_2021;
import Visual_DVM_2021.Passes.PassException;
import Visual_DVM_2021.Passes.Pass_2021;
import org.apache.commons.io.FileUtils;
import java.io.File;
public class CreateTestFromFile extends Pass_2021<Test> {
VFileChooser fileChooser = new VFileChooser("Выберите файл для создания теста");
//---
File file;
//----
Group group;
boolean from_file_chooser = false;
ProjectFile projectFile;
//---
//----
@Override
protected boolean needsAnimation() {
return true;
}
@Override
public String getIconPath() {
return "/icons/AddFile.png";
@@ -35,41 +33,27 @@ public class CreateTestFromFile extends Pass_2021<Test> {
@Override
protected boolean canStart(Object... args) throws Exception {
projectFile = null;
if (args.length == 0) {
from_file_chooser = true;
if (!Current.Check(Log, Current.Group))
return false;
group = Current.getGroup();
Utils.RestoreSelectedDirectory(fileChooser);
file = fileChooser.ShowDialog();
if (file == null) {
Log.Writeln_("Файл не выбран");
return false;
} else {
Pass_2021.passes.get(PassCode_2021.UpdateSetting).Do(SettingName.ProjectsSearchDirectory, file.getParent());
}
} else {
from_file_chooser = false;
file = (File) args[0];
group = (Group) args[1];
}
if (Utils.ContainsCyrillic(file.getName()) || Utils.ContainsForbiddenName(file.getName())) {
Log.Writeln_("Имя файла " + Utils.Brackets(file.getName()) + " содержит запрещённые символы " + Constants.all_forbidden_characters_string + ", или кириллицу.");
File file_in = (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()) + " содержит запрещённые символы " + Constants.all_forbidden_characters_string + ", или кириллицу.");
return false;
}
//если файл. все недопустимые файлы просто игнорируются.
projectFile = new ProjectFile(file);
//--
projectFile = new ProjectFile(file_in);
if (!projectFile.fileType.equals(FileType.program) || !projectFile.languageName.equals(group.language)) {
Log.Writeln_("Не удалось распознать файл как программу на языке " + group.language.getDescription());
Log.Writeln_("Не удалось распознать файл " +Utils.Brackets(file_in.getName()) +
" как программу на языке " + group.language.getDescription());
return false;
}
//-----
//--
target = new Test();
target.sender_address = Current.getAccount().email;
target.sender_name = Current.getAccount().name;
target.group_id = group.id;
target.description = Utils.getNameWithoutExtension(file.getName());
target.files = file.getName();
target.description = Utils.getNameWithoutExtension(file_in.getName());
target.files = file_in.getName();
return true;
}
public File packTestCode() throws Exception {
@@ -93,23 +77,11 @@ public class CreateTestFromFile extends Pass_2021<Test> {
}
@Override
protected void body() throws Exception {
ShowMessage1(file.getName());
ShowMessage1(projectFile.file.getName());
//--
File tempProject = packTestCode(); //создание копии папки, и архивация.
//-- получить размерность консольным сапфором. папка уже отправлена и чистить ее не нужно!!
File tempProject = packTestCode();
ShowMessage2("Синтаксический анализ и определение размерности");
if (group.language == LanguageName.fortran) {//если не определит, будут нули.
if (group.language == LanguageName.fortran)
Sapfor.getMinMaxDim(Sapfor.getTempCopy(Current.getSapfor().getFile()), tempProject, target);
}
}
@Override
protected boolean validate() {
return Log.isEmpty();
}
@Override
protected void performDone() throws Exception {
super.performDone();
if (from_file_chooser)
passes.get(PassCode_2021.PublishTest).Do(target);
}
}

View File

@@ -5,10 +5,10 @@ import Common.UI.UI;
import Common.Utils.Utils;
import ProjectData.Project.db_project_info;
import Visual_DVM_2021.Passes.PassCode_2021;
import Visual_DVM_2021.Passes.PublishTests;
import Visual_DVM_2021.Passes.PublishTests_OLD;
import java.util.Vector;
public class CreateTestsGroupFromSelectedVersions extends PublishTests {
public class CreateTestsGroupFromSelectedVersions extends PublishTests_OLD {
Vector<db_project_info> versions = new Vector<>();
@Override
public String getIconPath() {

View File

@@ -0,0 +1,68 @@
package Visual_DVM_2021.Passes.All;
import Common.UI.UI;
import Common.Utils.Utils;
import Repository.Server.ServerCode;
import Repository.Server.ServerExchangeUnit_2021;
import TestingSystem.Common.Group.Group;
import TestingSystem.Common.Test.Test;
import Visual_DVM_2021.Passes.PassCode_2021;
import Visual_DVM_2021.Passes.Pass_2021;
import Visual_DVM_2021.Passes.Server.TestingSystemPass;
import java.io.File;
import java.util.Vector;
public abstract class PublishTests extends TestingSystemPass<Vector<Test>> {
protected Group group;
//----
@Override
public String getButtonText() {
return "";
}
@Override
protected boolean needsAnimation() {
return true;
}
@Override
protected void ServerAction() throws Exception {
Command(new ServerExchangeUnit_2021(ServerCode.PublishObjects, null, target));
}
@Override
protected void performFinish() throws Exception {
super.performFinish();
passes.get(PassCode_2021.SynchronizeTests).Do();
}
@Override
protected void FocusResult() {
UI.getMainWindow().FocusTests();
}
//--
protected abstract PassCode_2021 getCreateTestCode();
protected abstract String getNoFilesMessage();
//--
@Override
protected boolean canStart(Object... args) throws Exception {
Vector<File> files = (Vector<File>) args[0];
group = (Group) args[1];
target = new Vector<>();
//---------------------
if (files.isEmpty()) {
Log.Writeln_("Не найдено " + getNoFilesMessage() + " для формирования тестов.");
return false;
}
//---
Pass_2021 createTestPass = passes.get(getCreateTestCode());
//---
for (File file : files) {
if (createTestPass.Do(file, group))
target.add((Test) createTestPass.target);
}
//---
if (target.isEmpty()) {
Log.Writeln_("Не удалось создать ни одного теста.");
return false;
}
//---
return UI.Question("В группу " + Utils.Brackets(group.description) +
"\nбудет добавлено " + target.size() + " тестов.\родолжить");
}
}

View File

@@ -0,0 +1,39 @@
package Visual_DVM_2021.Passes.All;
import Common.Current;
import Common.Utils.Files.VFileChooser;
import Common.Utils.Utils;
import GlobalData.Settings.SettingName;
import Visual_DVM_2021.Passes.PassCode_2021;
import Visual_DVM_2021.Passes.Pass_2021;
import java.io.File;
import java.util.Vector;
public class PublishTestsFromFiles extends PublishTests {
@Override
public String getIconPath() {
return "/icons/AddFile.png";
}
VFileChooser fileChooser = new VFileChooser("Выберите файл для создания теста");
@Override
protected PassCode_2021 getCreateTestCode() {
return PassCode_2021.CreateTestFromFile;
}
@Override
protected String getNoFilesMessage() {
return "ни одного файла";
}
@Override
protected boolean canStart(Object... args) throws Exception {
if (Current.Check(Log, Current.Group)){
Utils.RestoreSelectedDirectory(fileChooser);
Vector<File> files = fileChooser.ShowMultiDialog();
if (files.isEmpty()){
Log.Writeln_("Не выбрано ни одного файла.");
return false;
}
Pass_2021.passes.get(PassCode_2021.UpdateSetting).Do(SettingName.ProjectsSearchDirectory, fileChooser.getCurrentDirectory());
return super.canStart(files, Current.getGroup());
}
return false;
}
}

View File

@@ -302,12 +302,15 @@ public enum PassCode_2021 {
CreateTestFromProject,
SPF_RemoveComments,
CreateTestFromFile,
PublishTestsFromFiles,
//->
TestPass;
public String getDescription() {
switch (this) {
case Undefined:
return "?";
case PublishTestsFromFiles:
return "Добавить тесты из файлов к текущей группе";
case CreateTestFromFile:
return "Создать тест из файла";
case SPF_RemoveComments:

View File

@@ -10,7 +10,7 @@ import Visual_DVM_2021.Passes.Server.TestingSystemPass;
import java.io.File;
import java.util.Vector;
public abstract class PublishTests extends TestingSystemPass<Vector<Test>> {
public abstract class PublishTests_OLD extends TestingSystemPass<Vector<Test>> {
@Override
public String getButtonText() {
return "";
@@ -28,14 +28,14 @@ public abstract class PublishTests extends TestingSystemPass<Vector<Test>> {
protected boolean canStart(Object... args) throws Exception {
target = new Vector<>();
files = new Vector<>();
//--------------------------
group = null;
//--------------------------
if (!getGroup()) return false;
if (group == null) {
Log.Writeln_("Группа не выбрана.");
return false;
}
files = new Vector<>();
if (!findFiles()) return false;
if (files.isEmpty()) {
Log.Writeln_("Не найдено ни одной папки для формирования теста.");