Merge pull request #2563 from eclipse/jetty-9.4.x-issue-2556-jettybase-file-scheme
Issue #2556 - bad "file:" scheme present in Xml usage of "jetty.base" and "jetty.home" properties
This commit is contained in:
commit
d54da40f8f
|
@ -31,6 +31,8 @@ import java.net.InetAddress;
|
||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.net.UnknownHostException;
|
import java.net.UnknownHostException;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.nio.file.Paths;
|
||||||
import java.security.AccessController;
|
import java.security.AccessController;
|
||||||
import java.security.PrivilegedExceptionAction;
|
import java.security.PrivilegedExceptionAction;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -134,20 +136,21 @@ public class XmlConfiguration
|
||||||
{
|
{
|
||||||
if (server!=null)
|
if (server!=null)
|
||||||
getIdMap().put("Server", server);
|
getIdMap().put("Server", server);
|
||||||
|
|
||||||
Resource home = Resource.newResource(System.getProperty("jetty.home","."));
|
|
||||||
getProperties().put("jetty.home",home.toString());
|
|
||||||
getProperties().put("jetty.home.uri",normalizeURI(home.getURI().toString()));
|
|
||||||
|
|
||||||
Resource base = Resource.newResource(System.getProperty("jetty.base",home.toString()));
|
Path home = Paths.get(System.getProperty("jetty.home", "."));
|
||||||
|
getProperties().put("jetty.home",home.toString());
|
||||||
|
getProperties().put("jetty.home.uri",normalizeURI(home.toUri().toASCIIString()));
|
||||||
|
|
||||||
|
Path base = Paths.get(System.getProperty("jetty.base", home.toString()));
|
||||||
getProperties().put("jetty.base",base.toString());
|
getProperties().put("jetty.base",base.toString());
|
||||||
getProperties().put("jetty.base.uri",normalizeURI(base.getURI().toString()));
|
getProperties().put("jetty.base.uri",normalizeURI(base.toUri().toASCIIString()));
|
||||||
|
|
||||||
if (webapp!=null)
|
if (webapp!=null)
|
||||||
{
|
{
|
||||||
getProperties().put("jetty.webapp",webapp.toString());
|
Path webappPath = webapp.getFile().toPath().toAbsolutePath();
|
||||||
getProperties().put("jetty.webapps",webapp.getFile().toPath().getParent().toString());
|
getProperties().put("jetty.webapp", webappPath.toString());
|
||||||
getProperties().put("jetty.webapps.uri",normalizeURI(webapp.getURI().toString()));
|
getProperties().put("jetty.webapps", webappPath.getParent().toString());
|
||||||
|
getProperties().put("jetty.webapps.uri", normalizeURI(webapp.getURI().toString()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch(Exception e)
|
catch(Exception e)
|
||||||
|
|
|
@ -18,28 +18,27 @@
|
||||||
|
|
||||||
package org.eclipse.jetty.xml;
|
package org.eclipse.jetty.xml;
|
||||||
|
|
||||||
|
import static org.hamcrest.CoreMatchers.is;
|
||||||
|
import static org.hamcrest.CoreMatchers.not;
|
||||||
|
import static org.hamcrest.CoreMatchers.notNullValue;
|
||||||
|
import static org.hamcrest.CoreMatchers.nullValue;
|
||||||
|
import static org.hamcrest.CoreMatchers.startsWith;
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertThat;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Properties;
|
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
import org.eclipse.jetty.util.log.Log;
|
|
||||||
import org.hamcrest.Matchers;
|
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Ignore;
|
import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.hamcrest.CoreMatchers.is;
|
|
||||||
import static org.hamcrest.CoreMatchers.not;
|
|
||||||
import static org.hamcrest.CoreMatchers.nullValue;
|
|
||||||
import static org.hamcrest.Matchers.containsString;
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
import static org.junit.Assert.assertThat;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
|
|
||||||
public class XmlConfigurationTest
|
public class XmlConfigurationTest
|
||||||
{
|
{
|
||||||
protected String[] _configure=new String [] {"org/eclipse/jetty/xml/configureWithAttr.xml","org/eclipse/jetty/xml/configureWithElements.xml"};
|
protected String[] _configure=new String [] {"org/eclipse/jetty/xml/configureWithAttr.xml","org/eclipse/jetty/xml/configureWithElements.xml"};
|
||||||
|
@ -937,4 +936,60 @@ public class XmlConfigurationTest
|
||||||
DefaultTestConfiguration config = (DefaultTestConfiguration)xmlConfiguration.configure();
|
DefaultTestConfiguration config = (DefaultTestConfiguration)xmlConfiguration.configure();
|
||||||
assertEquals(value, config.getFirst());
|
assertEquals(value, config.getFirst());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testJettyStandardIdsAndProperties_JettyHome_JettyBase() throws Exception
|
||||||
|
{
|
||||||
|
String propNames[] = new String[] {
|
||||||
|
"jetty.base",
|
||||||
|
"jetty.home"
|
||||||
|
};
|
||||||
|
|
||||||
|
for(String propName: propNames)
|
||||||
|
{
|
||||||
|
XmlConfiguration configuration =
|
||||||
|
new XmlConfiguration("" +
|
||||||
|
"<Configure class=\"org.eclipse.jetty.xml.TestConfiguration\">" +
|
||||||
|
" <Set name=\"TestString\">" +
|
||||||
|
" <Property name=\"" + propName + "\"/>" +
|
||||||
|
" </Set>" +
|
||||||
|
"</Configure>");
|
||||||
|
|
||||||
|
configuration.setJettyStandardIdsAndProperties(null, null);
|
||||||
|
|
||||||
|
TestConfiguration tc = new TestConfiguration();
|
||||||
|
configuration.configure(tc);
|
||||||
|
|
||||||
|
assertThat(propName, tc.getTestString(), is(notNullValue()));
|
||||||
|
assertThat(propName, tc.getTestString(), not(startsWith("file:")));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testJettyStandardIdsAndProperties_JettyHomeUri_JettyBaseUri() throws Exception
|
||||||
|
{
|
||||||
|
String propNames[] = new String[] {
|
||||||
|
"jetty.base.uri",
|
||||||
|
"jetty.home.uri"
|
||||||
|
};
|
||||||
|
|
||||||
|
for(String propName: propNames)
|
||||||
|
{
|
||||||
|
XmlConfiguration configuration =
|
||||||
|
new XmlConfiguration("" +
|
||||||
|
"<Configure class=\"org.eclipse.jetty.xml.TestConfiguration\">" +
|
||||||
|
" <Set name=\"TestString\">" +
|
||||||
|
" <Property name=\"" + propName + "\"/>" +
|
||||||
|
" </Set>" +
|
||||||
|
"</Configure>");
|
||||||
|
|
||||||
|
configuration.setJettyStandardIdsAndProperties(null, null);
|
||||||
|
|
||||||
|
TestConfiguration tc = new TestConfiguration();
|
||||||
|
configuration.configure(tc);
|
||||||
|
|
||||||
|
assertThat(propName, tc.getTestString(), is(notNullValue()));
|
||||||
|
assertThat(propName, tc.getTestString(), startsWith("file:"));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue