mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-12 16:35:45 +01:00
Execute updates in order
This commit is contained in:
@@ -5,4 +5,6 @@ import sonia.scm.plugin.ExtensionPoint;
|
|||||||
@ExtensionPoint
|
@ExtensionPoint
|
||||||
public interface UpdateStep {
|
public interface UpdateStep {
|
||||||
void doUpdate();
|
void doUpdate();
|
||||||
|
|
||||||
|
String getTargetVersion();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,17 +1,29 @@
|
|||||||
package sonia.scm;
|
package sonia.scm;
|
||||||
|
|
||||||
import sonia.scm.migration.UpdateStep;
|
import sonia.scm.migration.UpdateStep;
|
||||||
|
import sonia.scm.version.Version;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
|
import java.util.Comparator;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import static java.util.stream.Collectors.toList;
|
||||||
|
|
||||||
public class UpdateEngine {
|
public class UpdateEngine {
|
||||||
|
|
||||||
private final Set<UpdateStep> steps;
|
private final List<UpdateStep> steps;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public UpdateEngine(Set<UpdateStep> steps) {
|
public UpdateEngine(Set<UpdateStep> steps) {
|
||||||
this.steps = steps;
|
this.steps = sortSteps(steps);
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<UpdateStep> sortSteps(Set<UpdateStep> steps) {
|
||||||
|
Comparator<UpdateStep> compareByVersion = Comparator.comparing(step -> Version.parse(step.getTargetVersion()));
|
||||||
|
return steps.stream()
|
||||||
|
.sorted(compareByVersion.reversed())
|
||||||
|
.collect(toList());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void update() {
|
public void update() {
|
||||||
|
|||||||
48
scm-webapp/src/test/java/sonia/scm/UpdateEngineTest.java
Normal file
48
scm-webapp/src/test/java/sonia/scm/UpdateEngineTest.java
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
package sonia.scm;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import sonia.scm.migration.UpdateStep;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.LinkedHashSet;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
class UpdateEngineTest {
|
||||||
|
|
||||||
|
List<String> processedUpdates = new ArrayList<>();
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void shouldProcessStepsInCorrectOrder() {
|
||||||
|
LinkedHashSet<UpdateStep> updateSteps = new LinkedHashSet<>();
|
||||||
|
|
||||||
|
updateSteps.add(new FixedVersionUpdateStep("1.1.1"));
|
||||||
|
updateSteps.add(new FixedVersionUpdateStep("1.2.0"));
|
||||||
|
updateSteps.add(new FixedVersionUpdateStep("1.1.0"));
|
||||||
|
|
||||||
|
UpdateEngine updateEngine = new UpdateEngine(updateSteps);
|
||||||
|
updateEngine.update();
|
||||||
|
|
||||||
|
assertThat(processedUpdates)
|
||||||
|
.containsExactly("1.1.0", "1.1.1", "1.2.0");
|
||||||
|
}
|
||||||
|
|
||||||
|
class FixedVersionUpdateStep implements UpdateStep {
|
||||||
|
private final String version;
|
||||||
|
|
||||||
|
FixedVersionUpdateStep(String version) {
|
||||||
|
this.version = version;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getTargetVersion() {
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void doUpdate() {
|
||||||
|
processedUpdates.add(version);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user