* Issue #11709 fix jetty-with-custom-class.xml file and use it
This commit is contained in:
parent
c5b2533fde
commit
b11d1cb27f
|
@ -22,6 +22,7 @@ import java.util.HashMap;
|
|||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Objects;
|
||||
import java.util.Optional;
|
||||
import java.util.StringTokenizer;
|
||||
|
||||
import org.eclipse.jetty.deploy.AppLifeCycle;
|
||||
|
@ -195,13 +196,14 @@ public class JettyServerFactory
|
|||
private static DeploymentManager ensureDeploymentManager(Server server)
|
||||
{
|
||||
Collection<DeploymentManager> deployers = server.getBeans(DeploymentManager.class);
|
||||
DeploymentManager deploymentManager;
|
||||
DeploymentManager deploymentManager = null;
|
||||
|
||||
if (deployers != null)
|
||||
{
|
||||
deploymentManager = deployers.stream().findFirst().get();
|
||||
deploymentManager = deployers.stream().findFirst().orElse(null);
|
||||
}
|
||||
else
|
||||
|
||||
if (deploymentManager == null)
|
||||
{
|
||||
deploymentManager = new DeploymentManager();
|
||||
deploymentManager.setContexts(getContextHandlerCollection(server));
|
||||
|
|
|
@ -42,6 +42,10 @@
|
|||
</exclusion>
|
||||
</exclusions>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty</groupId>
|
||||
<artifactId>jetty-slf4j-impl</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty.ee10.demos</groupId>
|
||||
<artifactId>jetty-ee10-demo-mock-resources</artifactId>
|
||||
|
@ -263,18 +267,6 @@
|
|||
<artifactId>jetty-alpn-server</artifactId>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
<!--
|
||||
<dependency>
|
||||
<groupId>org.slf4j</groupId>
|
||||
<artifactId>slf4j-simple</artifactId>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
-->
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty</groupId>
|
||||
<artifactId>jetty-slf4j-impl</artifactId>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty.ee10.demos</groupId>
|
||||
<artifactId>jetty-ee10-demo-container-initializer</artifactId>
|
||||
|
@ -539,6 +531,8 @@
|
|||
<systemPropertyVariables>
|
||||
<mavenRepoPath>${session.repositorySession.localRepository.basedir.absolutePath}</mavenRepoPath>
|
||||
<settingsFilePath>${env.GLOBAL_MVN_SETTINGS}</settingsFilePath>
|
||||
<!-- uncomment to be able to use jetty logging -->
|
||||
<!-- pax.exam.system>default</pax.exam.system -->
|
||||
</systemPropertyVariables>
|
||||
<argLine>-Dconscrypt-version=${conscrypt.version}</argLine>
|
||||
<!-- TODO -->
|
||||
|
|
|
@ -67,10 +67,9 @@
|
|||
<Item>org.eclipse.jetty.ee10.plus.webapp.PlusConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee10.plus.webapp.EnvConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee10.webapp.JmxConfiguration</Item>
|
||||
<Item>config.org.eclipse.jetty.ee10.websocket.server.JettyWebSocketConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.websocket.jakarta.server.config.JakartaWebSocketConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee10.websocket.server.config.JettyWebSocketConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee10.websocket.jakarta.server.config.JakartaWebSocketConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee10.osgi.annotations.AnnotationConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee10.osgi.boot.OSGiWebInfConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee10.osgi.boot.OSGiMetaInfConfiguration</Item>
|
||||
</Array>
|
||||
</Arg>
|
||||
|
|
|
@ -0,0 +1,123 @@
|
|||
//
|
||||
// ========================================================================
|
||||
// Copyright (c) 1995 Mort Bay Consulting Pty Ltd and others.
|
||||
//
|
||||
// This program and the accompanying materials are made available under the
|
||||
// terms of the Eclipse Public License v. 2.0 which is available at
|
||||
// https://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
|
||||
// which is available at https://www.apache.org/licenses/LICENSE-2.0.
|
||||
//
|
||||
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
|
||||
// ========================================================================
|
||||
//
|
||||
|
||||
package org.eclipse.jetty.ee10.osgi.test;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.FileInputStream;
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import javax.inject.Inject;
|
||||
|
||||
import org.eclipse.jetty.client.ContentResponse;
|
||||
import org.eclipse.jetty.client.HttpClient;
|
||||
import org.eclipse.jetty.http.HttpStatus;
|
||||
import org.eclipse.jetty.osgi.OSGiServerConstants;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.ops4j.pax.exam.Configuration;
|
||||
import org.ops4j.pax.exam.CoreOptions;
|
||||
import org.ops4j.pax.exam.Option;
|
||||
import org.ops4j.pax.exam.junit.PaxExam;
|
||||
import org.ops4j.pax.tinybundles.core.TinyBundle;
|
||||
import org.ops4j.pax.tinybundles.core.TinyBundles;
|
||||
import org.osgi.framework.BundleContext;
|
||||
import org.osgi.framework.Constants;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertNotNull;
|
||||
import static org.ops4j.pax.exam.CoreOptions.mavenBundle;
|
||||
import static org.ops4j.pax.exam.CoreOptions.systemProperty;
|
||||
|
||||
/**
|
||||
* TestJettyOSGiBootWithBundle
|
||||
*
|
||||
* Tests reading config from a bundle and loading classes from it
|
||||
*
|
||||
* Tests the ServiceContextProvider.
|
||||
*/
|
||||
@RunWith(PaxExam.class)
|
||||
public class TestJettyOSGiBootWithBundle
|
||||
{
|
||||
private static final String TEST_JETTY_HOME_BUNDLE = "test-jetty-xml-bundle";
|
||||
|
||||
@Inject
|
||||
BundleContext bundleContext = null;
|
||||
|
||||
@Configuration
|
||||
public static Option[] configure() throws IOException
|
||||
{
|
||||
ArrayList<Option> options = new ArrayList<>();
|
||||
|
||||
options.addAll(TestOSGiUtil.configurePaxExamLogging());
|
||||
options.add(TestOSGiUtil.optionalRemoteDebug());
|
||||
options.add(CoreOptions.junitBundles());
|
||||
options.addAll(configureJettyHomeAndPort());
|
||||
options.add(CoreOptions.bootDelegationPackages("org.xml.sax", "org.xml.*", "org.w3c.*", "javax.xml.*"));
|
||||
options.add(CoreOptions.systemPackages("com.sun.org.apache.xalan.internal.res", "com.sun.org.apache.xml.internal.utils",
|
||||
"com.sun.org.apache.xml.internal.utils", "com.sun.org.apache.xpath.internal",
|
||||
"com.sun.org.apache.xpath.internal.jaxp", "com.sun.org.apache.xpath.internal.objects"));
|
||||
TestOSGiUtil.coreJettyDependencies(options);
|
||||
TestOSGiUtil.coreJspDependencies(options);
|
||||
options.add(mavenBundle().groupId("org.eclipse.jetty").artifactId("jetty-alpn-java-client").versionAsInProject().start());
|
||||
options.add(mavenBundle().groupId("org.eclipse.jetty").artifactId("jetty-alpn-client").versionAsInProject().start());
|
||||
//back down version of bnd used here because tinybundles expects only this version
|
||||
options.add(mavenBundle().groupId("biz.aQute.bnd").artifactId("biz.aQute.bndlib").version("3.5.0").start());
|
||||
options.add(mavenBundle().groupId("org.ops4j.pax.tinybundles").artifactId("tinybundles").versionAsInProject().start());
|
||||
TinyBundle bundle = TinyBundles.bundle();
|
||||
bundle.add(SomeCustomBean.class);
|
||||
bundle.set(Constants.BUNDLE_SYMBOLICNAME, TEST_JETTY_HOME_BUNDLE);
|
||||
File etcFolder = new File("src/test/config/etc");
|
||||
bundle.add("jettyhome/etc/jetty-http-boot-with-bundle.xml", new FileInputStream(new File(etcFolder, "jetty-http-boot-with-bundle.xml")));
|
||||
bundle.add("jettyhome/etc/jetty-with-custom-class.xml", new FileInputStream(new File(etcFolder, "jetty-with-custom-class.xml")));
|
||||
options.add(CoreOptions.streamBundle(bundle.build()).startLevel(1));
|
||||
options.add(CoreOptions.cleanCaches(true));
|
||||
return options.toArray(new Option[0]);
|
||||
}
|
||||
|
||||
public static List<Option> configureJettyHomeAndPort()
|
||||
{
|
||||
List<Option> options = new ArrayList<>();
|
||||
options.add(systemProperty(OSGiServerConstants.MANAGED_JETTY_XML_CONFIG_URLS).value("etc/jetty-with-custom-class.xml,etc/jetty-http-boot-with-bundle.xml"));
|
||||
options.add(systemProperty("jetty.http.port").value("0"));
|
||||
// TODO: FIXME: options.add(systemProperty("jetty.ssl.port").value(String.valueOf(TestOSGiUtil.DEFAULT_SSL_PORT)));
|
||||
options.add(systemProperty("jetty.home.bundle").value(TEST_JETTY_HOME_BUNDLE));
|
||||
return options;
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testContextHandler() throws Exception
|
||||
{
|
||||
if (Boolean.getBoolean(TestOSGiUtil.BUNDLE_DEBUG))
|
||||
TestOSGiUtil.diagnoseBundles(bundleContext);
|
||||
|
||||
// now test the context
|
||||
HttpClient client = new HttpClient();
|
||||
try
|
||||
{
|
||||
client.start();
|
||||
String tmp = System.getProperty("boot.bundle.port");
|
||||
assertNotNull(tmp);
|
||||
int port = Integer.valueOf(tmp.trim());
|
||||
ContentResponse response = client.GET("http://127.0.0.1:" + port);
|
||||
assertEquals(HttpStatus.NOT_FOUND_404, response.getStatus());
|
||||
String content = new String(response.getContent());
|
||||
assertNotNull(content);
|
||||
}
|
||||
finally
|
||||
{
|
||||
client.stop();
|
||||
}
|
||||
}
|
||||
}
|
|
@ -153,41 +153,20 @@ public class TestOSGiUtil
|
|||
res.add(systemProperty("org.ops4j.pax.url.mvn.settings").value(System.getProperty("settingsFilePath")));
|
||||
}
|
||||
|
||||
res.add(mavenBundle().groupId("org.slf4j").artifactId("slf4j-api").versionAsInProject().noStart());
|
||||
|
||||
/*
|
||||
* Jetty 11 uses slf4j 2.0.0 by default, however we want to test with slf4j 1.7.30 for backwards compatibility.
|
||||
* To do that, we need to use slf4j-simple as the logging implementation. We make a simplelogger.properties
|
||||
* file available so that jetty logging can be configured
|
||||
*/
|
||||
// BEGIN - slf4j 1.7.x
|
||||
/* slf4j-simple conflicts with both slf4j 1.7.x, and jetty-slf4j-impl. (but in different ways)
|
||||
|
||||
TinyBundle simpleLoggingPropertiesBundle = TinyBundles.bundle();
|
||||
simpleLoggingPropertiesBundle.add("simplelogger.properties", ClassLoader.getSystemResource("simplelogger.properties"));
|
||||
simpleLoggingPropertiesBundle.set(Constants.BUNDLE_SYMBOLICNAME, "simple-logger-properties");
|
||||
simpleLoggingPropertiesBundle.set(Constants.FRAGMENT_HOST, "slf4j-simple");
|
||||
simpleLoggingPropertiesBundle.add(FragmentActivator.class);
|
||||
res.add(CoreOptions.streamBundle(simpleLoggingPropertiesBundle.build()).noStart());
|
||||
res.add(mavenBundle().groupId("org.slf4j").artifactId("slf4j-simple").versionAsInProject().noStart());
|
||||
*/
|
||||
// END - slf4j 1.7.x
|
||||
|
||||
/*
|
||||
* When running with slf4j >= 2.0.0, remove the slf4j simple logger above and uncomment the following lines
|
||||
*/
|
||||
// BEGIN - slf4j 2.x
|
||||
//configure jetty slf4j logging, and provide a jetty-logging properties file
|
||||
//note 1: you will need to change the surefire plugin config in pom.xml to set the system property "pax.exam.system=false"
|
||||
//to make paxexam use this slf4j
|
||||
//note 2: if you do set the above system property, more than likely the test will not finish, no idea why
|
||||
res.add(mavenBundle().groupId("org.eclipse.jetty").artifactId("jetty-slf4j-impl").versionAsInProject().start());
|
||||
res.add(mavenBundle().groupId("org.slf4j").artifactId("slf4j-api").versionAsInProject());
|
||||
TinyBundle loggingPropertiesBundle = TinyBundles.bundle();
|
||||
loggingPropertiesBundle.add("jetty-logging.properties", ClassLoader.getSystemResource("jetty-logging.properties"));
|
||||
loggingPropertiesBundle.set(Constants.BUNDLE_SYMBOLICNAME, "jetty-logging-properties");
|
||||
loggingPropertiesBundle.set(Constants.FRAGMENT_HOST, "org.eclipse.jetty.logging");
|
||||
loggingPropertiesBundle.add(FragmentActivator.class);
|
||||
res.add(CoreOptions.streamBundle(loggingPropertiesBundle.build()).noStart());
|
||||
res.add(mavenBundle().groupId("org.eclipse.jetty").artifactId("jetty-slf4j-impl").versionAsInProject().start());
|
||||
// END - slf4j 2.x
|
||||
|
||||
res.add(mavenBundle().groupId("jakarta.el").artifactId("jakarta.el-api").versionAsInProject().start());
|
||||
|
||||
res.add(mavenBundle().groupId("jakarta.servlet").artifactId("jakarta.servlet-api").versionAsInProject().start());
|
||||
res.add(mavenBundle().groupId("org.eclipse.platform").artifactId("org.eclipse.osgi.util").versionAsInProject());
|
||||
res.add(mavenBundle().groupId("org.osgi").artifactId("org.osgi.service.cm").versionAsInProject());
|
||||
|
|
|
@ -67,7 +67,7 @@
|
|||
<Item>org.eclipse.jetty.plus.webapp.PlusConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.plus.webapp.EnvConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee9.webapp.JmxConfiguration</Item>
|
||||
<Item>config.org.eclipse.jetty.ee10.websocket.server.JettyWebSocketConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee9.websocket.server.config.JettyWebSocketConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.websocket.jakarta.server.config.JakartaWebSocketConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee9.osgi.annotations.AnnotationConfiguration</Item>
|
||||
<Item>org.eclipse.jetty.ee9.osgi.boot.OSGiWebInfConfiguration</Item>
|
||||
|
|
Loading…
Reference in New Issue