Skip to content
This repository has been archived by the owner on Sep 16, 2024. It is now read-only.

Commit

Permalink
#106 Now processing custom forest files
Browse files Browse the repository at this point in the history
  • Loading branch information
rjrudin committed Jul 19, 2016
1 parent fbc7511 commit aa96978
Show file tree
Hide file tree
Showing 7 changed files with 64 additions and 34 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
* Command for configuring - i.e. creating and setting - replica forests for existing databases and/or primary forests.
* It's normally easier to just specify the databases that you want to configure forest replicas for, but this command
* does provide the ability to configure replicas for specific forests.
*
*
* Very useful for the out-of-the-box forests such as Security, Schemas, App-Services, and Meters, which normally need
* replicas for failover in a cluster.
*/
Expand All @@ -38,7 +38,7 @@ public ConfigureForestReplicasCommand() {
/**
* Allows for the map of database names and counts to be configured as a comma-delimited string of the form:
* "dbName,replicaCount,dbName,replicaCount,etc".
*
*
* @param str
*/
public void setDatabaseNamesAndReplicaCountsAsString(String str) {
Expand Down Expand Up @@ -96,7 +96,7 @@ public void undo(CommandContext context) {
if (str != null) {
setDatabaseNamesAndReplicaCountsAsString(str);
}

DatabaseManager dbMgr = new DatabaseManager(context.getManageClient());
ForestManager forestMgr = new ForestManager(context.getManageClient());

Expand Down Expand Up @@ -132,7 +132,7 @@ protected void deleteReplicas(String forestName, ForestManager forestMgr) {
* For the given database, find all of its primary forests. Then for each primary forest, just call
* configureReplicaForests? And that should be smart enough to say - if the primary forest already has replicas,
* then don't do anything.
*
*
* @param databaseName
* @param replicaCount
* @param hostIds
Expand All @@ -151,7 +151,7 @@ protected void configureDatabaseReplicaForests(String databaseName, int replicaC
/**
* Creates forests as needed (they may already exists) and then sets those forests as the replicas for the given
* primaryForestName.
*
*
* @param forestIdOrName
* @param replicaCount
* @param hostIds
Expand All @@ -178,7 +178,7 @@ protected void configureReplicaForests(String forestIdOrName, int replicaCount,
if (!hostId.equals(primaryForestHostId)) {
for (int i = 0; i < replicaCount; i++) {
String name = forestIdOrName + "-" + resourceCounter;
forestMgr.createForestWithName(name, hostId);
forestMgr.createJsonForestWithName(name, hostId);
replicaNamesAndHostIds.put(name, hostId);
resourceCounter++;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,15 @@
import com.marklogic.appdeployer.command.AbstractCommand;
import com.marklogic.appdeployer.command.CommandContext;
import com.marklogic.appdeployer.command.SortOrderConstants;
import com.marklogic.mgmt.forests.ForestManager;

import java.io.File;

/**
* For each directory in the ml-config/forests directory, TODO.
* Use this command when you want precise control over the forests that are created for a database. It processes
* each directory under ml-config/forests (the name of the directory does not matter, but it makes sense to name
* it after the database that the forests belong to), and each file in a directory can have a single forest object
* or an array of forest objects.
*/
public class DeployCustomForestsCommand extends AbstractCommand {

Expand All @@ -26,9 +30,10 @@ public void execute(CommandContext context) {
}

protected void processDirectory(File dir, CommandContext context) {
ForestManager mgr = new ForestManager(context.getManageClient());
for (File f : listFilesInDirectory(dir)) {
logger.info("Processing: " + f.getAbsolutePath());
String payload = copyFileToString(f, context);
mgr.saveJsonForests(payload);
}

}
}
33 changes: 26 additions & 7 deletions src/main/java/com/marklogic/mgmt/forests/ForestManager.java
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
package com.marklogic.mgmt.forests;

import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import com.fasterxml.jackson.databind.JsonNode;
import com.marklogic.mgmt.AbstractResourceManager;
import com.marklogic.mgmt.ManageClient;
import com.marklogic.rest.util.Fragment;
Expand All @@ -20,15 +22,15 @@ public class ForestManager extends AbstractResourceManager {

public ForestManager(ManageClient client) {
super(client);
setUpdateAllowed(false);
setUpdateAllowed(true);
}

public void createForestWithName(String name, String host) {
public void createJsonForestWithName(String name, String host) {
if (forestExists(name)) {
logger.info(format("Forest already exists with name, so not creating: %s", name));
} else {
logger.info(format("Creating forest %s on host %s", name, host));
createForest(format("{\"forest-name\":\"%s\", \"host\":\"%s\"}", name, host));
createJsonForest(format("{\"forest-name\":\"%s\", \"host\":\"%s\"}", name, host));
logger.info(format("Created forest %s on host %s", name, host));
}
}
Expand All @@ -43,7 +45,24 @@ public void delete(String nameOrId, String level) {
}
}

public void createForest(String json) {
/**
* Supports either an array of JSON objects or a single JSON object.
*
* @param json
*/
public void saveJsonForests(String json) {
JsonNode node = super.payloadParser.parseJson(json);
if (node.isArray()) {
Iterator<JsonNode> iter = node.iterator();
while (iter.hasNext()) {
save(iter.next().toString());
}
} else {
save(json);
}
}

public void createJsonForest(String json) {
getManageClient().postJson("/manage/v2/forests", json);
}

Expand Down Expand Up @@ -103,7 +122,7 @@ public void setReplicas(String forestIdOrName, Map<String, String> replicaNamesA
/**
* Convenience method for detaching a forest from any replicas it has; this is often used before deleting those
* replicas
*
*
* @param forestIdOrName
*/
public void setReplicasToNone(String forestIdOrName) {
Expand All @@ -112,7 +131,7 @@ public void setReplicasToNone(String forestIdOrName) {

/**
* Returns a list of IDs for each replica forest for the given forest ID or name.
*
*
* @param forestIdOrName
* @return
*/
Expand All @@ -124,7 +143,7 @@ public List<String> getReplicaIds(String forestIdOrName) {

/**
* Deletes (with a level of "full") all replicas for the given forest.
*
*
* @param forestIdOrName
*/
public void deleteReplicas(String forestIdOrName) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,11 +28,6 @@ public abstract class AbstractAppDeployerTest extends AbstractMgmtTest {
protected final static Integer SAMPLE_APP_REST_PORT = 8540;
protected final static Integer SAMPLE_APP_TEST_REST_PORT = 8541;

@Autowired
private ManageConfig manageConfig;

private ConfigurableApplicationContext appManagerContext;

// Intended to be used by subclasses
protected AppDeployer appDeployer;
protected AppConfig appConfig;
Expand Down Expand Up @@ -60,24 +55,17 @@ protected void initializeAppDeployer() {

/**
* Initialize an AppDeployer with the given set of commands. Avoids having to create a Spring configuration.
*
*
* @param commands
*/
protected void initializeAppDeployer(Command... commands) {
appDeployer = new SimpleAppDeployer(manageClient, adminManager, commands);
}

@After
public void closeAppContext() {
if (appManagerContext != null) {
appManagerContext.close();
}
}

protected void deploySampleApp() {
appDeployer.deploy(appConfig);
}

protected void undeploySampleApp() {
try {
appDeployer.undeploy(appConfig);
Expand All @@ -102,7 +90,7 @@ protected LoadModulesCommand buildLoadModulesCommand() {
command.setModulesLoader(loader);
return command;
}

protected void setConfigBaseDir(String path) {
appConfig.getConfigDir().setBaseDir(new File("src/test/resources/" + path));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,14 @@
import com.marklogic.appdeployer.AbstractAppDeployerTest;
import com.marklogic.appdeployer.ConfigDir;
import com.marklogic.appdeployer.command.databases.DeployContentDatabasesCommand;
import com.marklogic.mgmt.forests.ForestManager;
import org.junit.After;
import org.junit.Test;

import java.io.File;

/**
* Created by rrudin on 7/19/2016.
* Verifies that directories under ./forests/ are processed correctly.
*/
public class DeployCustomForestsTest extends AbstractAppDeployerTest {

Expand All @@ -20,8 +21,19 @@ public void tearDown() {

@Test
public void test() {
// To avoid hardcoding host names that might cause the test to fail, we use a custom token and assume that
// the host of the Management API will work
appConfig.getCustomTokens().put("%%CUSTOM_HOST%%", super.manageConfig.getHost());

appConfig.setConfigDir(new ConfigDir(new File("src/test/resources/sample-app/custom-forests")));

initializeAppDeployer(new DeployContentDatabasesCommand(1), new DeployCustomForestsCommand());
deploySampleApp();

ForestManager mgr = new ForestManager(manageClient);
assertTrue("One 'simple' forest should have been created by default", mgr.exists("sample-app-content-1"));
assertTrue(mgr.exists("sample-app-content-custom-1"));
assertTrue(mgr.exists("sample-app-content-custom-2"));
assertTrue(mgr.exists("sample-app-content-custom-3"));
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,13 @@
{
"forest-name": "sample-app-content-custom-1",
"enabled": true,
"host": "%%HOST%%",
"host": "%%CUSTOM_HOST%%",
"database": "%%DATABASE%%"
},
{
"forest-name": "sample-app-content-custom-2",
"enabled": true,
"host": "%%HOST%%",
"host": "%%CUSTOM_HOST%%",
"database": "%%DATABASE%%"
}
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
{
"forest-name": "sample-app-content-custom-3",
"enabled": true,
"host": "%%CUSTOM_HOST%%",
"database": "%%DATABASE%%"
}

0 comments on commit aa96978

Please sign in to comment.