Skip to content

Commit

Permalink
allow for resource methods to return <? extends XYZ>
Browse files Browse the repository at this point in the history
Signed-off-by: jansupol <jan.supol@oracle.com>
  • Loading branch information
jansupol committed Jun 20, 2023
1 parent 1f0dbfa commit c42a6a2
Show file tree
Hide file tree
Showing 3 changed files with 87 additions and 4 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2012, 2022 Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2012, 2023 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
Expand All @@ -21,6 +21,8 @@
import java.lang.annotation.Annotation;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.lang.reflect.TypeVariable;
import java.lang.reflect.WildcardType;
import java.net.URI;
import java.util.Date;
import java.util.Locale;
Expand Down Expand Up @@ -308,6 +310,18 @@ public void setEntityType(final Type type) {
if (parameterizedType.getRawType().equals(GenericEntity.class)) {
t = parameterizedType.getActualTypeArguments()[0];
}
} else if (type instanceof TypeVariable) {
final TypeVariable typeVariable = (TypeVariable) type;
final Type[] bounds = typeVariable.getBounds();
if (bounds.length == 1) {
t = bounds[0];
}
} else if (type instanceof WildcardType) {
final WildcardType wildcardType = (WildcardType) type;
final Type[] bounds = wildcardType.getUpperBounds();
if (bounds.length == 1) {
t = bounds[0];
}
}

messageContext.setEntityType(t);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2017, 2022 Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2017, 2023 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
Expand All @@ -18,7 +18,6 @@

import org.glassfish.jersey.server.ResourceConfig;
import org.glassfish.jersey.server.ServerProperties;
import org.glassfish.jersey.server.ServerRuntime;
import org.glassfish.jersey.test.JerseyTest;
import org.junit.jupiter.api.Test;

Expand Down Expand Up @@ -160,7 +159,15 @@ public void test4463() {

@Test
public void testCompletionStageUnwrappedInGenericType() {
try (Response r = target("cs/databeanlist").request().get()){
try (Response r = target("cs/databeanlist").request().get()) {
assertEquals(200, r.getStatus());
assertTrue(r.readEntity(String.class).startsWith(ENTITY));
}
}

@Test
void testExtends() {
try (Response r = target("cs/csextends").request().get()) {
assertEquals(200, r.getStatus());
assertTrue(r.readEntity(String.class).startsWith(ENTITY));
}
Expand Down Expand Up @@ -291,6 +298,12 @@ public CompletionStage<String> getCustomCompletionStageAsync() {
return cs;
}

@GET
@Path("csextends")
public CompletionStage<? extends CharSequence> csExtends() {
return CompletableFuture.completedFuture(ENTITY);
}

private void delaySubmit(Runnable runnable) {
EXECUTOR_SERVICE.submit(() -> {
try {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
/*
* Copyright (c) 2023 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/

package org.glassfish.jersey.tests.e2e.server;

import org.glassfish.jersey.server.ResourceConfig;
import org.glassfish.jersey.test.JerseyTest;
import org.junit.jupiter.api.Test;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.core.Application;
import javax.ws.rs.core.Response;

import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertTrue;

class TypedVariableTest extends JerseyTest {

private static final String ENTITY = "entity";

@Path("/typed")
public static class Resource {
@GET
@Path("extends")
public <T extends CharSequence> T justExtends() {
return (T) ENTITY;
}
}

@Override
protected Application configure() {
return new ResourceConfig(Resource.class);
}

@Test
void testExtends() {
try (Response r = target("typed/extends").request().get()) {
assertEquals(200, r.getStatus());
assertTrue(r.readEntity(String.class).startsWith(ENTITY));
}
}
}

0 comments on commit c42a6a2

Please sign in to comment.