From d4c5f732f1676a8877b9adbe93227e62a8aab18e Mon Sep 17 00:00:00 2001 From: Markus KARG Date: Sat, 6 Jul 2024 08:01:23 +0000 Subject: [PATCH] Entity Provider for java.nio.file.Path --- .../chapters/appendix/_change-log.adoc | 4 +- .../appendix/_changes-since-4.0-release.adoc | 14 +++ .../chapters/providers/_entity_providers.adoc | 4 +- .../ee/sse/sseeventsink/MBWCheckResource.java | 24 +++- .../filter/interceptor/JAXRSClientIT.java | 109 +++++++++++++++++- .../rs/spec/filter/interceptor/Resource.java | 18 ++- .../overridestandard/JAXRSClientIT.java | 20 +++- .../provider/overridestandard/Resource.java | 8 +- .../overridestandard/TckFileProvider.java | 2 +- .../spec/provider/standard/JAXRSClientIT.java | 4 +- .../rs/spec/provider/standard/Resource.java | 8 +- .../standardnotnull/JAXRSClientIT.java | 50 +++++++- .../provider/standardnotnull/Resource.java | 8 +- 13 files changed, 258 insertions(+), 15 deletions(-) create mode 100644 jaxrs-spec/src/main/asciidoc/chapters/appendix/_changes-since-4.0-release.adoc diff --git a/jaxrs-spec/src/main/asciidoc/chapters/appendix/_change-log.adoc b/jaxrs-spec/src/main/asciidoc/chapters/appendix/_change-log.adoc index 716a214b3..b411caed0 100644 --- a/jaxrs-spec/src/main/asciidoc/chapters/appendix/_change-log.adoc +++ b/jaxrs-spec/src/main/asciidoc/chapters/appendix/_change-log.adoc @@ -1,6 +1,6 @@ //// ******************************************************************* -* Copyright (c) 2019, 2024 Eclipse Foundation +* Copyright (c) 2019 Eclipse Foundation * * This specification document is made available under the terms * of the Eclipse Foundation Specification License v1.0, which is @@ -12,6 +12,8 @@ [[change-log]] == Change Log +include::_changes-since-4.0-release.adoc[] + include::_changes-since-3.1-release.adoc[] include::_changes-since-3.0-release.adoc[] diff --git a/jaxrs-spec/src/main/asciidoc/chapters/appendix/_changes-since-4.0-release.adoc b/jaxrs-spec/src/main/asciidoc/chapters/appendix/_changes-since-4.0-release.adoc new file mode 100644 index 000000000..ed3c003a9 --- /dev/null +++ b/jaxrs-spec/src/main/asciidoc/chapters/appendix/_changes-since-4.0-release.adoc @@ -0,0 +1,14 @@ +//// +******************************************************************* +* Copyright (c) 2024 Eclipse Foundation +* +* This specification document is made available under the terms +* of the Eclipse Foundation Specification License v1.0, which is +* available at https://www.eclipse.org/legal/efsl.php. +******************************************************************* +//// + +[[changes-since-4.0-release]] +=== Changes Since 4.0 Release + +* <>: Added entity provider for `java.nio.file.Path` diff --git a/jaxrs-spec/src/main/asciidoc/chapters/providers/_entity_providers.adoc b/jaxrs-spec/src/main/asciidoc/chapters/providers/_entity_providers.adoc index 989168aa6..7a8ca8190 100644 --- a/jaxrs-spec/src/main/asciidoc/chapters/providers/_entity_providers.adoc +++ b/jaxrs-spec/src/main/asciidoc/chapters/providers/_entity_providers.adoc @@ -1,6 +1,6 @@ //// ******************************************************************* -* Copyright (c) 2019, 2021 Eclipse Foundation +* Copyright (c) 2019 Eclipse Foundation * * This specification document is made available under the terms * of the Eclipse Foundation Specification License v1.0, which is @@ -138,6 +138,8 @@ type combinations: All media types (`\*/*`). `java.io.File`:: All media types (`\*/*`). +`java.nio.file.Path`:: + All media types (`\*/*`). `jakarta.activation.DataSource`:: All media types (`\*/*`). `javax.xml.transform.Source`:: diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/jaxrs21/ee/sse/sseeventsink/MBWCheckResource.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/jaxrs21/ee/sse/sseeventsink/MBWCheckResource.java index 5eca3f8e7..4bf16bdf9 100644 --- a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/jaxrs21/ee/sse/sseeventsink/MBWCheckResource.java +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/jaxrs21/ee/sse/sseeventsink/MBWCheckResource.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2020 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017 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 @@ -133,6 +133,28 @@ public void sendFile(@Context SseEventSink sink, @Context Sse sse) { } } + @GET + @Path("path") + @Produces(MediaType.SERVER_SENT_EVENTS) + public void sendPath(@Context SseEventSink sink, @Context Sse sse) { + java.nio.file.Path p; + try (SseEventSink s = sink) { + try { + p = Files.createTempFile("tck", "temppath"); + Files.write(p, MESSAGE.getBytes(), StandardOpenOption.CREATE, + StandardOpenOption.APPEND); + p.toFile().deleteOnExit(); + s.send(sse.newEventBuilder().data(p).mediaType(MediaType.WILDCARD_TYPE) + .build()); + } catch (IOException e) { + s.send(sse.newEvent(e.getMessage())); + throw new RuntimeException(e); // log to server log + } + } catch (IOException e) { + LOG.log(Level.WARNING, "Failed to close SseEventSink", e); + } + } + @GET @Path("inputstream") @Produces(MediaType.SERVER_SENT_EVENTS) diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/filter/interceptor/JAXRSClientIT.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/filter/interceptor/JAXRSClientIT.java index a258a9c8c..055ee2212 100644 --- a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/filter/interceptor/JAXRSClientIT.java +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/filter/interceptor/JAXRSClientIT.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2021 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013 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 @@ -22,6 +22,7 @@ import java.io.IOException; import java.io.InputStreamReader; import java.io.InputStream; +import java.nio.file.Files; import javax.xml.namespace.QName; @@ -548,7 +549,7 @@ public void fileReaderContainerInterceptorTest() throws Fault { @Test @Tag("xml_binding") public void fileReaderNoInterceptorTest() throws Fault { - setProperty(Property.REQUEST, buildRequest(Request.POST, "postfile")); + setProperty(Property.REQUEST, buildRequest(Request.POST, "postpath")); setRequestContentEntity(content); setProperty(Property.SEARCH_STRING, content); invoke(); @@ -620,6 +621,110 @@ public void fileWriterClientInterceptorTest() throws Fault { logMsg("JAXRS called registered writer interceptor for file provider"); } + // ------------------------- Path ----------------------------------- + + /* + * @testName: pathReaderContainerInterceptorTest + * + * @assertion_ids: JAXRS:SPEC:84; + * + * @test_Strategy: JAX-RS implementations are REQUIRED to call registered + * interceptors when mapping representations to Java types and vice versa. + */ + @Test + @Tag("xml_binding") + public void pathReaderContainerInterceptorTest() throws Fault { + addInterceptors(EntityReaderInterceptor.class); + setProperty(Property.REQUEST, buildRequest(Request.POST, "postpath")); + setRequestContentEntity(content); + setProperty(Property.SEARCH_STRING, + EntityReaderInterceptor.class.getName()); + setProperty(Property.UNEXPECTED_RESPONSE_MATCH, Resource.DIRECTION); + invoke(); + logMsg("JAXRS called registered reader interceptor for path provider"); + } + + /* + * @testName: pathReaderNoInterceptorTest + * + * @assertion_ids: JAXRS:SPEC:84; + * + * @test_Strategy: JAX-RS implementations are REQUIRED to call registered + * interceptors when mapping representations to Java types and vice versa. + */ + @Test + @Tag("xml_binding") + public void pathReaderNoInterceptorTest() throws Fault { + setProperty(Property.REQUEST, buildRequest(Request.POST, "postpath")); + setRequestContentEntity(content); + setProperty(Property.SEARCH_STRING, content); + invoke(); + } + + /* + * @testName: pathWriterContainerInterceptorTest + * + * @assertion_ids: JAXRS:SPEC:84; + * + * @test_Strategy: JAX-RS implementations are REQUIRED to call registered + * interceptors when mapping representations to Java types and vice versa. + */ + @Test + @Tag("xml_binding") + public void pathWriterContainerInterceptorTest() throws Fault { + addInterceptors(EntityWriterInterceptor.class); + setProperty(Property.REQUEST, buildRequest(Request.GET, "getpath")); + setProperty(Property.SEARCH_STRING, + EntityWriterInterceptor.class.getName()); + setProperty(Property.SEARCH_STRING, Resource.DIRECTION); + invoke(); + logMsg("JAXRS called registered writer interceptor for path provider"); + } + + /* + * @testName: pathWriterNoInterceptorTest + * + * @assertion_ids: JAXRS:SPEC:84; + * + * @test_Strategy: JAX-RS implementations are REQUIRED to call registered + * interceptors when mapping representations to Java types and vice versa. + */ + @Test + @Tag("xml_binding") + public void pathWriterNoInterceptorTest() throws Fault { + setProperty(Property.REQUEST, buildRequest(Request.GET, "getpath")); + setProperty(Property.SEARCH_STRING, Resource.getName()); + invoke(); + } + + /* + * @testName: pathWriterClientInterceptorTest + * + * @assertion_ids: JAXRS:SPEC:84; + * + * @test_Strategy: JAX-RS implementations are REQUIRED to call registered + * interceptors when mapping representations to Java types and vice versa. + */ + @Test + @Tag("xml_binding") + public void pathWriterClientInterceptorTest() throws Fault { + try { + java.nio.file.Path path = Files.createTempFile("temp", "tmp"); + Files.writeString(path, content); + setRequestContentEntity(path); + } catch (IOException e) { + throw new Fault(e); + } + addProvider(EntityWriterInterceptor.class); + addInterceptors(EntityWriterInterceptor.class); + setProperty(Property.REQUEST, buildRequest(Request.POST, "poststring")); + setProperty(Property.SEARCH_STRING, + EntityWriterInterceptor.class.getName()); + setProperty(Property.UNEXPECTED_RESPONSE_MATCH, Resource.DIRECTION); + invoke(); + logMsg("JAXRS called registered writer interceptor for path provider"); + } + // ------------------------- DataSource ----------------------------------- /* diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/filter/interceptor/Resource.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/filter/interceptor/Resource.java index 55978227f..e65c9e2e7 100644 --- a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/filter/interceptor/Resource.java +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/filter/interceptor/Resource.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2021 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013 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 @@ -23,6 +23,7 @@ import java.io.InputStream; import java.io.InputStreamReader; import java.io.Reader; +import java.nio.file.Files; import java.util.List; import javax.xml.namespace.QName; @@ -133,6 +134,21 @@ public Response postFile(File file) throws IOException { return buildResponse(text); } + @GET + @Path("getpath") + public Response getPath() throws IOException { + java.nio.file.Path path = Files.createTempFile("filter", "tmp"); + Files.writeString(path, getName()); + return buildResponse(path); + } + + @POST + @Path("postpath") + public Response postPath(java.nio.file.Path path) throws IOException { + String text = Files.readString(path); + return buildResponse(text); + } + @GET @Path("getdatasource") public Response getDataSource() { diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/JAXRSClientIT.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/JAXRSClientIT.java index 1dbd47b25..ea66473bc 100644 --- a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/JAXRSClientIT.java +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/JAXRSClientIT.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2021 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012 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 @@ -82,7 +82,7 @@ void setPropertyAndInvokeEncoded(String resourceMethod) throws Fault { } String[] methodsAll = { "bytearray", "string", "inputstream", "reader", - "file", "datasource", "source", "jaxb", "streamingoutput" }; + "file", "path", "datasource", "source", "jaxb", "streamingoutput" }; @Deployment(testable = false) @@ -195,6 +195,22 @@ public void readWriteFileProviderTest() throws Fault { setPropertyAndInvoke("file", MediaType.APPLICATION_XML_TYPE); } + /* + * @testName: readWritePathProviderTest + * + * @assertion_ids: JAXRS:SPEC:35 + * + * @test_Strategy: An implementation MUST support application-provided entity + * providers and MUST use those in preference to its own pre-packaged + * providers when either could handle the same request. + * + */ + @Test + @Tag("xml_binding") + public void readWritePathProviderTest() throws Fault { + setPropertyAndInvoke("path", MediaType.APPLICATION_XML_TYPE); + } + /* * @testName: readWriteDataSourceProviderTest * diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/Resource.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/Resource.java index 6652ef13a..548a8914e 100644 --- a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/Resource.java +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/Resource.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2021 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012 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 @@ -63,6 +63,12 @@ public File file(File file) { return file; } + @Path("path") + @POST + public java.nio.file.Path path(java.nio.file.Path path) { + return path; + } + @Path("datasource") @POST public DataSource datasource(DataSource datasource) { diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/TckFileProvider.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/TckFileProvider.java index f8996e3f5..64f500179 100644 --- a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/TckFileProvider.java +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/overridestandard/TckFileProvider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2021 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012 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 diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standard/JAXRSClientIT.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standard/JAXRSClientIT.java index df778ab79..4cbb64457 100644 --- a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standard/JAXRSClientIT.java +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standard/JAXRSClientIT.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2021 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012 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 @@ -151,7 +151,7 @@ void logFinishTest(TestInfo testInfo) { } - String[] methodsAll = { "bytearray", "string", "inputstream", "file", + String[] methodsAll = { "bytearray", "string", "inputstream", "file", "path", "datasource", "streamingoutput" }; /* Run test */ diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standard/Resource.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standard/Resource.java index e69348238..cc5ab1a68 100644 --- a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standard/Resource.java +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standard/Resource.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2021 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012 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 @@ -110,6 +110,12 @@ public File filesvg(File file) { return file; } + @Path("path") + @POST + public java.nio.file.Path file(java.nio.file.Path path) { + return path; + } + @Path("datasource") @POST public DataSource datasource(DataSource datasource) { diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standardnotnull/JAXRSClientIT.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standardnotnull/JAXRSClientIT.java index 767652c49..170672aef 100644 --- a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standardnotnull/JAXRSClientIT.java +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standardnotnull/JAXRSClientIT.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2021 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012 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 @@ -21,6 +21,7 @@ import java.io.Reader; import java.math.BigDecimal; import java.io.IOException; +import java.nio.file.Files; import javax.xml.transform.Source; @@ -310,6 +311,53 @@ public void clientFileProviderTest() throws Fault { "File reader gets unexpected"+ content); } + /* + * @testName: serverPathProviderTest + * + * @assertion_ids: JAXRS:SPEC:33; JAXRS:SPEC:33.5; JAXRS:SPEC:75; + * + * @test_Strategy: java.nio.file.Path All media types. + * + * When reading zero-length request entities, all implementation-supplied + * MessageBodyReader implementations except the JAXB-related one MUST create a + * corresponding Java object that represents zero-length data; they MUST NOT + * return null. + */ + @Test + @Tag("xml_binding") + public void serverPathProviderTest() throws Fault { + setProperty(Property.SEARCH_STRING, Resource.NOTNULL); + setProperty(Property.REQUEST, buildRequest(Request.POST, "path")); + invoke(); + } + + /* + * @testName: clientPathProviderTest + * + * @assertion_ids: JAXRS:JAVADOC:863; + * + * @test_Strategy: java.io.File All media types. + * + * for a zero-length response entities returns null or a corresponding Java + * object that represents zero-length data. + */ + @Test + @Tag("xml_binding") + public void clientPathProviderTest() throws Fault { + setProperty(Property.REQUEST, buildRequest(Request.GET, "entity")); + invoke(); + java.nio.file.Path entity = getResponseBody(java.nio.file.Path.class); + String content = null; + if (entity != null) + try { + content = Files.readString(entity); + } catch (Exception e) { + throw new Fault(e); + } + assertTrue(content == null || content.length() == 0, + "Path reader gets unexpected"+ content); + } + /* * @testName: serverDataSourceProviderTest * diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standardnotnull/Resource.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standardnotnull/Resource.java index 31e9e3d7d..cad71b8c0 100644 --- a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standardnotnull/Resource.java +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/spec/provider/standardnotnull/Resource.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2021 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012 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 @@ -72,6 +72,12 @@ public String file(File file) { return isNull(file); } + @Path("path") + @POST + public String path(java.nio.file.Path path) { + return isNull(path); + } + @Path("datasource") @POST public String datasource(DataSource datasource) {