Дополнил замену. Если файлы выделены, но не совпадают по именам с уже имеющимися в группе тестами, будут добавлены как новые тесты.

This commit is contained in:
2024-03-05 19:52:49 +03:00
parent a4bca9c33b
commit da3f624cf2
2 changed files with 33 additions and 12 deletions

2
.idea/workspace.xml generated
View File

@@ -7,7 +7,7 @@
</component>
<component name="ChangeListManager">
<list default="true" id="e42177c3-2328-4b27-8a01-35779b2beb99" name="Default Changelist" comment="">
<change beforePath="$PROJECT_DIR$/properties" beforeDir="false" afterPath="$PROJECT_DIR$/properties" afterDir="false" />
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
<change beforePath="$PROJECT_DIR$/src/Visual_DVM_2021/Passes/All/ReplaceTestsFromFiles.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/Visual_DVM_2021/Passes/All/ReplaceTestsFromFiles.java" afterDir="false" />
</list>
<option name="SHOW_DIALOG" value="false" />

View File

@@ -22,6 +22,7 @@ public class ReplaceTestsFromFiles extends TestingSystemPass<Vector<Test>> {
Group group;
LinkedHashMap<Integer, Test> oldTests;
Vector<Test> replaceTests;
Vector<Test> newTests;
//--
@Override
public String getIconPath() {
@@ -65,6 +66,7 @@ public class ReplaceTestsFromFiles extends TestingSystemPass<Vector<Test>> {
//--
oldTests = new LinkedHashMap<>();
Vector<String> testForReplaceNames = new Vector<>();
Vector<String> newTestsNames = new Vector<>();
//--
for (String name : filesByNames.keySet()) {
boolean exists = false;
@@ -77,6 +79,8 @@ public class ReplaceTestsFromFiles extends TestingSystemPass<Vector<Test>> {
break;
}
}
if (!exists)
newTestsNames.add(name);
}
//--
if (oldTests.size() == 0) {
@@ -84,7 +88,11 @@ public class ReplaceTestsFromFiles extends TestingSystemPass<Vector<Test>> {
return false;
}
//--
if (UI.Question("Тесты\n"+String.join("\n", testForReplaceNames)+"\nбудут заменены. Продолжить")){
if (UI.Question(
testForReplaceNames.size() + " тестов будет заменено,\n" +
newTestsNames.size() + " тестов будет добавлено.\n" +
"Продолжить"
)) {
replaceTests = new Vector<>();
Pass_2021 createTestPass = passes.get(PassCode_2021.CreateTestFromFile);
for (Test old_test : oldTests.values()) {
@@ -95,14 +103,27 @@ public class ReplaceTestsFromFiles extends TestingSystemPass<Vector<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 {