mirror of https://github.com/apache/openjpa.git
[OPENJPA-2915] properties of type Duration can be set as expected (#114)
This commit is contained in:
parent
7ef6c946e1
commit
7892f4baec
|
@ -24,6 +24,7 @@ import java.lang.reflect.Member;
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
import java.security.AccessController;
|
import java.security.AccessController;
|
||||||
import java.security.PrivilegedActionException;
|
import java.security.PrivilegedActionException;
|
||||||
|
import java.time.Duration;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -428,6 +429,11 @@ public class Options extends TypedProperties {
|
||||||
if (type == primWrapper[0])
|
if (type == primWrapper[0])
|
||||||
return stringToObject(str, (Class<?>) primWrapper[1]);
|
return stringToObject(str, (Class<?>) primWrapper[1]);
|
||||||
|
|
||||||
|
// special case for Durations
|
||||||
|
if (type == Duration.class) {
|
||||||
|
return Duration.ofMillis(Long.valueOf(str));
|
||||||
|
}
|
||||||
|
|
||||||
// look for a string constructor
|
// look for a string constructor
|
||||||
Exception err = null;
|
Exception err = null;
|
||||||
try {
|
try {
|
||||||
|
@ -627,7 +633,7 @@ public class Options extends TypedProperties {
|
||||||
*/
|
*/
|
||||||
private static class EmptyOptions extends Options {
|
private static class EmptyOptions extends Options {
|
||||||
|
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.openjpa.lib.util;
|
package org.apache.openjpa.lib.util;
|
||||||
|
|
||||||
|
import java.time.Duration;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
|
@ -103,9 +104,11 @@ public class TestOptions {
|
||||||
inner = new Inner();
|
inner = new Inner();
|
||||||
opts = new Options();
|
opts = new Options();
|
||||||
opts.setProperty("mixed", "STR,1");
|
opts.setProperty("mixed", "STR,1");
|
||||||
|
opts.setProperty("maxWait", "10000");
|
||||||
opts.setInto(inner);
|
opts.setInto(inner);
|
||||||
assertEquals(1, inner.getInt());
|
assertEquals(1, inner.getInt());
|
||||||
assertEquals("STR", inner.getString());
|
assertEquals("STR", inner.getString());
|
||||||
|
assertEquals(10_000, inner.getMaxWait().toMillis());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -124,6 +127,7 @@ public class TestOptions {
|
||||||
private Inner _nullInner = null;
|
private Inner _nullInner = null;
|
||||||
private int[] _range1 = new int[2];
|
private int[] _range1 = new int[2];
|
||||||
private int[] _range2 = new int[2];
|
private int[] _range2 = new int[2];
|
||||||
|
private Duration _maxWait = Duration.ofMillis(-1);
|
||||||
|
|
||||||
public Inner() {
|
public Inner() {
|
||||||
}
|
}
|
||||||
|
@ -200,6 +204,14 @@ public class TestOptions {
|
||||||
public void setNullInner(Inner in) {
|
public void setNullInner(Inner in) {
|
||||||
_nullInner = in;
|
_nullInner = in;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Duration getMaxWait() {
|
||||||
|
return _maxWait;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setMaxWait(Duration dur) {
|
||||||
|
_maxWait = dur;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue