Synchronize request init in AbstractHttpSockJsSession
Although unlikely in practice (but not impossible), the SockJS integration tests write a message while the request is initializing. This change adds synchronization around request intiailization for the SockJS HTTP sesion. Issue: SPR-11916
This commit is contained in:
parent
5614e257d1
commit
59e02e63c4
|
|
@ -201,6 +201,7 @@ public abstract class AbstractHttpSockJsSession extends AbstractSockJsSession {
|
||||||
this.frameFormat = frameFormat;
|
this.frameFormat = frameFormat;
|
||||||
this.asyncRequestControl = request.getAsyncRequestControl(response);
|
this.asyncRequestControl = request.getAsyncRequestControl(response);
|
||||||
|
|
||||||
|
synchronized (this.responseLock) {
|
||||||
try {
|
try {
|
||||||
// Let "our" handler know before sending the open frame to the remote handler
|
// Let "our" handler know before sending the open frame to the remote handler
|
||||||
delegateConnectionEstablished();
|
delegateConnectionEstablished();
|
||||||
|
|
@ -215,6 +216,7 @@ public abstract class AbstractHttpSockJsSession extends AbstractSockJsSession {
|
||||||
throw new SockJsTransportFailureException("Failed to open session", getId(), ex);
|
throw new SockJsTransportFailureException("Failed to open session", getId(), ex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
protected void writePrelude(ServerHttpRequest request, ServerHttpResponse response) throws IOException {
|
protected void writePrelude(ServerHttpRequest request, ServerHttpResponse response) throws IOException {
|
||||||
}
|
}
|
||||||
|
|
@ -244,8 +246,8 @@ public abstract class AbstractHttpSockJsSession extends AbstractSockJsSession {
|
||||||
* @param response the current response
|
* @param response the current response
|
||||||
* @param frameFormat the transport-specific SocksJS frame format to use
|
* @param frameFormat the transport-specific SocksJS frame format to use
|
||||||
*/
|
*/
|
||||||
public void handleSuccessiveRequest(ServerHttpRequest request,
|
public void handleSuccessiveRequest(ServerHttpRequest request, ServerHttpResponse response,
|
||||||
ServerHttpResponse response, SockJsFrameFormat frameFormat) throws SockJsException {
|
SockJsFrameFormat frameFormat) throws SockJsException {
|
||||||
|
|
||||||
synchronized (this.responseLock) {
|
synchronized (this.responseLock) {
|
||||||
try {
|
try {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue