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


Java EventBus類代碼示例

本文整理匯總了Java中com.lambdaworks.redis.event.EventBus的典型用法代碼示例。如果您正苦於以下問題:Java EventBus類的具體用法?Java EventBus怎麽用?Java EventBus使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


EventBus類屬於com.lambdaworks.redis.event包,在下文中一共展示了EventBus類的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testEventBus

import com.lambdaworks.redis.event.EventBus; //導入依賴的package包/類
@Test
public void testEventBus() throws Exception {

    DefaultClientResources sut = DefaultClientResources.create();

    EventBus eventBus = sut.eventBus();

    final TestSubscriber<Event> subject = new TestSubscriber<>();

    eventBus.get().subscribe(subject);

    Event event = mock(Event.class);
    eventBus.publish(event);

    WaitFor.waitOrTimeout(new Condition() {
        @Override
        public boolean isSatisfied() {
            return !subject.getOnNextEvents().isEmpty();
        }
    }, timeout(seconds(2)));

    assertThat(subject.getOnNextEvents()).contains(event);
    assertThat(sut.shutdown(0, 0, TimeUnit.MILLISECONDS).get()).isTrue();
}
 
開發者ID:lettuce-io,項目名稱:lettuce-core,代碼行數:25,代碼來源:DefaultClientResourcesTest.java

示例2: testMetricsEvent

import com.lambdaworks.redis.event.EventBus; //導入依賴的package包/類
@Test
public void testMetricsEvent() throws Exception {

    EventBus eventBus = client.getResources().eventBus();
    MetricEventPublisher publisher = (MetricEventPublisher) ReflectionTestUtils.getField(client.getResources(),
            "metricEventPublisher");
    publisher.emitMetricsEvent();

    TestSubscriber<CommandLatencyEvent> subscriber = new TestSubscriber<>();
    Subscription subscription = eventBus.get().filter(redisEvent -> redisEvent instanceof CommandLatencyEvent).cast(CommandLatencyEvent.class).subscribe(subscriber);

    generateTestData();
    publisher.emitMetricsEvent();

    WaitFor.waitOrTimeout(() -> !subscriber.getOnNextEvents().isEmpty(), timeout(seconds(5)));

    subscription.unsubscribe();

    subscriber.assertValueCount(1);
}
 
開發者ID:lettuce-io,項目名稱:lettuce-core,代碼行數:21,代碼來源:ClientMetricsTest.java

示例3: testMetricsEvent

import com.lambdaworks.redis.event.EventBus; //導入依賴的package包/類
@Test
public void testMetricsEvent() throws Exception {

    EventBus eventBus = clientResources.eventBus();
    MetricEventPublisher publisher = (MetricEventPublisher) ReflectionTestUtils.getField(clientResources,
            "metricEventPublisher");
    publisher.emitMetricsEvent();

    final TestSubscriber<CommandLatencyEvent> subscriber = new TestSubscriber<CommandLatencyEvent>();
    Subscription subscription = eventBus.get().filter(new Func1<Event, Boolean>() {
        @Override
        public Boolean call(Event redisEvent) {

            return redisEvent instanceof CommandLatencyEvent;
        }
    }).cast(CommandLatencyEvent.class).subscribe(subscriber);

    generateTestData();

    publisher.emitMetricsEvent();

    WaitFor.waitOrTimeout(new Condition() {
        @Override
        public boolean isSatisfied() {
            return !subscriber.getOnNextEvents().isEmpty();
        }
    }, timeout(seconds(5)));

    subscription.unsubscribe();

    subscriber.assertValueCount(1);

    CommandLatencyEvent event = subscriber.getOnNextEvents().get(0);

    assertThat(event.getLatencies()).hasSize(2);
    assertThat(event.toString()).contains("local:any ->");
    assertThat(event.toString()).contains("commandType=PING");
}
 
開發者ID:mp911de,項目名稱:spinach,代碼行數:39,代碼來源:ClientMetricsTest.java

示例4: DefaultCommandLatencyEventPublisher

import com.lambdaworks.redis.event.EventBus; //導入依賴的package包/類
public DefaultCommandLatencyEventPublisher(EventExecutorGroup eventExecutorGroup, EventPublisherOptions options,
        EventBus eventBus, CommandLatencyCollector commandLatencyCollector) {
    this.eventExecutorGroup = eventExecutorGroup;
    this.options = options;
    this.eventBus = eventBus;
    this.commandLatencyCollector = commandLatencyCollector;

    if (options.eventEmitInterval() > 0) {
        scheduledFuture = this.eventExecutorGroup.scheduleAtFixedRate(EMITTER, options.eventEmitInterval(),
                options.eventEmitInterval(), options.eventEmitIntervalUnit());
    }
}
 
開發者ID:lettuce-io,項目名稱:lettuce-core,代碼行數:13,代碼來源:DefaultCommandLatencyEventPublisher.java

示例5: testProvidedResources

import com.lambdaworks.redis.event.EventBus; //導入依賴的package包/類
@Test
    public void testProvidedResources() throws Exception {

        EventExecutorGroup executorMock = mock(EventExecutorGroup.class);
        EventLoopGroupProvider groupProviderMock = mock(EventLoopGroupProvider.class);
        Timer timerMock = mock(Timer.class);
        EventBus eventBusMock = mock(EventBus.class);
        CommandLatencyCollector latencyCollectorMock = mock(CommandLatencyCollector.class);
        NettyCustomizer nettyCustomizer = mock(NettyCustomizer.class);

        DefaultClientResources sut = new DefaultClientResources.Builder().eventExecutorGroup(executorMock)
                .eventLoopGroupProvider(groupProviderMock).timer(timerMock).eventBus(eventBusMock)
                .commandLatencyCollector(latencyCollectorMock)
.nettyCustomizer(nettyCustomizer)
                .build();

        assertThat(sut.eventExecutorGroup()).isSameAs(executorMock);
        assertThat(sut.eventLoopGroupProvider()).isSameAs(groupProviderMock);
        assertThat(sut.timer()).isSameAs(timerMock);
        assertThat(sut.eventBus()).isSameAs(eventBusMock);
        assertThat(sut.nettyCustomizer()).isSameAs(nettyCustomizer);

        assertThat(sut.shutdown().get()).isTrue();

        verifyZeroInteractions(executorMock);
        verifyZeroInteractions(groupProviderMock);
        verifyZeroInteractions(timerMock);
        verify(latencyCollectorMock).isEnabled();
        verifyNoMoreInteractions(latencyCollectorMock);
    }
 
開發者ID:lettuce-io,項目名稱:lettuce-core,代碼行數:31,代碼來源:DefaultClientResourcesTest.java

示例6: testMetrics

import com.lambdaworks.redis.event.EventBus; //導入依賴的package包/類
@Test
public void testMetrics() throws Exception {

    EventBus eventBus = client.getResources().eventBus();
    MetricEventPublisher publisher = (MetricEventPublisher) ReflectionTestUtils.getField(client.getResources(),
            "metricEventPublisher");
    publisher.emitMetricsEvent();

    TestSubscriber<CommandLatencyEvent> subscriber = new TestSubscriber<>();
    Subscription subscription = eventBus.get().filter(redisEvent -> redisEvent instanceof CommandLatencyEvent).cast(CommandLatencyEvent.class).subscribe(subscriber);

    generateTestData();
    publisher.emitMetricsEvent();

    WaitFor.waitOrTimeout(() -> !subscriber.getOnNextEvents().isEmpty(), timeout(seconds(5)));
    subscription.unsubscribe();

    subscriber.assertValueCount(1);

    CommandLatencyEvent event = subscriber.getOnNextEvents().get(0);

    Set<CommandLatencyId> ids = event.getLatencies().keySet();
    CommandMetrics commandMetrics = event.getLatencies().get(ids.iterator().next());
    assertThat(commandMetrics.getCompletion().getMin()).isBetween(0L, TimeUnit.MILLISECONDS.toMicros(100));
    assertThat(commandMetrics.getCompletion().getMax()).isBetween(0L, TimeUnit.MILLISECONDS.toMicros(200));

    assertThat(commandMetrics.getFirstResponse().getMin()).isBetween(0L, TimeUnit.MILLISECONDS.toMicros(100));
    assertThat(commandMetrics.getFirstResponse().getMax()).isBetween(0L, TimeUnit.MILLISECONDS.toMicros(200));
}
 
開發者ID:lettuce-io,項目名稱:lettuce-core,代碼行數:30,代碼來源:ClientMetricsTest.java

示例7: eventBus

import com.lambdaworks.redis.event.EventBus; //導入依賴的package包/類
@Override
public EventBus eventBus() {
    return eventBus;
}
 
開發者ID:lettuce-io,項目名稱:lettuce-core,代碼行數:5,代碼來源:DefaultClientResources.java

示例8: ConnectionEventTrigger

import com.lambdaworks.redis.event.EventBus; //導入依賴的package包/類
public ConnectionEventTrigger(ConnectionEvents connectionEvents, RedisChannelHandler<?, ?> connection, EventBus eventBus) {
    this.connectionEvents = connectionEvents;
    this.connection = connection;
    this.eventBus = eventBus;
}
 
開發者ID:lettuce-io,項目名稱:lettuce-core,代碼行數:6,代碼來源:ConnectionEventTrigger.java

示例9: eventBus

import com.lambdaworks.redis.event.EventBus; //導入依賴的package包/類
@Override
public EventBus eventBus() {
    return null;
}
 
開發者ID:lettuce-io,項目名稱:lettuce-core,代碼行數:5,代碼來源:EmptyClientResources.java

示例10: eventBus

import com.lambdaworks.redis.event.EventBus; //導入依賴的package包/類
/**
 * Returns the event bus used to publish events.
 *
 * @return the event bus
 */
EventBus eventBus();
 
開發者ID:lettuce-io,項目名稱:lettuce-core,代碼行數:7,代碼來源:ClientResources.java


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