Skip to content

Commit

Permalink
Add additional utility methods
Browse files Browse the repository at this point in the history
  • Loading branch information
olegz committed Nov 1, 2024
1 parent 824403d commit ba09e40
Show file tree
Hide file tree
Showing 3 changed files with 101 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,12 @@ public final class BinderHeaders {
IntegrationMessageHeaderAccessor.SEQUENCE_NUMBER, MessageHeaders.CONTENT_TYPE};

private static final String PREFIX = "scst_";


/**
* Name of the Message header identifying structure for batch Message headers.
*/
public static String BATCH_HEADERS = PREFIX + "batchHeaders";

/**
* Indicates the name of the target destination the binder should use if they
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,21 +18,81 @@

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;

import org.springframework.cloud.stream.binder.BinderHeaders;
import org.springframework.messaging.Message;
import org.springframework.messaging.MessageHeaders;
import org.springframework.messaging.support.MessageBuilder;
import org.springframework.util.Assert;

/**
* @author Oleg Zhurakousky
* @since 4.2
*/
public class StandardBatchUtils {
public final class StandardBatchUtils {

public static String BATCH_HEADERS = "scst_batchHeaders";
private StandardBatchUtils() {

}

/**
* Iterates over batch message structure returning {@link Iterable} of individual messages.
*
* @param batchMessage instance of batch {@link Message}
* @return instance of {@link Iterable} representing individual Messages in a batch {@link Message} as {@link Entry}.
*/
public static Iterable<Entry<Object, Map<String, Object>>> iterate(Message<List<Object>> batchMessage) {
return new Iterable<Map.Entry<Object,Map<String, Object>>>() {
@Override
public Iterator<Entry<Object, Map<String, Object>>> iterator() {
return new Iterator<Entry<Object, Map<String, Object>>>() {
int index = 0;
@Override
public Entry<Object, Map<String, Object>> next() {
return getMessageByIndex(batchMessage, index++);
}

@Override
public boolean hasNext() {
return index < batchMessage.getPayload().size();
}
};
}
};
}

/**
* Extracts individual {@link Message} by index from batch {@link Message}
* @param batchMessage instance of batch {@link Message}
* @param index index of individual {@link Message} in a batch
* @return individual {@link Message} in a batch {@link Message}
*/
public static Entry<Object, Map<String, Object>> getMessageByIndex(Message<List<Object>> batchMessage, int index) {
Assert.isTrue(index < batchMessage.getPayload().size(), "Index " + index + " is out of bounds as there are only "
+ batchMessage.getPayload().size() + " messages in a batch.");
return new Entry<Object, Map<String,Object>>() {

@Override
public Map<String, Object> setValue(Map<String, Object> value) {
throw new UnsupportedOperationException();
}

@SuppressWarnings("unchecked")
@Override
public Map<String, Object> getValue() {
return ((List<Map<String, Object>>) batchMessage.getHeaders().get(BinderHeaders.BATCH_HEADERS)).get(index);
}

@Override
public Object getKey() {
return batchMessage.getPayload().get(index);
}
};
}

public static class BatchMessageBuilder {

Expand All @@ -48,13 +108,13 @@ public BatchMessageBuilder addMessage(Object payload, Map<String, Object> batchH
return this;
}

public BatchMessageBuilder addHeader(String key, Object value) {
public BatchMessageBuilder addRootHeader(String key, Object value) {
this.headers.put(key, value);
return this;
}

public Message<List<Object>> build() {
this.headers.put(BATCH_HEADERS, this.batchHeaders);
this.headers.put(BinderHeaders.BATCH_HEADERS, this.batchHeaders);
return MessageBuilder.createMessage(payloads, new MessageHeaders(headers));
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,14 +18,18 @@

import static org.assertj.core.api.Assertions.assertThat;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;

import org.junit.jupiter.api.Test;
import org.springframework.cloud.stream.binder.BinderHeaders;
import org.springframework.cloud.stream.function.StandardBatchUtils.BatchMessageBuilder;
import org.springframework.messaging.Message;


/**
*
*/
Expand All @@ -36,7 +40,7 @@ public class StandardBatchUtilsTests {
public void testBatchMessageBuilder() {
BatchMessageBuilder builder = new BatchMessageBuilder();
builder.addMessage("foo", Collections.singletonMap("fooKey", "fooValue"));
builder.addHeader("a", "a");
builder.addRootHeader("a", "a");
builder.addMessage("bar", Collections.singletonMap("barKey", "barValue"));
builder.addMessage("baz", Collections.singletonMap("bazKey", "bazValue"));

Expand All @@ -45,7 +49,7 @@ public void testBatchMessageBuilder() {
List<Object> payloads = batchMessage.getPayload();
assertThat(payloads.size()).isEqualTo(3);

List<Map<String, Object>> batchHeaders = (List<Map<String, Object>>) batchMessage.getHeaders().get(StandardBatchUtils.BATCH_HEADERS);
List<Map<String, Object>> batchHeaders = (List<Map<String, Object>>) batchMessage.getHeaders().get(BinderHeaders.BATCH_HEADERS);
assertThat(batchHeaders.size()).isEqualTo(3);

assertThat(payloads.get(0)).isEqualTo("foo");
Expand All @@ -56,4 +60,29 @@ public void testBatchMessageBuilder() {

assertThat(batchMessage.getHeaders().get("a")).isEqualTo("a");
}

@Test
public void testIterator() {
BatchMessageBuilder builder = new BatchMessageBuilder();
builder.addMessage("foo", Collections.singletonMap("fooKey", "fooValue"));
builder.addRootHeader("a", "a");
builder.addMessage("bar", Collections.singletonMap("barKey", "barValue"));
builder.addMessage("baz", Collections.singletonMap("bazKey", "bazValue"));

Message<List<Object>> batchMessage = builder.build();

List<Entry<Object, Map<String, Object>>> entries = new ArrayList<>();
StandardBatchUtils.iterate(batchMessage).forEach(entry -> {
entries.add(entry);
});
assertThat(entries.size()).isEqualTo(3);
assertThat(entries.get(0).getKey()).isEqualTo("foo");
assertThat(entries.get(0).getValue().get("fooKey")).isEqualTo("fooValue");

assertThat(entries.get(1).getKey()).isEqualTo("bar");
assertThat(entries.get(1).getValue().get("barKey")).isEqualTo("barValue");

assertThat(entries.get(2).getKey()).isEqualTo("baz");
assertThat(entries.get(2).getValue().get("bazKey")).isEqualTo("bazValue");
}
}

0 comments on commit ba09e40

Please sign in to comment.