Skip to content

Commit

Permalink
O3-3434: SDK Command: Remove dependencies from distro.properties (#289)
Browse files Browse the repository at this point in the history
  • Loading branch information
wikumChamith authored Aug 28, 2024
1 parent 1747463 commit 8be79d8
Show file tree
Hide file tree
Showing 3 changed files with 124 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
package org.openmrs.maven.plugins;

import org.apache.maven.plugin.MojoExecutionException;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.openmrs.maven.plugins.model.DistroProperties;
import org.openmrs.maven.plugins.utility.DistroHelper;

import java.io.File;

import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;

public class RemoveDependencyTest extends AbstractSdkIntegrationTest {

private String distroFile;


private DistroProperties originalProperties;

@Before
public void setUp() {
distroFile = testDirectory + File.separator + "openmrs-distro.properties";
originalProperties = DistroHelper.getDistroPropertiesFromFile(new File(distroFile));
}

@Test
public void shouldRemoveExistingDependency() throws Exception {
DistroProperties distroProperties = DistroHelper.getDistroPropertiesFromFile(new File(distroFile));
assertNotNull(distroProperties);

assertTrue(distroProperties.getAllKeys().contains("omod.uicommons"));

addTaskParam("distro", distroFile);
addTaskParam("property", "omod.uicommons");

executeTask("remove");
assertSuccess();

distroProperties = DistroHelper.getDistroPropertiesFromFile(new File(distroFile));
assertFalse(distroProperties.getAllKeys().contains("omod.uicommons"));
}

@After
public void reset() throws MojoExecutionException {
originalProperties.saveTo(new File(distroFile).getParentFile());
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
package org.openmrs.maven.plugins;

import org.apache.commons.lang.StringUtils;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.MojoFailureException;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import org.openmrs.maven.plugins.model.DistroProperties;

import java.io.File;
import java.util.ArrayList;

@Mojo(name = "remove", requiresProject = false)
public class RemoveDependency extends AbstractTask {

/**
* Path to the openmrs-distro.properties file to modify
*/
@Parameter(property = "distro")
private String distro;

/**
* Name of the property you want to remove
*/
@Parameter(property = "property")
private String property;

@Override
public void executeTask() throws MojoExecutionException, MojoFailureException {

if (distro == null) {
File userDir = new File(System.getProperty("user.dir"));
File distroFile = new File(userDir, DistroProperties.DISTRO_FILE_NAME);
if (distroFile.exists()) {
distro = distroFile.getAbsolutePath();
} else {
throw new MojoFailureException("Please specify a distro file");
}
}

DistroProperties properties = null;

if (StringUtils.isNotBlank(distro)) {
properties = distroHelper.resolveDistroPropertiesForStringSpecifier(distro, versionsHelper);

}

if (properties == null) {
throw new MojoFailureException("Invalid distro file");
}

if (StringUtils.isBlank(property)) {
property = wizard.promptForMissingValueWithOptions("Enter the property you want to remove",
null, null, new ArrayList<>(properties.getPropertyNames()));
}

if (StringUtils.isNotBlank(property)) {
properties.removeProperty(property);
properties.saveTo(new File(distro).getParentFile());
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -271,6 +271,17 @@ public List<String> getExclusions() {
return Arrays.asList(exclusions.split(","));
}

public Set<String> getPropertyNames() {
return properties.stringPropertyNames();
}

public void removeProperty(String property) throws MojoExecutionException {
if (!properties.containsKey(property)) {
throw new MojoExecutionException("The property " + property + " was not found in the distro");
}
properties.remove(property);
}

private String getPlaceholderKey(String string){
int startIndex = string.indexOf("${")+2;
int endIndex = string.indexOf("}", startIndex);
Expand Down

0 comments on commit 8be79d8

Please sign in to comment.