[OLINGO-663] Default metadata etag generation fix
ETag value based on nano seconds will always be 14 characters long from now on.
This commit is contained in:
parent
a604fa78f2
commit
c35076fbe9
|
@ -170,7 +170,7 @@ public class BatchClientITCase extends AbstractTestITCase {
|
||||||
assertEquals(1, oDataResonse.getHeader("OData-Version").size());
|
assertEquals(1, oDataResonse.getHeader("OData-Version").size());
|
||||||
assertEquals("4.0", oDataResonse.getHeader("OData-Version").toArray()[0]);
|
assertEquals("4.0", oDataResonse.getHeader("OData-Version").toArray()[0]);
|
||||||
assertEquals(1, oDataResonse.getHeader("Content-Length").size());
|
assertEquals(1, oDataResonse.getHeader("Content-Length").size());
|
||||||
assertEquals("582", oDataResonse.getHeader("Content-Length").toArray()[0]);
|
assertEquals("583", oDataResonse.getHeader("Content-Length").toArray()[0]);
|
||||||
assertEquals("application/json;odata.metadata=minimal", oDataResonse.getContentType());
|
assertEquals("application/json;odata.metadata=minimal", oDataResonse.getContentType());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -202,7 +202,7 @@ public class BatchClientITCase extends AbstractTestITCase {
|
||||||
assertEquals(1, oDataResonse.getHeader("OData-Version").size());
|
assertEquals(1, oDataResonse.getHeader("OData-Version").size());
|
||||||
assertEquals("4.0", oDataResonse.getHeader("OData-Version").toArray()[0]);
|
assertEquals("4.0", oDataResonse.getHeader("OData-Version").toArray()[0]);
|
||||||
assertEquals(1, oDataResonse.getHeader("Content-Length").size());
|
assertEquals(1, oDataResonse.getHeader("Content-Length").size());
|
||||||
assertEquals("582", oDataResonse.getHeader("Content-Length").toArray()[0]);
|
assertEquals("583", oDataResonse.getHeader("Content-Length").toArray()[0]);
|
||||||
assertEquals("application/json;odata.metadata=minimal", oDataResonse.getContentType());
|
assertEquals("application/json;odata.metadata=minimal", oDataResonse.getContentType());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -234,7 +234,7 @@ public class BatchClientITCase extends AbstractTestITCase {
|
||||||
assertEquals(1, oDataResonse.getHeader("OData-Version").size());
|
assertEquals(1, oDataResonse.getHeader("OData-Version").size());
|
||||||
assertEquals("4.0", oDataResonse.getHeader("OData-Version").toArray()[0]);
|
assertEquals("4.0", oDataResonse.getHeader("OData-Version").toArray()[0]);
|
||||||
assertEquals(1, oDataResonse.getHeader("Content-Length").size());
|
assertEquals(1, oDataResonse.getHeader("Content-Length").size());
|
||||||
assertEquals("582", oDataResonse.getHeader("Content-Length").toArray()[0]);
|
assertEquals("583", oDataResonse.getHeader("Content-Length").toArray()[0]);
|
||||||
assertEquals("application/json;odata.metadata=minimal", oDataResonse.getContentType());
|
assertEquals("application/json;odata.metadata=minimal", oDataResonse.getContentType());
|
||||||
|
|
||||||
// Check second get request
|
// Check second get request
|
||||||
|
@ -334,7 +334,7 @@ public class BatchClientITCase extends AbstractTestITCase {
|
||||||
assertEquals(1, oDataResonse.getHeader("OData-Version").size());
|
assertEquals(1, oDataResonse.getHeader("OData-Version").size());
|
||||||
assertEquals("4.0", oDataResonse.getHeader("OData-Version").toArray()[0]);
|
assertEquals("4.0", oDataResonse.getHeader("OData-Version").toArray()[0]);
|
||||||
assertEquals(1, oDataResonse.getHeader("Content-Length").size());
|
assertEquals(1, oDataResonse.getHeader("Content-Length").size());
|
||||||
assertEquals("582", oDataResonse.getHeader("Content-Length").toArray()[0]);
|
assertEquals("583", oDataResonse.getHeader("Content-Length").toArray()[0]);
|
||||||
assertEquals("application/json;odata.metadata=minimal", oDataResonse.getContentType());
|
assertEquals("application/json;odata.metadata=minimal", oDataResonse.getContentType());
|
||||||
|
|
||||||
// Check second get request
|
// Check second get request
|
||||||
|
@ -357,7 +357,7 @@ public class BatchClientITCase extends AbstractTestITCase {
|
||||||
assertEquals(1, oDataResonse.getHeader("OData-Version").size());
|
assertEquals(1, oDataResonse.getHeader("OData-Version").size());
|
||||||
assertEquals("4.0", oDataResonse.getHeader("OData-Version").toArray()[0]);
|
assertEquals("4.0", oDataResonse.getHeader("OData-Version").toArray()[0]);
|
||||||
assertEquals(1, oDataResonse.getHeader("Content-Length").size());
|
assertEquals(1, oDataResonse.getHeader("Content-Length").size());
|
||||||
assertEquals("490", oDataResonse.getHeader("Content-Length").toArray()[0]);
|
assertEquals("491", oDataResonse.getHeader("Content-Length").toArray()[0]);
|
||||||
assertEquals("application/json;odata.metadata=minimal", oDataResonse.getContentType());
|
assertEquals("application/json;odata.metadata=minimal", oDataResonse.getContentType());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -60,7 +60,7 @@ public class BasicBatchITCase extends AbstractBaseTestITCase {
|
||||||
assertEquals("HTTP/1.1 200 OK", reader.readLine());
|
assertEquals("HTTP/1.1 200 OK", reader.readLine());
|
||||||
assertEquals("OData-Version: 4.0", reader.readLine());
|
assertEquals("OData-Version: 4.0", reader.readLine());
|
||||||
assertEquals("Content-Type: application/json;odata.metadata=minimal", reader.readLine());
|
assertEquals("Content-Type: application/json;odata.metadata=minimal", reader.readLine());
|
||||||
assertEquals("Content-Length: 582", reader.readLine());
|
assertEquals("Content-Length: 583", reader.readLine());
|
||||||
blankLine(reader);
|
blankLine(reader);
|
||||||
|
|
||||||
reader.close();
|
reader.close();
|
||||||
|
|
|
@ -56,7 +56,7 @@ public class TechnicalServlet extends HttpServlet {
|
||||||
* therefore any change must be deployed, resulting in re-loading of this class,
|
* therefore any change must be deployed, resulting in re-loading of this class,
|
||||||
* giving this field a new and hopefully unique value.</p>
|
* giving this field a new and hopefully unique value.</p>
|
||||||
*/
|
*/
|
||||||
private static final String metadataETag = "W/\"" + System.nanoTime() + "\"";
|
private static final String metadataETag = getETag();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void service(final HttpServletRequest request, final HttpServletResponse response)
|
protected void service(final HttpServletRequest request, final HttpServletResponse response)
|
||||||
|
@ -89,4 +89,16 @@ public class TechnicalServlet extends HttpServlet {
|
||||||
throw new ServletException(e);
|
throw new ServletException(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static String getETag() {
|
||||||
|
String time = "" + System.nanoTime();
|
||||||
|
if (time.length() > 14) {
|
||||||
|
time = time.substring(0, 14);
|
||||||
|
} else {
|
||||||
|
while (time.length() < 14) {
|
||||||
|
time = "0" + time;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return "W/\"" + time + "\"";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue