SwaggerUiConfigurationQueryConfigTest.java
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.cxf.systest.jaxrs.description.openapi;
import java.util.Arrays;
import com.fasterxml.jackson.jakarta.rs.json.JacksonJsonProvider;
import jakarta.ws.rs.core.MediaType;
import jakarta.ws.rs.core.Response;
import org.apache.cxf.Bus;
import org.apache.cxf.jaxrs.JAXRSServerFactoryBean;
import org.apache.cxf.jaxrs.client.WebClient;
import org.apache.cxf.jaxrs.lifecycle.SingletonResourceProvider;
import org.apache.cxf.jaxrs.model.AbstractResourceInfo;
import org.apache.cxf.jaxrs.openapi.OpenApiFeature;
import org.apache.cxf.jaxrs.swagger.ui.SwaggerUiConfig;
import org.apache.cxf.testutil.common.AbstractClientServerTestBase;
import org.apache.cxf.testutil.common.AbstractServerTestServerBase;
import org.junit.BeforeClass;
import org.junit.Test;
import static org.hamcrest.CoreMatchers.containsString;
import static org.hamcrest.CoreMatchers.equalTo;
import static org.hamcrest.MatcherAssert.assertThat;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;
public class SwaggerUiConfigurationQueryConfigTest extends AbstractClientServerTestBase {
private static final String PORT = allocatePort(SwaggerUiConfigurationQueryConfigTest.class);
public static class Server extends AbstractServerTestServerBase {
@Override
protected org.apache.cxf.endpoint.Server createServer(Bus bus) throws Exception {
final JAXRSServerFactoryBean sf = new JAXRSServerFactoryBean();
sf.setResourceClasses(BookStoreOpenApi.class);
sf.setResourceProvider(BookStoreOpenApi.class,
new SingletonResourceProvider(new BookStoreOpenApi()));
sf.setProvider(new JacksonJsonProvider());
final OpenApiFeature feature = new OpenApiFeature();
feature.setRunAsFilter(false);
feature.setSwaggerUiConfig(new SwaggerUiConfig().url("/openapi.json"));
sf.setFeatures(Arrays.asList(feature));
sf.setAddress("http://localhost:" + PORT + "/");
return sf.create();
}
public static void main(String[] args) throws Exception {
new Server().start();
}
}
@BeforeClass
public static void startServers() throws Exception {
AbstractResourceInfo.clearAllMaps();
//keep out of process due to stack traces testing failures
assertTrue("server did not launch correctly", launchServer(Server.class, false));
}
@Test
public void testUiRootResource() {
// Test that Swagger UI resources do not interfere with
// application-specific ones and are accessible.
WebClient uiClient = WebClient
.create("http://localhost:" + getPort() + "/api-docs")
.query("url", "/openapi.json")
.accept("*/*");
try (Response response = uiClient.get()) {
String html = response.readEntity(String.class);
assertThat(html, containsString("<!-- HTML"));
assertThat(response.getMediaType(), equalTo(MediaType.TEXT_HTML_TYPE));
}
}
@Test
public void testUiRootResourceDoesNotReplaceUrl() {
// With query config enabled, we do not replace any values in the Swagger resource, just let
// Swagger UI handle the query parameters.
WebClient uiClient = WebClient
.create("http://localhost:" + getPort() + "/api-docs")
.path("/swagger-initializer.js")
.query("url", "/another-openapi.json")
.accept("*/*");
try (Response response = uiClient.get()) {
String jsCode = response.readEntity(String.class);
// We can only verify that the url was not replaced with the one configured, but not that
// the one in query is used (that would be testing the Swagger itself). The query parameter was included
// to demonstrate how the address might look, though.
assertFalse(jsCode.contains("url: \"/openapi.json\""));
}
}
public static String getPort() {
return PORT;
}
}