Browse Source

Merge pull request #509 from garyrussel/SPR-11468

pull/515/head
Rossen Stoyanchev 12 years ago
parent
commit
2e674c24f8
  1. 36
      spring-messaging/src/main/java/org/springframework/messaging/MessageHeaders.java
  2. 20
      spring-messaging/src/test/java/org/springframework/messaging/MessageHeadersTests.java

36
spring-messaging/src/main/java/org/springframework/messaging/MessageHeaders.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2013 the original author or authors. * Copyright 2002-2014 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.
@ -34,6 +34,7 @@ import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import org.springframework.util.AlternativeJdkIdGenerator; import org.springframework.util.AlternativeJdkIdGenerator;
import org.springframework.util.Assert;
import org.springframework.util.IdGenerator; import org.springframework.util.IdGenerator;
/** /**
@ -42,6 +43,7 @@ import org.springframework.util.IdGenerator;
* <b>IMPORTANT</b>: This class is immutable. Any mutating operation such as * <b>IMPORTANT</b>: This class is immutable. Any mutating operation such as
* {@code put(..)}, {@code putAll(..)} and others will throw * {@code put(..)}, {@code putAll(..)} and others will throw
* {@link UnsupportedOperationException}. * {@link UnsupportedOperationException}.
* <p>Subclasses do have access to the raw headers, however, via {@link #getRawHeaders()}.
* <p> * <p>
* One way to create message headers is to use the * One way to create message headers is to use the
* {@link org.springframework.messaging.support.MessageBuilder MessageBuilder}: * {@link org.springframework.messaging.support.MessageBuilder MessageBuilder}:
@ -66,7 +68,7 @@ import org.springframework.util.IdGenerator;
* @see org.springframework.messaging.support.MessageBuilder * @see org.springframework.messaging.support.MessageBuilder
* @see org.springframework.messaging.support.MessageHeaderAccessor * @see org.springframework.messaging.support.MessageHeaderAccessor
*/ */
public final class MessageHeaders implements Map<String, Object>, Serializable { public class MessageHeaders implements Map<String, Object>, Serializable {
private static final long serialVersionUID = -4615750558355702881L; private static final long serialVersionUID = -4615750558355702881L;
@ -96,13 +98,39 @@ public final class MessageHeaders implements Map<String, Object>, Serializable {
private final Map<String, Object> headers; private final Map<String, Object> headers;
/**
* Consructs a {@link MessageHeaders} from the headers map; adding (or
* overwriting) the {@link #ID} and {@link #TIMESTAMP} headers.
* @param headers a map with headers to add
*/
public MessageHeaders(Map<String, Object> headers) { public MessageHeaders(Map<String, Object> headers) {
this(headers, ((idGenerator != null) ? idGenerator : defaultIdGenerator).generateId(),
System.currentTimeMillis());
}
/**
* Constructor allowing a sub-class to access the (mutable) header map as well
* to provide the ID and TIMESTAMP header values.
*
* @param headers a map with headers to add
* @param id the value for the {@link #ID} header, never {@code null}
* @param timestamp the value for the {@link #TIMESTAMP} header,
* or {@code null} meaning no timestamp header
*/
protected MessageHeaders(Map<String, Object> headers, UUID id, Long timestamp) {
Assert.notNull(id, "'id' is required");
this.headers = (headers != null) ? new HashMap<String, Object>(headers) : new HashMap<String, Object>(); this.headers = (headers != null) ? new HashMap<String, Object>(headers) : new HashMap<String, Object>();
this.headers.put(ID, ((idGenerator != null) ? idGenerator : defaultIdGenerator).generateId()); this.headers.put(ID, id);
this.headers.put(TIMESTAMP, System.currentTimeMillis()); if (timestamp != null) {
this.headers.put(TIMESTAMP, timestamp);
}
} }
protected Map<String, Object> getRawHeaders() {
return this.headers;
}
public UUID getId() { public UUID getId() {
return this.get(ID, UUID.class); return this.get(ID, UUID.class);
} }

20
spring-messaging/src/test/java/org/springframework/messaging/MessageHeadersTests.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2013 the original author or authors. * Copyright 2002-2014 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.
@ -23,6 +23,8 @@ import java.io.ObjectOutputStream;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.UUID;
import java.util.concurrent.atomic.AtomicLong;
import org.junit.Test; import org.junit.Test;
@ -32,6 +34,7 @@ import static org.junit.Assert.*;
* Test fixture for {@link MessageHeaders}. * Test fixture for {@link MessageHeaders}.
* *
* @author Rossen Stoyanchev * @author Rossen Stoyanchev
* @author Gary Russell
*/ */
public class MessageHeadersTests { public class MessageHeadersTests {
@ -138,6 +141,21 @@ public class MessageHeadersTests {
assertNull(output.get("address")); assertNull(output.get("address"));
} }
@Test
public void subClassWithCustomIdAndNoTimestamp() {
final AtomicLong id = new AtomicLong();
@SuppressWarnings("serial")
class MyMH extends MessageHeaders {
public MyMH() {
super(null, new UUID(0, id.incrementAndGet()), null);
}
}
MessageHeaders headers = new MyMH();
assertEquals("00000000-0000-0000-0000-000000000001", headers.getId().toString());
assertEquals(1, headers.size());
}
private static Object serializeAndDeserialize(Object object) throws Exception { private static Object serializeAndDeserialize(Object object) throws Exception {
ByteArrayOutputStream baos = new ByteArrayOutputStream(); ByteArrayOutputStream baos = new ByteArrayOutputStream();

Loading…
Cancel
Save