本文整理匯總了Java中org.jeeventstore.WritableEventStream類的典型用法代碼示例。如果您正苦於以下問題:Java WritableEventStream類的具體用法?Java WritableEventStream怎麽用?Java WritableEventStream使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
WritableEventStream類屬於org.jeeventstore包,在下文中一共展示了WritableEventStream類的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: testOpenStreamForWritingConcurrency
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
@Test
public void testOpenStreamForWritingConcurrency() throws Exception {
cleanup();
fill(BUCKET_ID, "FOO", 10);
caught = false;
caughtCS = null;
WritableEventStream wes = eventStore.openStreamForWriting(BUCKET_ID, "FOO", 8);
wes.append("bla");
try {
wes.commit(UUID.randomUUID().toString());
fail("Should have failed by now");
} catch (ConcurrencyException e) {
// expected
}
assertTrue(!caught);
assertTrue(caughtCS == null);
assertEquals(BUCKET_ID, wes.bucketId());
assertEquals("FOO", wes.streamId());
}
示例2: log
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
@Override
@Asynchronous
public void log(Command<?> command, Map<String, String> metadata) {
Validate.notNull(command, "command must not be null");
Validate.notNull(metadata, "metadata must not be null");
String commandId = command.id().toString();
WritableEventStream stream = streamFor(command);
CommandLogEnvelope<Command<?>> envelope = new CommandLogEnvelope<Command<?>>(command,
new HashMap<>(metadata));
log.log(Level.FINE, "Logging command: {0}", envelope);
stream.append(envelope);
try {
stream.commit(commandId);
} catch (DuplicateCommitException | ConcurrencyException e) {
throw new RuntimeException(e);
}
}
示例3: dispatch
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
@Override
public void dispatch(Event event) {
log.fine("Dispatch event #" + event.id() + ", " + event);
String eventId = event.id().toString();
String streamId = String.format("%s:%s", event.getClass().getCanonicalName(), eventId);
WritableEventStream stream = eventStore.createStream(sagaTimeoutEventBucketId, streamId);
stream.append(event);
try {
stream.commit(streamId);
} catch (ConcurrencyException | DuplicateCommitException e) {
// this simply means the event has been stored already, this is good,
// we can ignore these errors
log.log(Level.FINE, "Caught exception saving stream with id {0}, but ignored on purpose: {1}",
new Object[]{streamId, e});
}
}
開發者ID:JEEventStore,項目名稱:JEECQRS-JCommonDomain-Integration,代碼行數:17,代碼來源:SagaTrackerPersistingEventBusService.java
示例4: fill
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
private void fill(String bucketId, String streamId, int count) throws Exception {
WritableEventStream wes = eventStore.createStream(bucketId, streamId);
for (int i = 0; i < count; i++) {
List<Integer> data = TestUtils.randomdata(i % 5 + 1);
for (Integer ii : data)
wes.append(ii);
wes.commit(UUID.randomUUID().toString());
}
}
示例5: testCreateStream
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
@Test
public void testCreateStream() throws Exception {
cleanup();
WritableEventStream wes = eventStore.createStream(BUCKET_ID, "CREATED");
assertEquals(wes.version(), 0);
testWriting(wes);
assertEquals(BUCKET_ID, wes.bucketId());
assertEquals("CREATED", wes.streamId());
}
示例6: testOpenStreamForWriting
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
@Test
public void testOpenStreamForWriting() throws Exception {
cleanup();
fill(BUCKET_ID, "FOO", 10);
WritableEventStream wes = eventStore.openStreamForWriting(BUCKET_ID, "FOO", 10);
assertEquals(wes.version(), 10);
testWriting(wes);
assertEquals(BUCKET_ID, wes.bucketId());
assertEquals("FOO", wes.streamId());
}
示例7: test_create_writeable
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
@Test
public void test_create_writeable() {
WritableEventStream oes = OptimisticEventStream.createWritable(BUCKET_ID, STREAM_ID, 28l, persistence);
assertEquals(oes.bucketId(), BUCKET_ID);
assertEquals(oes.streamId(), STREAM_ID);
assertEquals(28l, oes.version());
}
示例8: busForStream
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
private EventSourcingBus<Event> busForStream(final WritableEventStream stream) {
return new EventSourcingBus<Event>() {
@Override
public void store(Event event) {
appendToStream(stream, event);
}
@Override
public void commit(String commitId) {
commitChanges(stream, commitId);
}
};
}
示例9: commitChanges
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
protected void commitChanges(WritableEventStream stream, String commitId) {
try {
stream.commit(commitId);
} catch (DuplicateCommitException | ConcurrencyException e) {
throw new RuntimeException("committing changes failed: " + e.getMessage(), e);
}
}
示例10: busForAdd
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
@Override
protected EventSourcingBus<Event> busForAdd(String streamId) {
WritableEventStream stream = eventStore().createStream(bucketId(), streamId);
return busForStream(stream);
}
示例11: busForSave
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
@Override
protected EventSourcingBus<Event> busForSave(String streamId, long version) {
WritableEventStream stream = eventStore().openStreamForWriting(bucketId(), streamId, version);
return busForStream(stream);
}
示例12: appendToStream
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
protected void appendToStream(WritableEventStream stream, Event event) {
stream.append(event);
}
示例13: streamFor
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
protected WritableEventStream streamFor(Command command) {
return eventStore.createStream(commandBucketId, streamIdFor(command));
}
示例14: createWritable
import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
/**
* Factory method to create a new writable event stream supporting optimistic locking.
* Does not query the persistence layer upon creation.
*
* @param bucketId the identifier of the bucket the stream belongs to
* @param streamId the identifier of the stream
* @param version the version of the stream
* @param persistence the persistence layer to which changes are to be committed
* @return the stream
*/
protected static WritableEventStream createWritable(
String bucketId,
String streamId,
long version,
EventStorePersistence persistence) {
return new OptimisticEventStream(bucketId, streamId, version, persistence);
}