no message

This commit is contained in:
2024-10-14 12:14:01 +03:00
parent 3a29898d5f
commit 452c4c7268
466 changed files with 1255 additions and 1100 deletions

View File

@@ -0,0 +1,137 @@
package _VisualDVM.Passes.All;
import Common.Utils.Utils_;
import Common.Visual.UI_;
import _VisualDVM.Constants;
import _VisualDVM.Current;
import Common.Visual.Windows.Dialog.VFileChooser;
import _VisualDVM.Global;
import _VisualDVM.Utils;
import _VisualDVM.GlobalData.Settings.SettingName;
import _VisualDVM.Repository.Server.ServerCode;
import _VisualDVM.Repository.Server.ServerExchangeUnit_2021;
import _VisualDVM.TestingSystem.Common.Group.Group;
import _VisualDVM.TestingSystem.Common.Test.Test;
import _VisualDVM.Passes.PassCode;
import Common.Passes.Pass;
import _VisualDVM.Passes.Server.TestingSystemPass;
import java.io.File;
import java.util.LinkedHashMap;
import java.util.Vector;
public class ReplaceTestsFromFiles extends TestingSystemPass<Vector<Test>> {
VFileChooser fileChooser = new VFileChooser("Выберите файлы для замены тестов");
//--
Group group;
LinkedHashMap<Integer, Test> oldTests;
Vector<Test> replaceTests;
Vector<Test> newTests;
//--
@Override
public String getIconPath() {
return "/icons/Menu/Undo.png";
}
//-
@Override
protected boolean canStart(Object... args) throws Exception {
if (!Global.mainModule.Check(Log, Current.Group))
return false;
group = Global.mainModule.getGroup();
//--->>>
Utils.RestoreSelectedDirectory(fileChooser);
Vector<File> files = fileChooser.ShowMultiDialog();
//---------------------------------------------------------------
//--
File dir = fileChooser.getCurrentDirectory();
Global.mainModule.getPass(PassCode.UpdateSetting).Do(SettingName.ProjectsSearchDirectory, dir);
//---------------
if (dir.getName().equals(Constants.data)) {
Log.Writeln_(Utils_.Brackets(dir) + "\nявляется служебной папкой визуализатора!");
return false;
}
if (!Utils.validateProjectFile(dir, Log)) {
Log.Writeln_("Имя папки " + Utils_.Brackets(dir.getName()) + " содержит запрещённые символы "
+ Utils_.printAllForbiddenCharacters()
+ ", или кириллицу.");
return false;
}
if (files.isEmpty()) {
Log.Writeln_("Не выбрано ни одного файла.");
return false;
}
//-----------------------------------------
LinkedHashMap<String, File> filesByNames = new LinkedHashMap<>(); //выделенные файлы, сортированные по именам.
//--
for (File file : files) {
String name = Utils_.getNameWithoutExtension(file.getName()).toLowerCase();
if (!filesByNames.containsKey(name)) {
filesByNames.put(name, file);
}
}
//--
oldTests = new LinkedHashMap<>();
Vector<String> testForReplaceNames = new Vector<>();
Vector<String> newTestsNames = new Vector<>();
//--
for (String name : filesByNames.keySet()) {
boolean exists = false;
for (Test test : server.db.tests.Data.values()) {
if ((test.group_id == group.id) && test.description.equals(name)) {
exists = true;
//--
oldTests.put(test.id, test);
testForReplaceNames.add(name);
break;
}
}
if (!exists)
newTestsNames.add(name);
}
//--
if (oldTests.size() == 0) {
Log.Writeln_("Не найдено тестов на замену.");
return false;
}
//--
if (UI_.Question(
testForReplaceNames.size() + " тестов будет заменено,\n" +
newTestsNames.size() + " тестов будет добавлено.\n" +
"Продолжить"
)) {
replaceTests = new Vector<>();
Pass createTestPass = Global.mainModule.getPass(PassCode.CreateTestFromFile);
for (Test old_test : oldTests.values()) {
File file = filesByNames.get(old_test.description);
if (createTestPass.Do(file, group)) {
Test new_test = (Test) createTestPass.target;
replaceTests.add(new_test);
new_test.id = old_test.id;
}
}
//--
newTests = new Vector<>();
for (String name : newTestsNames) {
File file = filesByNames.get(name);
if (createTestPass.Do(file, group)) {
Test new_test = (Test) createTestPass.target;
newTests.add(new_test);
}
}
return true;
}
;
return false;
}
//-
@Override
protected void ServerAction() throws Exception {
if (!replaceTests.isEmpty())
Command(new ServerExchangeUnit_2021(ServerCode.ReplaceTestsCodes, null, replaceTests));
if (!newTests.isEmpty())
Command(new ServerExchangeUnit_2021(ServerCode.PublishObjects, null, newTests));
}
@Override
protected void performFinish() throws Exception {
super.performFinish();
Global.mainModule.getPass(PassCode.SynchronizeTests).Do();
}
}