Polishing

This commit is contained in:
Juergen Hoeller 2016-08-10 14:20:42 +02:00
parent a4b6682c3e
commit 59a24b406a
25 changed files with 154 additions and 152 deletions

View File

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2014 the original author or authors. * Copyright 2002-2016 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -31,14 +31,16 @@ public abstract class AbstractCacheInvoker {
private CacheErrorHandler errorHandler; private CacheErrorHandler errorHandler;
protected AbstractCacheInvoker() {
this(new SimpleCacheErrorHandler());
}
protected AbstractCacheInvoker(CacheErrorHandler errorHandler) { protected AbstractCacheInvoker(CacheErrorHandler errorHandler) {
Assert.notNull("ErrorHandler must not be null"); Assert.notNull("ErrorHandler must not be null");
this.errorHandler = errorHandler; this.errorHandler = errorHandler;
} }
protected AbstractCacheInvoker() {
this(new SimpleCacheErrorHandler());
}
/** /**
* Set the {@link CacheErrorHandler} instance to use to handle errors * Set the {@link CacheErrorHandler} instance to use to handle errors
@ -56,6 +58,7 @@ public abstract class AbstractCacheInvoker {
return this.errorHandler; return this.errorHandler;
} }
/** /**
* Execute {@link Cache#get(Object)} on the specified {@link Cache} and * Execute {@link Cache#get(Object)} on the specified {@link Cache} and
* invoke the error handler if an exception occurs. Return {@code null} * invoke the error handler if an exception occurs. Return {@code null}
@ -67,8 +70,8 @@ public abstract class AbstractCacheInvoker {
try { try {
return cache.get(key); return cache.get(key);
} }
catch (RuntimeException e) { catch (RuntimeException ex) {
getErrorHandler().handleCacheGetError(e, cache, key); getErrorHandler().handleCacheGetError(ex, cache, key);
return null; // If the exception is handled, return a cache miss return null; // If the exception is handled, return a cache miss
} }
} }
@ -81,8 +84,8 @@ public abstract class AbstractCacheInvoker {
try { try {
cache.put(key, result); cache.put(key, result);
} }
catch (RuntimeException e) { catch (RuntimeException ex) {
getErrorHandler().handleCachePutError(e, cache, key, result); getErrorHandler().handleCachePutError(ex, cache, key, result);
} }
} }
@ -94,8 +97,8 @@ public abstract class AbstractCacheInvoker {
try { try {
cache.evict(key); cache.evict(key);
} }
catch (RuntimeException e) { catch (RuntimeException ex) {
getErrorHandler().handleCacheEvictError(e, cache, key); getErrorHandler().handleCacheEvictError(ex, cache, key);
} }
} }
@ -107,8 +110,8 @@ public abstract class AbstractCacheInvoker {
try { try {
cache.clear(); cache.clear();
} }
catch (RuntimeException e) { catch (RuntimeException ex) {
getErrorHandler().handleCacheClearError(e, cache); getErrorHandler().handleCacheClearError(ex, cache);
} }
} }

View File

@ -418,7 +418,7 @@ public abstract class CacheAspectSupport extends AbstractCacheInvoker
excluded.add(context); excluded.add(context);
} }
} }
catch (VariableNotAvailableException e) { catch (VariableNotAvailableException ex) {
// Ignoring failure due to missing result, consider the cache put has to proceed // Ignoring failure due to missing result, consider the cache put has to proceed
} }
} }

View File

@ -70,8 +70,8 @@ public class SimpleJmsHeaderMapper extends AbstractHeaderMapper<Message> impleme
try { try {
jmsMessage.setJMSCorrelationID((String) jmsCorrelationId); jmsMessage.setJMSCorrelationID((String) jmsCorrelationId);
} }
catch (Exception e) { catch (Exception ex) {
logger.info("failed to set JMSCorrelationID, skipping", e); logger.info("Failed to set JMSCorrelationID - skipping", ex);
} }
} }
Destination jmsReplyTo = getHeaderIfAvailable(headers, JmsHeaders.REPLY_TO, Destination.class); Destination jmsReplyTo = getHeaderIfAvailable(headers, JmsHeaders.REPLY_TO, Destination.class);
@ -79,8 +79,8 @@ public class SimpleJmsHeaderMapper extends AbstractHeaderMapper<Message> impleme
try { try {
jmsMessage.setJMSReplyTo(jmsReplyTo); jmsMessage.setJMSReplyTo(jmsReplyTo);
} }
catch (Exception e) { catch (Exception ex) {
logger.info("failed to set JMSReplyTo, skipping", e); logger.info("Failed to set JMSReplyTo - skipping", ex);
} }
} }
String jmsType = getHeaderIfAvailable(headers, JmsHeaders.TYPE, String.class); String jmsType = getHeaderIfAvailable(headers, JmsHeaders.TYPE, String.class);
@ -88,8 +88,8 @@ public class SimpleJmsHeaderMapper extends AbstractHeaderMapper<Message> impleme
try { try {
jmsMessage.setJMSType(jmsType); jmsMessage.setJMSType(jmsType);
} }
catch (Exception e) { catch (Exception ex) {
logger.info("failed to set JMSType, skipping", e); logger.info("Failed to set JMSType - skipping", ex);
} }
} }
Set<String> headerNames = headers.keySet(); Set<String> headerNames = headers.keySet();
@ -101,14 +101,15 @@ public class SimpleJmsHeaderMapper extends AbstractHeaderMapper<Message> impleme
String propertyName = this.fromHeaderName(headerName); String propertyName = this.fromHeaderName(headerName);
jmsMessage.setObjectProperty(propertyName, value); jmsMessage.setObjectProperty(propertyName, value);
} }
catch (Exception e) { catch (Exception ex) {
if (headerName.startsWith("JMSX")) { if (headerName.startsWith("JMSX")) {
if (logger.isTraceEnabled()) { if (logger.isTraceEnabled()) {
logger.trace("skipping reserved header, it cannot be set by client: " + headerName); logger.trace("Skipping reserved header '" + headerName +
"' since it cannot be set by client");
} }
} }
else if (logger.isWarnEnabled()) { else if (logger.isWarnEnabled()) {
logger.warn("failed to map Message header '" + headerName + "' to JMS property", e); logger.warn("Failed to map message header '" + headerName + "' to JMS property", ex);
} }
} }
} }
@ -117,7 +118,7 @@ public class SimpleJmsHeaderMapper extends AbstractHeaderMapper<Message> impleme
} }
catch (Exception ex) { catch (Exception ex) {
if (logger.isWarnEnabled()) { if (logger.isWarnEnabled()) {
logger.warn("error occurred while mapping from MessageHeaders to JMS properties", ex); logger.warn("Error occurred while mapping from MessageHeaders to JMS properties", ex);
} }
} }
} }
@ -133,7 +134,7 @@ public class SimpleJmsHeaderMapper extends AbstractHeaderMapper<Message> impleme
} }
} }
catch (Exception ex) { catch (Exception ex) {
logger.info("failed to read JMSCorrelationID property, skipping", ex); logger.info("Failed to read JMSCorrelationID property - skipping", ex);
} }
try { try {
Destination destination = jmsMessage.getJMSDestination(); Destination destination = jmsMessage.getJMSDestination();
@ -142,21 +143,21 @@ public class SimpleJmsHeaderMapper extends AbstractHeaderMapper<Message> impleme
} }
} }
catch (Exception ex) { catch (Exception ex) {
logger.info("failed to read JMSDestination property, skipping", ex); logger.info("Failed to read JMSDestination property - skipping", ex);
} }
try { try {
int deliveryMode = jmsMessage.getJMSDeliveryMode(); int deliveryMode = jmsMessage.getJMSDeliveryMode();
headers.put(JmsHeaders.DELIVERY_MODE, deliveryMode); headers.put(JmsHeaders.DELIVERY_MODE, deliveryMode);
} }
catch (Exception ex) { catch (Exception ex) {
logger.info("failed to read JMSDeliveryMode property, skipping", ex); logger.info("Failed to read JMSDeliveryMode property - skipping", ex);
} }
try { try {
long expiration = jmsMessage.getJMSExpiration(); long expiration = jmsMessage.getJMSExpiration();
headers.put(JmsHeaders.EXPIRATION, expiration); headers.put(JmsHeaders.EXPIRATION, expiration);
} }
catch (Exception ex) { catch (Exception ex) {
logger.info("failed to read JMSExpiration property, skipping", ex); logger.info("Failed to read JMSExpiration property - skipping", ex);
} }
try { try {
String messageId = jmsMessage.getJMSMessageID(); String messageId = jmsMessage.getJMSMessageID();
@ -165,13 +166,13 @@ public class SimpleJmsHeaderMapper extends AbstractHeaderMapper<Message> impleme
} }
} }
catch (Exception ex) { catch (Exception ex) {
logger.info("failed to read JMSMessageID property, skipping", ex); logger.info("Failed to read JMSMessageID property - skipping", ex);
} }
try { try {
headers.put(JmsHeaders.PRIORITY, jmsMessage.getJMSPriority()); headers.put(JmsHeaders.PRIORITY, jmsMessage.getJMSPriority());
} }
catch (Exception ex) { catch (Exception ex) {
logger.info("failed to read JMSPriority property, skipping", ex); logger.info("Failed to read JMSPriority property - skipping", ex);
} }
try { try {
Destination replyTo = jmsMessage.getJMSReplyTo(); Destination replyTo = jmsMessage.getJMSReplyTo();
@ -180,13 +181,13 @@ public class SimpleJmsHeaderMapper extends AbstractHeaderMapper<Message> impleme
} }
} }
catch (Exception ex) { catch (Exception ex) {
logger.info("failed to read JMSReplyTo property, skipping", ex); logger.info("Failed to read JMSReplyTo property - skipping", ex);
} }
try { try {
headers.put(JmsHeaders.REDELIVERED, jmsMessage.getJMSRedelivered()); headers.put(JmsHeaders.REDELIVERED, jmsMessage.getJMSRedelivered());
} }
catch (Exception ex) { catch (Exception ex) {
logger.info("failed to read JMSRedelivered property, skipping", ex); logger.info("Failed to read JMSRedelivered property - skipping", ex);
} }
try { try {
String type = jmsMessage.getJMSType(); String type = jmsMessage.getJMSType();
@ -195,13 +196,13 @@ public class SimpleJmsHeaderMapper extends AbstractHeaderMapper<Message> impleme
} }
} }
catch (Exception ex) { catch (Exception ex) {
logger.info("failed to read JMSType property, skipping", ex); logger.info("Failed to read JMSType property - skipping", ex);
} }
try { try {
headers.put(JmsHeaders.TIMESTAMP, jmsMessage.getJMSTimestamp()); headers.put(JmsHeaders.TIMESTAMP, jmsMessage.getJMSTimestamp());
} }
catch (Exception ex) { catch (Exception ex) {
logger.info("failed to read JMSTimestamp property, skipping", ex); logger.info("Failed to read JMSTimestamp property - skipping", ex);
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2014 the original author or authors. * Copyright 2002-2016 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -98,13 +98,13 @@ public class GenericMessagingTemplate extends AbstractDestinationResolvingMessag
@Override @Override
public void setBeanFactory(BeanFactory beanFactory) throws BeansException { public void setBeanFactory(BeanFactory beanFactory) throws BeansException {
super.setDestinationResolver(new BeanFactoryMessageChannelDestinationResolver(beanFactory)); setDestinationResolver(new BeanFactoryMessageChannelDestinationResolver(beanFactory));
} }
@Override @Override
protected final void doSend(MessageChannel channel, Message<?> message) { protected final void doSend(MessageChannel channel, Message<?> message) {
Assert.notNull(channel, "'channel' is required"); Assert.notNull(channel, "MessageChannel is required");
MessageHeaderAccessor accessor = MessageHeaderAccessor.getAccessor(message, MessageHeaderAccessor.class); MessageHeaderAccessor accessor = MessageHeaderAccessor.getAccessor(message, MessageHeaderAccessor.class);
if (accessor != null && accessor.isMutable()) { if (accessor != null && accessor.isMutable()) {
@ -116,13 +116,13 @@ public class GenericMessagingTemplate extends AbstractDestinationResolvingMessag
if (!sent) { if (!sent) {
throw new MessageDeliveryException(message, throw new MessageDeliveryException(message,
"failed to send message to channel '" + channel + "' within timeout: " + timeout); "Failed to send message to channel '" + channel + "' within timeout: " + timeout);
} }
} }
@Override @Override
protected final Message<?> doReceive(MessageChannel channel) { protected final Message<?> doReceive(MessageChannel channel) {
Assert.notNull(channel, "'channel' is required"); Assert.notNull(channel, "MessageChannel is required");
Assert.state(channel instanceof PollableChannel, "A PollableChannel is required to receive messages"); Assert.state(channel instanceof PollableChannel, "A PollableChannel is required to receive messages");
long timeout = this.receiveTimeout; long timeout = this.receiveTimeout;
@ -208,7 +208,7 @@ public class GenericMessagingTemplate extends AbstractDestinationResolvingMessag
} }
} }
} }
catch (InterruptedException e) { catch (InterruptedException ex) {
Thread.currentThread().interrupt(); Thread.currentThread().interrupt();
} }
return this.replyMessage; return this.replyMessage;

View File

@ -74,7 +74,7 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
try { try {
host = InetAddress.getLocalHost().getHostAddress(); host = InetAddress.getLocalHost().getHostAddress();
} }
catch (UnknownHostException e) { catch (UnknownHostException ex) {
host = "unknown"; host = "unknown";
} }
return host + "-" + UUID.randomUUID(); return host + "-" + UUID.randomUUID();
@ -87,6 +87,7 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
((SmartApplicationListener) this.localRegistry).getOrder() : Ordered.LOWEST_PRECEDENCE); ((SmartApplicationListener) this.localRegistry).getOrder() : Ordered.LOWEST_PRECEDENCE);
} }
// SmartApplicationListener methods // SmartApplicationListener methods
@Override @Override
@ -108,6 +109,7 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
} }
} }
// SimpUserRegistry methods // SimpUserRegistry methods
@Override @Override
@ -143,6 +145,7 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
return result; return result;
} }
// Internal methods for UserRegistryMessageHandler to manage broadcasts // Internal methods for UserRegistryMessageHandler to manage broadcasts
Object getLocalRegistryDto() { Object getLocalRegistryDto() {
@ -179,7 +182,6 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
* Holds a copy of a SimpUserRegistry for the purpose of broadcasting to and * Holds a copy of a SimpUserRegistry for the purpose of broadcasting to and
* receiving broadcasts from other application servers. * receiving broadcasts from other application servers.
*/ */
@SuppressWarnings("unused")
private static class UserRegistrySnapshot { private static class UserRegistrySnapshot {
private String id; private String id;
@ -188,10 +190,10 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
private long expirationTime; private long expirationTime;
/** /**
* Default constructor for JSON deserialization. * Default constructor for JSON deserialization.
*/ */
@SuppressWarnings("unused")
public UserRegistrySnapshot() { public UserRegistrySnapshot() {
} }
@ -207,7 +209,6 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
} }
} }
public void setId(String id) { public void setId(String id) {
this.id = id; this.id = id;
} }
@ -228,7 +229,6 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
return (now > this.expirationTime); return (now > this.expirationTime);
} }
public void init(long expirationPeriod, SessionLookup sessionLookup) { public void init(long expirationPeriod, SessionLookup sessionLookup) {
this.expirationTime = System.currentTimeMillis() + expirationPeriod; this.expirationTime = System.currentTimeMillis() + expirationPeriod;
for (TransferSimpUser user : this.users.values()) { for (TransferSimpUser user : this.users.values()) {
@ -236,7 +236,6 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
} }
} }
public Set<SimpSubscription> findSubscriptions(SimpSubscriptionMatcher matcher) { public Set<SimpSubscription> findSubscriptions(SimpSubscriptionMatcher matcher) {
Set<SimpSubscription> result = new HashSet<>(); Set<SimpSubscription> result = new HashSet<>();
for (TransferSimpUser user : this.users.values()) { for (TransferSimpUser user : this.users.values()) {
@ -251,12 +250,10 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
return result; return result;
} }
@Override @Override
public String toString() { public String toString() {
return "id=" + this.id + ", users=" + this.users; return "id=" + this.id + ", users=" + this.users;
} }
} }
@ -274,7 +271,6 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
/* Cross-server session lookup (e.g. user connected to multiple servers) */ /* Cross-server session lookup (e.g. user connected to multiple servers) */
private SessionLookup sessionLookup; private SessionLookup sessionLookup;
/** /**
* Default constructor for JSON deserialization. * Default constructor for JSON deserialization.
*/ */
@ -294,7 +290,6 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
} }
} }
public void setName(String name) { public void setName(String name) {
this.name = name; this.name = name;
} }
@ -369,6 +364,7 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
} }
} }
/** /**
* SimpSession that can be (de)serialized and broadcast to other servers. * SimpSession that can be (de)serialized and broadcast to other servers.
*/ */
@ -381,7 +377,6 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
private final Set<TransferSimpSubscription> subscriptions; private final Set<TransferSimpSubscription> subscriptions;
/** /**
* Default constructor for JSON deserialization. * Default constructor for JSON deserialization.
*/ */
@ -450,10 +445,10 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
} }
} }
/** /**
* SimpSubscription that can be (de)serialized and broadcast to other servers. * SimpSubscription that can be (de)serialized and broadcast to other servers.
*/ */
@SuppressWarnings("unused")
private static class TransferSimpSubscription implements SimpSubscription { private static class TransferSimpSubscription implements SimpSubscription {
private String id; private String id;
@ -462,10 +457,10 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
private String destination; private String destination;
/** /**
* Default constructor for JSON deserialization. * Default constructor for JSON deserialization.
*/ */
@SuppressWarnings("unused")
public TransferSimpSubscription() { public TransferSimpSubscription() {
} }
@ -477,7 +472,6 @@ public class MultiServerUserRegistry implements SimpUserRegistry, SmartApplicati
this.destination = subscription.getDestination(); this.destination = subscription.getDestination();
} }
public void setId(String id) { public void setId(String id) {
this.id = id; this.id = id;
} }

View File

@ -941,7 +941,7 @@ public class Jaxb2Marshaller implements MimeMarshaller, MimeUnmarshaller, Generi
try { try {
contentId = URLEncoder.encode(contentId, "UTF-8"); contentId = URLEncoder.encode(contentId, "UTF-8");
} }
catch (UnsupportedEncodingException e) { catch (UnsupportedEncodingException ex) {
// ignore // ignore
} }
return CID + contentId; return CID + contentId;
@ -952,7 +952,7 @@ public class Jaxb2Marshaller implements MimeMarshaller, MimeUnmarshaller, Generi
URI uri = new URI(elementNamespace); URI uri = new URI(elementNamespace);
return uri.getHost(); return uri.getHost();
} }
catch (URISyntaxException e) { catch (URISyntaxException ex) {
// ignore // ignore
} }
return dataHandler.getName(); return dataHandler.getName();
@ -998,7 +998,7 @@ public class Jaxb2Marshaller implements MimeMarshaller, MimeUnmarshaller, Generi
try { try {
contentId = URLDecoder.decode(contentId, "UTF-8"); contentId = URLDecoder.decode(contentId, "UTF-8");
} }
catch (UnsupportedEncodingException e) { catch (UnsupportedEncodingException ex) {
// ignore // ignore
} }
contentId = '<' + contentId + '>'; contentId = '<' + contentId + '>';

View File

@ -112,8 +112,8 @@ public class MockAsyncContext implements AsyncContext {
try { try {
listener.onComplete(new AsyncEvent(this, this.request, this.response)); listener.onComplete(new AsyncEvent(this, this.request, this.response));
} }
catch (IOException e) { catch (IOException ex) {
throw new IllegalStateException("AsyncListener failure", e); throw new IllegalStateException("AsyncListener failure", ex);
} }
} }
} }

View File

@ -19,7 +19,6 @@ package org.springframework.test.context.jdbc;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.util.List; import java.util.List;
import java.util.Set; import java.util.Set;
import javax.sql.DataSource; import javax.sql.DataSource;
import org.apache.commons.logging.Log; import org.apache.commons.logging.Log;
@ -216,10 +215,10 @@ public class SqlScriptsTestExecutionListener extends AbstractTestExecutionListen
DataSource dataSourceFromTxMgr = getDataSourceFromTransactionManager(transactionManager); DataSource dataSourceFromTxMgr = getDataSourceFromTransactionManager(transactionManager);
// Ensure user configured an appropriate DataSource/TransactionManager pair. // Ensure user configured an appropriate DataSource/TransactionManager pair.
if ((dataSource != null) && (dataSourceFromTxMgr != null) && !dataSource.equals(dataSourceFromTxMgr)) { if (dataSource != null && dataSourceFromTxMgr != null && !dataSource.equals(dataSourceFromTxMgr)) {
throw new IllegalStateException(String.format("Failed to execute SQL scripts for test context %s: " throw new IllegalStateException(String.format("Failed to execute SQL scripts for test context %s: " +
+ "the configured DataSource [%s] (named '%s') is not the one associated " "the configured DataSource [%s] (named '%s') is not the one associated with " +
+ "with transaction manager [%s] (named '%s').", testContext, dataSource.getClass().getName(), "transaction manager [%s] (named '%s').", testContext, dataSource.getClass().getName(),
dsName, transactionManager.getClass().getName(), tmName)); dsName, transactionManager.getClass().getName(), tmName));
} }
@ -231,8 +230,8 @@ public class SqlScriptsTestExecutionListener extends AbstractTestExecutionListen
} }
final DataSource finalDataSource = dataSource; final DataSource finalDataSource = dataSource;
int propagation = newTxRequired ? TransactionDefinition.PROPAGATION_REQUIRES_NEW int propagation = (newTxRequired ? TransactionDefinition.PROPAGATION_REQUIRES_NEW :
: TransactionDefinition.PROPAGATION_REQUIRED; TransactionDefinition.PROPAGATION_REQUIRED);
TransactionAttribute transactionAttribute = TestContextTransactionUtils.createDelegatingTransactionAttribute( TransactionAttribute transactionAttribute = TestContextTransactionUtils.createDelegatingTransactionAttribute(
testContext, new DefaultTransactionAttribute(propagation)); testContext, new DefaultTransactionAttribute(propagation));
@ -252,8 +251,8 @@ public class SqlScriptsTestExecutionListener extends AbstractTestExecutionListen
return (DataSource) obj; return (DataSource) obj;
} }
} }
catch (Exception e) { catch (Exception ex) {
/* ignore */ // ignore
} }
return null; return null;
} }
@ -293,9 +292,9 @@ public class SqlScriptsTestExecutionListener extends AbstractTestExecutionListen
return prefixedResourcePath; return prefixedResourcePath;
} }
else { else {
String msg = String.format("Could not detect default SQL script for test %s [%s]: " String msg = String.format("Could not detect default SQL script for test %s [%s]: " +
+ "%s does not exist. Either declare statements or scripts via @Sql or make the " "%s does not exist. Either declare statements or scripts via @Sql or make the " +
+ "default SQL script available.", elementType, elementName, classPathResource); "default SQL script available.", elementType, elementName, classPathResource);
logger.error(msg); logger.error(msg);
throw new IllegalStateException(msg); throw new IllegalStateException(msg);
} }

View File

@ -52,18 +52,12 @@ abstract class ActiveProfilesUtils {
private static final Log logger = LogFactory.getLog(ActiveProfilesUtils.class); private static final Log logger = LogFactory.getLog(ActiveProfilesUtils.class);
private ActiveProfilesUtils() {
/* no-op */
}
/** /**
* Resolve <em>active bean definition profiles</em> for the supplied {@link Class}. * Resolve <em>active bean definition profiles</em> for the supplied {@link Class}.
*
* <p>Note that the {@link ActiveProfiles#inheritProfiles inheritProfiles} flag of * <p>Note that the {@link ActiveProfiles#inheritProfiles inheritProfiles} flag of
* {@link ActiveProfiles @ActiveProfiles} will be taken into consideration. * {@link ActiveProfiles @ActiveProfiles} will be taken into consideration.
* Specifically, if the {@code inheritProfiles} flag is set to {@code true}, profiles * Specifically, if the {@code inheritProfiles} flag is set to {@code true}, profiles
* defined in the test class will be merged with those defined in superclasses. * defined in the test class will be merged with those defined in superclasses.
*
* @param testClass the class for which to resolve the active profiles (must not be * @param testClass the class for which to resolve the active profiles (must not be
* {@code null}) * {@code null})
* @return the set of active profiles for the specified class, including active * @return the set of active profiles for the specified class, including active
@ -78,8 +72,8 @@ abstract class ActiveProfilesUtils {
final List<String[]> profileArrays = new ArrayList<>(); final List<String[]> profileArrays = new ArrayList<>();
Class<ActiveProfiles> annotationType = ActiveProfiles.class; Class<ActiveProfiles> annotationType = ActiveProfiles.class;
AnnotationDescriptor<ActiveProfiles> descriptor = MetaAnnotationUtils.findAnnotationDescriptor(testClass, AnnotationDescriptor<ActiveProfiles> descriptor =
annotationType); MetaAnnotationUtils.findAnnotationDescriptor(testClass, annotationType);
if (descriptor == null && logger.isDebugEnabled()) { if (descriptor == null && logger.isDebugEnabled()) {
logger.debug(String.format( logger.debug(String.format(
"Could not find an 'annotation declaring class' for annotation type [%s] and class [%s]", "Could not find an 'annotation declaring class' for annotation type [%s] and class [%s]",
@ -92,8 +86,8 @@ abstract class ActiveProfilesUtils {
ActiveProfiles annotation = descriptor.synthesizeAnnotation(); ActiveProfiles annotation = descriptor.synthesizeAnnotation();
if (logger.isTraceEnabled()) { if (logger.isTraceEnabled()) {
logger.trace(String.format("Retrieved @ActiveProfiles [%s] for declaring class [%s].", annotation, logger.trace(String.format("Retrieved @ActiveProfiles [%s] for declaring class [%s].",
declaringClass.getName())); annotation, declaringClass.getName()));
} }
Class<? extends ActiveProfilesResolver> resolverClass = annotation.resolver(); Class<? extends ActiveProfilesResolver> resolverClass = annotation.resolver();
@ -101,15 +95,15 @@ abstract class ActiveProfilesUtils {
resolverClass = DefaultActiveProfilesResolver.class; resolverClass = DefaultActiveProfilesResolver.class;
} }
ActiveProfilesResolver resolver = null; ActiveProfilesResolver resolver;
try { try {
resolver = BeanUtils.instantiateClass(resolverClass, ActiveProfilesResolver.class); resolver = BeanUtils.instantiateClass(resolverClass, ActiveProfilesResolver.class);
} }
catch (Exception e) { catch (Exception ex) {
String msg = String.format("Could not instantiate ActiveProfilesResolver of " String msg = String.format("Could not instantiate ActiveProfilesResolver of type [%s] " +
+ "type [%s] for test class [%s].", resolverClass.getName(), rootDeclaringClass.getName()); "for test class [%s].", resolverClass.getName(), rootDeclaringClass.getName());
logger.error(msg); logger.error(msg);
throw new IllegalStateException(msg, e); throw new IllegalStateException(msg, ex);
} }
String[] profiles = resolver.resolve(rootDeclaringClass); String[] profiles = resolver.resolve(rootDeclaringClass);

View File

@ -42,7 +42,6 @@ public class AopTestUtils {
* {@linkplain AopUtils#isAopProxy proxy}, the target of the proxy will * {@linkplain AopUtils#isAopProxy proxy}, the target of the proxy will
* be returned; otherwise, the {@code candidate} will be returned * be returned; otherwise, the {@code candidate} will be returned
* <em>as is</em>. * <em>as is</em>.
*
* @param candidate the instance to check (potentially a Spring AOP proxy); * @param candidate the instance to check (potentially a Spring AOP proxy);
* never {@code null} * never {@code null}
* @return the target object or the {@code candidate}; never {@code null} * @return the target object or the {@code candidate}; never {@code null}
@ -58,8 +57,8 @@ public class AopTestUtils {
return (T) ((Advised) candidate).getTargetSource().getTarget(); return (T) ((Advised) candidate).getTargetSource().getTarget();
} }
} }
catch (Exception e) { catch (Exception ex) {
throw new IllegalStateException("Failed to unwrap proxied object.", e); throw new IllegalStateException("Failed to unwrap proxied object", ex);
} }
return (T) candidate; return (T) candidate;
} }
@ -72,7 +71,6 @@ public class AopTestUtils {
* {@linkplain AopUtils#isAopProxy proxy}, the ultimate target of all * {@linkplain AopUtils#isAopProxy proxy}, the ultimate target of all
* nested proxies will be returned; otherwise, the {@code candidate} * nested proxies will be returned; otherwise, the {@code candidate}
* will be returned <em>as is</em>. * will be returned <em>as is</em>.
*
* @param candidate the instance to check (potentially a Spring AOP proxy); * @param candidate the instance to check (potentially a Spring AOP proxy);
* never {@code null} * never {@code null}
* @return the ultimate target object or the {@code candidate}; never * @return the ultimate target object or the {@code candidate}; never
@ -89,8 +87,8 @@ public class AopTestUtils {
return (T) getUltimateTargetObject(((Advised) candidate).getTargetSource().getTarget()); return (T) getUltimateTargetObject(((Advised) candidate).getTargetSource().getTarget());
} }
} }
catch (Exception e) { catch (Exception ex) {
throw new IllegalStateException("Failed to unwrap proxied object.", e); throw new IllegalStateException("Failed to unwrap proxied object", ex);
} }
return (T) candidate; return (T) candidate;
} }

View File

@ -13,6 +13,7 @@
* See the License for the specific language governing permissions and * See the License for the specific language governing permissions and
* limitations under the License. * limitations under the License.
*/ */
package org.springframework.test.web.client.match; package org.springframework.test.web.client.match;
import java.io.IOException; import java.io.IOException;
@ -192,8 +193,8 @@ public class XpathRequestMatchers {
MockClientHttpRequest mockRequest = (MockClientHttpRequest) request; MockClientHttpRequest mockRequest = (MockClientHttpRequest) request;
matchInternal(mockRequest); matchInternal(mockRequest);
} }
catch (Exception e) { catch (Exception ex) {
throw new AssertionError("Failed to parse XML request content: " + e.getMessage()); throw new AssertionError("Failed to parse XML request content: " + ex.getMessage());
} }
} }

View File

@ -126,7 +126,7 @@ final class MockWebResponseBuilder {
result.setExpiryDate(expires); result.setExpiryDate(expires);
result.setPath(cookie.getPath()); result.setPath(cookie.getPath());
result.setSecure(cookie.getSecure()); result.setSecure(cookie.getSecure());
if(cookie.isHttpOnly()) { if (cookie.isHttpOnly()) {
result.setAttribute("httponly", "true"); result.setAttribute("httponly", "true");
} }
return new com.gargoylesoftware.htmlunit.util.Cookie(result); return new com.gargoylesoftware.htmlunit.util.Cookie(result);

View File

@ -27,6 +27,7 @@ import org.springframework.core.io.InputStreamResource;
import org.springframework.core.io.Resource; import org.springframework.core.io.Resource;
import org.springframework.core.io.support.ResourceRegion; import org.springframework.core.io.support.ResourceRegion;
import org.springframework.util.Assert; import org.springframework.util.Assert;
import org.springframework.util.CollectionUtils;
import org.springframework.util.ObjectUtils; import org.springframework.util.ObjectUtils;
import org.springframework.util.StringUtils; import org.springframework.util.StringUtils;
@ -170,11 +171,11 @@ public abstract class HttpRange {
* @return the list of regions for the given resource * @return the list of regions for the given resource
*/ */
public static List<ResourceRegion> toResourceRegions(List<HttpRange> ranges, Resource resource) { public static List<ResourceRegion> toResourceRegions(List<HttpRange> ranges, Resource resource) {
if(ranges == null || ranges.size() == 0) { if (CollectionUtils.isEmpty(ranges)) {
return Collections.emptyList(); return Collections.emptyList();
} }
List<ResourceRegion> regions = new ArrayList<>(ranges.size()); List<ResourceRegion> regions = new ArrayList<>(ranges.size());
for(HttpRange range : ranges) { for (HttpRange range : ranges) {
regions.add(range.toResourceRegion(resource)); regions.add(range.toResourceRegion(resource));
} }
return regions; return regions;

View File

@ -93,7 +93,9 @@ final class SimpleClientHttpResponse extends AbstractClientHttpResponse {
StreamUtils.drain(this.responseStream); StreamUtils.drain(this.responseStream);
this.responseStream.close(); this.responseStream.close();
} }
catch (IOException e) { } catch (IOException ex) {
// ignore
}
} }
} }

View File

@ -111,7 +111,7 @@ public class ResourceRegionHttpMessageConverter extends AbstractGenericHttpMessa
} }
else { else {
Collection<ResourceRegion> regions = (Collection<ResourceRegion>) object; Collection<ResourceRegion> regions = (Collection<ResourceRegion>) object;
if(regions.size() == 1) { if (regions.size() == 1) {
writeResourceRegion(regions.iterator().next(), outputMessage); writeResourceRegion(regions.iterator().next(), outputMessage);
} }
else { else {

View File

@ -126,8 +126,8 @@ public class ServletServerHttpResponse extends AbstractListenerServerHttpRespons
try { try {
outputStream().setWriteListener(writeListener); outputStream().setWriteListener(writeListener);
} }
catch (IOException e) { catch (IOException ex) {
throw new UncheckedIOException(e); throw new UncheckedIOException(ex);
} }
} }

View File

@ -47,14 +47,13 @@ import org.springframework.web.servlet.resource.ResourceHttpRequestHandler;
* *
* @author Rossen Stoyanchev * @author Rossen Stoyanchev
* @since 3.1 * @since 3.1
*
* @see DefaultServletHandlerConfigurer * @see DefaultServletHandlerConfigurer
*/ */
public class ResourceHandlerRegistry { public class ResourceHandlerRegistry {
private final ServletContext servletContext; private final ServletContext servletContext;
private final ApplicationContext appContext; private final ApplicationContext applicationContext;
private final ContentNegotiationManager contentNegotiationManager; private final ContentNegotiationManager contentNegotiationManager;
@ -69,26 +68,30 @@ public class ResourceHandlerRegistry {
public ResourceHandlerRegistry(ApplicationContext applicationContext, ServletContext servletContext, public ResourceHandlerRegistry(ApplicationContext applicationContext, ServletContext servletContext,
ContentNegotiationManager contentNegotiationManager) { ContentNegotiationManager contentNegotiationManager) {
Assert.notNull(applicationContext, "ApplicationContext is required"); Assert.notNull(applicationContext, "ApplicationContext is required");
this.appContext = applicationContext; this.applicationContext = applicationContext;
this.servletContext = servletContext; this.servletContext = servletContext;
this.contentNegotiationManager = contentNegotiationManager; this.contentNegotiationManager = contentNegotiationManager;
} }
/** /**
* Add a resource handler for serving static resources based on the specified URL path patterns. * Add a resource handler for serving static resources based on the specified URL path
* The handler will be invoked for every incoming request that matches to one of the specified path patterns. * patterns. The handler will be invoked for every incoming request that matches to
* @return A {@link ResourceHandlerRegistration} to use to further configure the registered resource handler. * one of the specified path patterns.
* @return A {@link ResourceHandlerRegistration} to use to further configure the
* registered resource handler
*/ */
public ResourceHandlerRegistration addResourceHandler(String... pathPatterns) { public ResourceHandlerRegistration addResourceHandler(String... pathPatterns) {
ResourceHandlerRegistration registration = new ResourceHandlerRegistration(this.appContext, pathPatterns); ResourceHandlerRegistration registration =
new ResourceHandlerRegistration(this.applicationContext, pathPatterns);
this.registrations.add(registration); this.registrations.add(registration);
return registration; return registration;
} }
/** /**
* Whether a resource handler has already been registered for the given pathPattern. * Whether a resource handler has already been registered for the given path pattern.
*/ */
public boolean hasMappingForPattern(String pathPattern) { public boolean hasMappingForPattern(String pathPattern) {
for (ResourceHandlerRegistration registration : this.registrations) { for (ResourceHandlerRegistration registration : this.registrations) {
@ -100,8 +103,9 @@ public class ResourceHandlerRegistry {
} }
/** /**
* Specify the order to use for resource handling relative to other {@link HandlerMapping}s configured in * Specify the order to use for resource handling relative to other {@link HandlerMapping}s
* the Spring MVC application context. The default value used is {@code Integer.MAX_VALUE-1}. * configured in the Spring MVC application context.
* <p>The default value used is {@code Integer.MAX_VALUE-1}.
*/ */
public ResourceHandlerRegistry setOrder(int order) { public ResourceHandlerRegistry setOrder(int order) {
this.order = order; this.order = order;
@ -109,10 +113,11 @@ public class ResourceHandlerRegistry {
} }
/** /**
* Return a handler mapping with the mapped resource handlers; or {@code null} in case of no registrations. * Return a handler mapping with the mapped resource handlers; or {@code null} in case
* of no registrations.
*/ */
protected AbstractHandlerMapping getHandlerMapping() { protected AbstractHandlerMapping getHandlerMapping() {
if (registrations.isEmpty()) { if (this.registrations.isEmpty()) {
return null; return null;
} }
@ -121,13 +126,13 @@ public class ResourceHandlerRegistry {
for (String pathPattern : registration.getPathPatterns()) { for (String pathPattern : registration.getPathPatterns()) {
ResourceHttpRequestHandler handler = registration.getRequestHandler(); ResourceHttpRequestHandler handler = registration.getRequestHandler();
handler.setServletContext(this.servletContext); handler.setServletContext(this.servletContext);
handler.setApplicationContext(this.appContext); handler.setApplicationContext(this.applicationContext);
handler.setContentNegotiationManager(this.contentNegotiationManager); handler.setContentNegotiationManager(this.contentNegotiationManager);
try { try {
handler.afterPropertiesSet(); handler.afterPropertiesSet();
} }
catch (Exception e) { catch (Exception ex) {
throw new BeanInitializationException("Failed to init ResourceHttpRequestHandler", e); throw new BeanInitializationException("Failed to init ResourceHttpRequestHandler", ex);
} }
urlMap.put(pathPattern, handler); urlMap.put(pathPattern, handler);
} }

View File

@ -275,7 +275,7 @@ public class ResourceHttpRequestHandler extends WebContentGenerator
if (this.resourceHttpMessageConverter == null) { if (this.resourceHttpMessageConverter == null) {
this.resourceHttpMessageConverter = new ResourceHttpMessageConverter(); this.resourceHttpMessageConverter = new ResourceHttpMessageConverter();
} }
if(this.resourceRegionHttpMessageConverter == null) { if (this.resourceRegionHttpMessageConverter == null) {
this.resourceRegionHttpMessageConverter = new ResourceRegionHttpMessageConverter(); this.resourceRegionHttpMessageConverter = new ResourceRegionHttpMessageConverter();
} }
} }
@ -372,7 +372,7 @@ public class ResourceHttpRequestHandler extends WebContentGenerator
try { try {
List<HttpRange> httpRanges = inputMessage.getHeaders().getRange(); List<HttpRange> httpRanges = inputMessage.getHeaders().getRange();
response.setStatus(HttpServletResponse.SC_PARTIAL_CONTENT); response.setStatus(HttpServletResponse.SC_PARTIAL_CONTENT);
if(httpRanges.size() == 1) { if (httpRanges.size() == 1) {
ResourceRegion resourceRegion = httpRanges.get(0).toResourceRegion(resource); ResourceRegion resourceRegion = httpRanges.get(0).toResourceRegion(resource);
this.resourceRegionHttpMessageConverter.write(resourceRegion, mediaType, outputMessage); this.resourceRegionHttpMessageConverter.write(resourceRegion, mediaType, outputMessage);
} }

View File

@ -181,8 +181,8 @@ public class UrlTag extends HtmlEscapingAwareTag implements ParamAware {
try { try {
pageContext.getOut().print(url); pageContext.getOut().print(url);
} }
catch (IOException e) { catch (IOException ex) {
throw new JspException(e); throw new JspException(ex);
} }
} }
else { else {

View File

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2012 the original author or authors. * Copyright 2002-2016 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -25,8 +25,8 @@ import org.springframework.util.StringUtils;
/** /**
* Convenient super class for many html tags that render content using the databinding * Convenient super class for many html tags that render content using the databinding
* features of the {@link AbstractHtmlElementTag AbstractHtmlElementTag}. The only thing sub tags * features of the {@link AbstractHtmlElementTag AbstractHtmlElementTag}. The only thing
* need to do is override {@link #renderDefaultContent(TagWriter)}. * sub-tags need to do is override {@link #renderDefaultContent(TagWriter)}.
* *
* @author Rob Harrop * @author Rob Harrop
* @author Juergen Hoeller * @author Juergen Hoeller
@ -136,8 +136,8 @@ public abstract class AbstractHtmlElementBodyTag extends AbstractHtmlElementTag
try { try {
bodyContent.writeOut(bodyContent.getEnclosingWriter()); bodyContent.writeOut(bodyContent.getEnclosingWriter());
} }
catch (IOException e) { catch (IOException ex) {
throw new JspException("Unable to write buffered body content.", e); throw new JspException("Unable to write buffered body content.", ex);
} }
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2012 the original author or authors. * Copyright 2002-2016 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -13,6 +13,7 @@
* See the License for the specific language governing permissions and * See the License for the specific language governing permissions and
* limitations under the License. * limitations under the License.
*/ */
package org.springframework.web.servlet.view.tiles3; package org.springframework.web.servlet.view.tiles3;
import java.util.Locale; import java.util.Locale;
@ -46,8 +47,8 @@ public class SpringLocaleResolver extends DefaultLocaleResolver {
return RequestContextUtils.getLocale(servletRequest); return RequestContextUtils.getLocale(servletRequest);
} }
} }
catch (NotAServletEnvironmentException e) { catch (NotAServletEnvironmentException ex) {
// Ignore // ignore
} }
return super.resolveLocale(request); return super.resolveLocale(request);
} }

View File

@ -117,8 +117,8 @@ public class JettyWebSocketClient extends AbstractWebSocketClient implements Lif
} }
this.client.start(); this.client.start();
} }
catch (Exception e) { catch (Exception ex) {
throw new IllegalStateException("Failed to start Jetty client", e); throw new IllegalStateException("Failed to start Jetty client", ex);
} }
} }
} }
@ -134,8 +134,8 @@ public class JettyWebSocketClient extends AbstractWebSocketClient implements Lif
} }
this.client.stop(); this.client.stop();
} }
catch (Exception e) { catch (Exception ex) {
logger.error("Error stopping Jetty WebSocketClient", e); logger.error("Error stopping Jetty WebSocketClient", ex);
} }
} }
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2013 the original author or authors. * Copyright 2002-2016 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -24,9 +24,11 @@ import org.springframework.web.socket.WebSocketHandler;
import org.springframework.web.socket.WebSocketSession; import org.springframework.web.socket.WebSocketSession;
/** /**
* A convenient base class for {@link WebSocketHandler} implementation that process binary * A convenient base class for {@link WebSocketHandler} implementations
* messages only. Text messages are rejected with {@link CloseStatus#NOT_ACCEPTABLE}. All * that process binary messages only.
* other methods have empty implementations. *
* <p>Text messages are rejected with {@link CloseStatus#NOT_ACCEPTABLE}.
* All other methods have empty implementations.
* *
* @author Rossen Stoyanchev * @author Rossen Stoyanchev
* @author Phillip Webb * @author Phillip Webb
@ -39,7 +41,7 @@ public class BinaryWebSocketHandler extends AbstractWebSocketHandler {
try { try {
session.close(CloseStatus.NOT_ACCEPTABLE.withReason("Text messages not supported")); session.close(CloseStatus.NOT_ACCEPTABLE.withReason("Text messages not supported"));
} }
catch (IOException e) { catch (IOException ex) {
// ignore // ignore
} }
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2013 the original author or authors. * Copyright 2002-2016 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -24,9 +24,11 @@ import org.springframework.web.socket.WebSocketHandler;
import org.springframework.web.socket.WebSocketSession; import org.springframework.web.socket.WebSocketSession;
/** /**
* A convenient base class for {@link WebSocketHandler} implementation that process text * A convenient base class for {@link WebSocketHandler} implementations
* messages only. Binary messages are rejected with {@link CloseStatus#NOT_ACCEPTABLE}. All * that process text messages only.
* other methods have empty implementations. *
* <p>Binary messages are rejected with {@link CloseStatus#NOT_ACCEPTABLE}.
* All other methods have empty implementations.
* *
* @author Rossen Stoyanchev * @author Rossen Stoyanchev
* @author Phillip Webb * @author Phillip Webb

View File

@ -82,8 +82,8 @@ public class JettyXhrTransport extends AbstractXhrTransport implements Lifecycle
this.httpClient.start(); this.httpClient.start();
} }
} }
catch (Exception e) { catch (Exception ex) {
throw new SockJsException("Failed to start " + this, e); throw new SockJsException("Failed to start " + this, ex);
} }
} }
@ -94,8 +94,8 @@ public class JettyXhrTransport extends AbstractXhrTransport implements Lifecycle
this.httpClient.stop(); this.httpClient.stop();
} }
} }
catch (Exception e) { catch (Exception ex) {
throw new SockJsException("Failed to stop " + this, e); throw new SockJsException("Failed to stop " + this, ex);
} }
} }
@ -154,6 +154,7 @@ public class JettyXhrTransport extends AbstractXhrTransport implements Lifecycle
new ResponseEntity<>(responseHeaders, status)); new ResponseEntity<>(responseHeaders, status));
} }
private static void addHttpHeaders(Request request, HttpHeaders headers) { private static void addHttpHeaders(Request request, HttpHeaders headers) {
for (String name : headers.keySet()) { for (String name : headers.keySet()) {
for (String value : headers.get(name)) { for (String value : headers.get(name)) {
@ -194,7 +195,6 @@ public class JettyXhrTransport extends AbstractXhrTransport implements Lifecycle
private final ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); private final ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
public SockJsResponseListener(URI url, HttpHeaders headers, XhrClientSockJsSession sockJsSession, public SockJsResponseListener(URI url, HttpHeaders headers, XhrClientSockJsSession sockJsSession,
SettableListenableFuture<WebSocketSession> connectFuture) { SettableListenableFuture<WebSocketSession> connectFuture) {
@ -204,7 +204,6 @@ public class JettyXhrTransport extends AbstractXhrTransport implements Lifecycle
this.sockJsSession = sockJsSession; this.sockJsSession = sockJsSession;
} }
@Override @Override
public void onBegin(Response response) { public void onBegin(Response response) {
if (response.getStatus() != 200) { if (response.getStatus() != 200) {