當前位置: 首頁>>代碼示例>>Java>>正文


Java WritableEventStream類代碼示例

本文整理匯總了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());
}
 
開發者ID:JEEventStore,項目名稱:JEEventStore,代碼行數:20,代碼來源:OptimisticEventStoreServiceTest.java

示例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);
    }
}
 
開發者ID:JEEventStore,項目名稱:JEECQRS-JCommonDomain-Integration,代碼行數:18,代碼來源:CommandLoggerService.java

示例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());
    }
}
 
開發者ID:JEEventStore,項目名稱:JEEventStore,代碼行數:10,代碼來源:OptimisticEventStoreServiceTest.java

示例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());
}
 
開發者ID:JEEventStore,項目名稱:JEEventStore,代碼行數:10,代碼來源:OptimisticEventStoreServiceTest.java

示例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());
}
 
開發者ID:JEEventStore,項目名稱:JEEventStore,代碼行數:11,代碼來源:OptimisticEventStoreServiceTest.java

示例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());
}
 
開發者ID:JEEventStore,項目名稱:JEEventStore,代碼行數:8,代碼來源:OptimisticEventStreamTest.java

示例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);
        }
    };
}
 
開發者ID:JEEventStore,項目名稱:JCommonDomain,代碼行數:13,代碼來源:AbstractJEEventStoreRepository.java

示例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);
    }
}
 
開發者ID:JEEventStore,項目名稱:JCommonDomain,代碼行數:8,代碼來源:AbstractJEEventStoreRepository.java

示例10: busForAdd

import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
@Override
protected EventSourcingBus<Event> busForAdd(String streamId) {
    WritableEventStream stream = eventStore().createStream(bucketId(), streamId);
    return busForStream(stream);
}
 
開發者ID:JEEventStore,項目名稱:JCommonDomain,代碼行數:6,代碼來源:AbstractJEEventStoreRepository.java

示例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);
}
 
開發者ID:JEEventStore,項目名稱:JCommonDomain,代碼行數:6,代碼來源:AbstractJEEventStoreRepository.java

示例12: appendToStream

import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
protected void appendToStream(WritableEventStream stream, Event event) {
    stream.append(event);
}
 
開發者ID:JEEventStore,項目名稱:JCommonDomain,代碼行數:4,代碼來源:AbstractJEEventStoreRepository.java

示例13: streamFor

import org.jeeventstore.WritableEventStream; //導入依賴的package包/類
protected WritableEventStream streamFor(Command command) {
    return eventStore.createStream(commandBucketId, streamIdFor(command));
}
 
開發者ID:JEEventStore,項目名稱:JEECQRS-JCommonDomain-Integration,代碼行數:4,代碼來源:CommandLoggerService.java

示例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);
}
 
開發者ID:JEEventStore,項目名稱:JEEventStore,代碼行數:19,代碼來源:OptimisticEventStream.java


注:本文中的org.jeeventstore.WritableEventStream類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。