提交 60a23e5b 编写于 作者: J Jesse Glick

[FIXED JENKINS-31954] Stack overflow reconfiguring some settings where...

[FIXED JENKINS-31954] Stack overflow reconfiguring some settings where Descriptor.newInstance is gratuitously overridden.
上级 8f38e206
......@@ -578,13 +578,13 @@ public abstract class Descriptor<T extends Describable<T>> implements Saveable {
BindInterceptor oldInterceptor = req.getBindInterceptor();
try {
NewInstanceBindInterceptor interceptor;
if ((oldInterceptor instanceof NewInstanceBindInterceptor)) {
if (oldInterceptor instanceof NewInstanceBindInterceptor) {
interceptor = (NewInstanceBindInterceptor) oldInterceptor;
} else {
interceptor = new NewInstanceBindInterceptor(oldInterceptor);
req.setBindInterceptor(interceptor);
}
interceptor.processed.put(formData, null);
interceptor.processed.put(formData, true);
return verifyNewInstance(req.bindJSON(clazz, formData));
} finally {
req.setBindInterceptor(oldInterceptor);
......@@ -612,7 +612,7 @@ public abstract class Descriptor<T extends Describable<T>> implements Saveable {
private static class NewInstanceBindInterceptor extends BindInterceptor {
private final BindInterceptor oldInterceptor;
private final Map<JSONObject,Void> processed = new IdentityHashMap<>();
private final Map<JSONObject,Boolean> processed = new IdentityHashMap<>();
NewInstanceBindInterceptor(BindInterceptor oldInterceptor) {
LOGGER.log(Level.FINER, "new interceptor delegating to {0}", oldInterceptor);
......@@ -628,7 +628,7 @@ public abstract class Descriptor<T extends Describable<T>> implements Saveable {
LOGGER.log(Level.FINER, "ignoring non-Describable {0} {1}", new Object[] {type.getName(), json});
return false;
}
if (processed.containsKey(json)) {
if (Boolean.TRUE.equals(processed.put(json, true))) {
LOGGER.log(Level.FINER, "already processed {0} {1}", new Object[] {type.getName(), json});
return false;
}
......
......@@ -49,6 +49,16 @@ public class RunParameterDefinitionTest {
@Rule
public JenkinsRule j = new JenkinsRule();
@Issue("JENKINS-31954")
@Test public void configRoundtrip() throws Exception {
FreeStyleProject p = j.createFreeStyleProject();
p.addProperty(new ParametersDefinitionProperty(new RunParameterDefinition("build", "p", "", RunParameterFilter.COMPLETED)));
j.configRoundtrip(p);
RunParameterDefinition rpd = (RunParameterDefinition) p.getProperty(ParametersDefinitionProperty.class).getParameterDefinition("build");
assertEquals("p", rpd.getProjectName());
assertEquals(RunParameterFilter.COMPLETED, rpd.getFilter());
}
@Issue("JENKINS-16462")
@Test public void inFolders() throws Exception {
MockFolder dir = j.createFolder("dir");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册