Refine Narayana log directory logic

Refine the log directory logic used by Narayana so that it is consistent
with Atomikos and Bitronix.

See gh-5552
This commit is contained in:
Phillip Webb 2016-04-06 19:13:38 -07:00
parent ec33c59f6b
commit 9f1466c9a3
4 changed files with 37 additions and 13 deletions

View File

@ -16,12 +16,15 @@
package org.springframework.boot.autoconfigure.transaction.jta;
import java.io.File;
import javax.jms.Message;
import javax.transaction.TransactionManager;
import javax.transaction.UserTransaction;
import com.arjuna.ats.jbossatx.jta.RecoveryManagerService;
import org.springframework.boot.ApplicationHome;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.boot.jta.XAConnectionFactoryWrapper;
@ -37,6 +40,7 @@ import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.DependsOn;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.jta.JtaTransactionManager;
import org.springframework.util.StringUtils;
/**
* JTA Configuration for <a href="http://narayana.io/">Narayana</a>.
@ -66,9 +70,7 @@ public class NarayanaJtaConfiguration {
@ConditionalOnMissingBean
public NarayanaConfigurationBean narayanaConfiguration(
NarayanaProperties properties) {
if (this.jtaProperties.getLogDir() != null) {
properties.setLogDir(this.jtaProperties.getLogDir());
}
properties.setLogDir(getLogDir().getAbsolutePath());
if (this.jtaProperties.getTransactionManagerId() != null) {
properties.setTransactionManagerId(
this.jtaProperties.getTransactionManagerId());
@ -76,6 +78,14 @@ public class NarayanaJtaConfiguration {
return new NarayanaConfigurationBean(properties);
}
private File getLogDir() {
if (StringUtils.hasLength(this.jtaProperties.getLogDir())) {
return new File(this.jtaProperties.getLogDir());
}
File home = new ApplicationHome().getDir();
return new File(home, "transaction-logs");
}
@Bean
@DependsOn("narayanaConfiguration")
@ConditionalOnMissingBean

View File

@ -71,11 +71,14 @@ public class NarayanaConfigurationBean implements InitializingBean {
}
private void setObjectStoreDir(String objectStoreDir) {
getPopulator(ObjectStoreEnvironmentBean.class).setObjectStoreDir(objectStoreDir);
getPopulator(ObjectStoreEnvironmentBean.class, "communicationStore")
.setObjectStoreDir(objectStoreDir);
getPopulator(ObjectStoreEnvironmentBean.class, "stateStore")
.setObjectStoreDir(objectStoreDir);
if (objectStoreDir != null) {
getPopulator(ObjectStoreEnvironmentBean.class)
.setObjectStoreDir(objectStoreDir);
getPopulator(ObjectStoreEnvironmentBean.class, "communicationStore")
.setObjectStoreDir(objectStoreDir);
getPopulator(ObjectStoreEnvironmentBean.class, "stateStore")
.setObjectStoreDir(objectStoreDir);
}
}
private void setCommitOnePhase(boolean isCommitOnePhase) {

View File

@ -37,9 +37,9 @@ public class NarayanaProperties {
public static final String PROPERTIES_PREFIX = "spring.jta.narayana";
/**
* Transaction object store directory. Default: target/tx-object-store.
* Transaction object store directory.
*/
private String logDir = "target/tx-object-store";
private String logDir;
/**
* Unique transaction manager id. Default: 1.

View File

@ -18,6 +18,7 @@ package org.springframework.boot.jta.narayana;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import com.arjuna.ats.arjuna.common.CoordinatorEnvironmentBean;
import com.arjuna.ats.arjuna.common.CoreEnvironmentBean;
@ -25,8 +26,11 @@ import com.arjuna.ats.arjuna.common.ObjectStoreEnvironmentBean;
import com.arjuna.ats.arjuna.common.RecoveryEnvironmentBean;
import com.arjuna.ats.jta.common.JTAEnvironmentBean;
import com.arjuna.common.internal.util.propertyservice.BeanPopulator;
import org.junit.After;
import org.junit.Test;
import org.springframework.test.util.ReflectionTestUtils;
import static org.assertj.core.api.Assertions.assertThat;
/**
@ -36,6 +40,13 @@ import static org.assertj.core.api.Assertions.assertThat;
*/
public class NarayanaConfigurationBeanTests {
@After
@SuppressWarnings("unchecked")
public void cleanup() {
((Map<String, Object>) ReflectionTestUtils.getField(BeanPopulator.class,
"beanInstances")).clear();
}
@Test
public void shouldSetDefaultProperties() throws Exception {
NarayanaProperties narayanaProperties = new NarayanaProperties();
@ -46,13 +57,13 @@ public class NarayanaConfigurationBeanTests {
assertThat(BeanPopulator.getDefaultInstance(CoreEnvironmentBean.class)
.getNodeIdentifier()).isEqualTo("1");
assertThat(BeanPopulator.getDefaultInstance(ObjectStoreEnvironmentBean.class)
.getObjectStoreDir()).isEqualTo("target/tx-object-store");
.getObjectStoreDir()).endsWith("ObjectStore");
assertThat(BeanPopulator
.getNamedInstance(ObjectStoreEnvironmentBean.class, "communicationStore")
.getObjectStoreDir()).isEqualTo("target/tx-object-store");
.getObjectStoreDir()).endsWith("ObjectStore");
assertThat(BeanPopulator
.getNamedInstance(ObjectStoreEnvironmentBean.class, "stateStore")
.getObjectStoreDir()).isEqualTo("target/tx-object-store");
.getObjectStoreDir()).endsWith("ObjectStore");
assertThat(BeanPopulator.getDefaultInstance(CoordinatorEnvironmentBean.class)
.isCommitOnePhase()).isTrue();
assertThat(BeanPopulator.getDefaultInstance(CoordinatorEnvironmentBean.class)