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


Java SettableFuture.setException方法代碼示例

本文整理匯總了Java中com.google.common.util.concurrent.SettableFuture.setException方法的典型用法代碼示例。如果您正苦於以下問題:Java SettableFuture.setException方法的具體用法?Java SettableFuture.setException怎麽用?Java SettableFuture.setException使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.google.common.util.concurrent.SettableFuture的用法示例。


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

示例1: handleOperationComplete

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
protected synchronized void handleOperationComplete ( final SettableFuture<Void> result, final ChannelFuture future )
{
    if ( this.connectFuture != result )
    {
        // this should never happen
        return;
    }

    this.connectFuture = null;

    try
    {
        future.get ();
        this.channel = future.channel ();

        fireConnected ( this.channel );
        result.set ( null );
    }
    catch ( final InterruptedException | ExecutionException e )
    {
        fireDisconnected ( e );
        result.setException ( e );
    }
}
 
開發者ID:eclipse,項目名稱:neoscada,代碼行數:25,代碼來源:Client.java

示例2: run

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Override
public void run() {
    requestSemaphore.acquireUninterruptibly();
    try {
        currentBatch.getAndUpdate(batch -> (batch == this) ? null : batch); //Removing this batch from current
        Map<MetricDir, DirContent> dirsContent = metricSearch.loadDirsContent(requests.keySet());
        for (Map.Entry<MetricDir, DirContent> dirDirContentEntry : dirsContent.entrySet()) {
            requests.remove(dirDirContentEntry.getKey()).set(dirDirContentEntry.getValue());
        }
        if (!requests.isEmpty()) {
            log.error(requests.size() + " requests without data for dirs: " + requests.entrySet());
            throw new IllegalStateException("No data for dirs");
        }
    } catch (Exception e) {
        log.error("Failed to load content for dirs: " + requests.keySet(), e);

        for (SettableFuture<DirContent> settableFuture : requests.values()) {
            settableFuture.setException(e);
        }
    } finally {
        requestSemaphore.release();
    }
}
 
開發者ID:yandex,項目名稱:graphouse,代碼行數:24,代碼來源:DirContentBatcher.java

示例3: getNodeData

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Override
@SuppressWarnings("unchecked")
protected <M extends Message> ListenableFuture<M> getNodeData(
    WatchCallback watcher, String path, Message.Builder builder) {
  final SettableFuture<M> future = SettableFuture.create();
  byte[] data = new byte[]{};
  if (FileUtils.isFileExists(path)) {
    data = FileUtils.readFromFile(path);
  }
  if (data.length == 0) {
    future.set(null);
    return future;
  }

  try {
    builder.mergeFrom(data);
    future.set((M) builder.build());
  } catch (InvalidProtocolBufferException e) {
    future.setException(new RuntimeException("Could not parse " + Message.Builder.class, e));
  }

  return future;
}
 
開發者ID:DSC-SPIDAL,項目名稱:twister2,代碼行數:24,代碼來源:SharedFileSystemStateManager.java

示例4: setException

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
private void setException(SettableFuture<Long> result, Throwable e, CreateTableAnalyzedStatement statement) {
    e = Exceptions.unwrap(e);
    String message = e.getMessage();
    // sometimes message is empty
    if ("mapping [default]".equals(message) && e.getCause() != null) {
        // this is a generic mapping parse exception,
        // the cause has usually a better more detailed error message
        result.setException(e.getCause());
    } else if (statement.ifNotExists() &&
               (e instanceof IndexAlreadyExistsException
                || (e instanceof IndexTemplateAlreadyExistsException && statement.templateName() != null))) {
        result.set(null);
    } else {
        result.setException(e);
    }
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:17,代碼來源:TableCreator.java

示例5: start

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Override
public void start() {
    FluentIterable<NodeOperation> nodeOperations = FluentIterable.from(nodeOperationTrees)
        .transformAndConcat(new Function<NodeOperationTree, Iterable<? extends NodeOperation>>() {
            @Nullable
            @Override
            public Iterable<? extends NodeOperation> apply(NodeOperationTree input) {
                return input.nodeOperations();
            }
        });

    Map<String, Collection<NodeOperation>> operationByServer = NodeOperationGrouper.groupByServer(nodeOperations);
    InitializationTracker initializationTracker = new InitializationTracker(operationByServer.size());
    List<Tuple<ExecutionPhase, RowReceiver>> handlerPhases = createHandlerPhases(initializationTracker);
    try {
        setupContext(operationByServer, handlerPhases, initializationTracker);
    } catch (Throwable throwable) {
        for (SettableFuture<TaskResult> result : results) {
            result.setException(throwable);
        }
    }
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:23,代碼來源:ExecutionPhasesTask.java

示例6: innerClose

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Override
protected void innerClose(@Nullable Throwable t) {
    if (t != null) {
        for (SettableFuture<TaskResult> resultFuture : resultFutures) {
            if (!resultFuture.isDone()) {
                resultFuture.setException(t);
            }
        }
    }
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:11,代碼來源:ESJobContext.java

示例7: executeUpsertRequest

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
private void executeUpsertRequest(final UpsertByIdNode.Item item, final SettableFuture<TaskResult> futureResult) {
    ShardId shardId;
    try {
        shardId = clusterService.operationRouting().indexShards(
                clusterService.state(),
                item.index(),
                Constants.DEFAULT_MAPPING_TYPE,
                item.id(),
                item.routing()
        ).shardId();
    } catch (IndexNotFoundException e) {
        if (PartitionName.isPartition(item.index())) {
            futureResult.set(TaskResult.ZERO);
            return;
        }
        throw e;
    }

    ShardUpsertRequest upsertRequest = new ShardUpsertRequest(
            shardId, node.updateColumns(), node.insertColumns(), item.routing(), jobId());
    upsertRequest.continueOnError(false);
    ShardUpsertRequest.Item requestItem = new ShardUpsertRequest.Item(
            item.id(), item.updateAssignments(), item.insertValues(), item.version());
    upsertRequest.add(0, requestItem);

    UpsertByIdContext upsertByIdContext = new UpsertByIdContext(
            node.executionPhaseId(), upsertRequest, item, futureResult, transportShardUpsertActionDelegate);
    createJobExecutionContext(upsertByIdContext);
    try {
        jobExecutionContext.start();
    } catch (Throwable throwable) {
        futureResult.setException(throwable);
    }
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:35,代碼來源:UpsertByIdTask.java

示例8: executeRead

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Override
public <T> void executeRead(AbstractRead<T> readCmd, SettableFuture<T> proxyFuture) {
    LOG.debug("Tx {} executeRead {} called path = {}", getIdentifier(), readCmd.getClass().getSimpleName(),
            readCmd.getPath());

    final Throwable t;
    if (failure instanceof NoShardLeaderException) {
        t = new DataStoreUnavailableException(failure.getMessage(), failure);
    } else {
        t = failure;
    }
    proxyFuture.setException(new ReadFailedException("Error executeRead " + readCmd.getClass().getSimpleName()
            + " for path " + readCmd.getPath(), t));
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:15,代碼來源:NoOpTransactionContext.java

示例9: executeRead

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Override
public <T> void executeRead(final AbstractRead<T> readCmd, final SettableFuture<T> returnFuture) {
    LOG.debug("Tx {} executeRead {} called path = {}", getIdentifier(), readCmd.getClass().getSimpleName(),
            readCmd.getPath());

    // Send any batched modifications. This is necessary to honor the read uncommitted semantics of the
    // public API contract.

    acquireOperation();
    sendBatchedModifications();

    OnComplete<Object> onComplete = new OnComplete<Object>() {
        @Override
        public void onComplete(Throwable failure, Object response) throws Throwable {
            if (failure != null) {
                LOG.debug("Tx {} {} operation failed: {}", getIdentifier(), readCmd.getClass().getSimpleName(),
                        failure);

                returnFuture.setException(new ReadFailedException("Error checking "
                    + readCmd.getClass().getSimpleName() + " for path " + readCmd.getPath(), failure));
            } else {
                LOG.debug("Tx {} {} operation succeeded", getIdentifier(), readCmd.getClass().getSimpleName());
                readCmd.processResponse(response, returnFuture);
            }
        }
    };

    Future<Object> future = executeOperationAsync(readCmd.asVersion(getTransactionVersion()),
            actorContext.getOperationTimeout());

    future.onComplete(onComplete, actorContext.getClientDispatcher());
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:33,代碼來源:RemoteTransactionContext.java

示例10: processResponse

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Override
public void processResponse(Object readResponse, SettableFuture<Optional<NormalizedNode<?, ?>>> returnFuture) {
    if (ReadDataReply.isSerializedType(readResponse)) {
        ReadDataReply reply = ReadDataReply.fromSerializable(readResponse);
        returnFuture.set(Optional.<NormalizedNode<?, ?>>fromNullable(reply.getNormalizedNode()));
    } else {
        returnFuture.setException(new ReadFailedException("Invalid response reading data for path " + getPath()));
    }
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:10,代碼來源:ReadData.java

示例11: processResponse

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Override
public void processResponse(Object response, SettableFuture<Boolean> returnFuture) {
    if (DataExistsReply.isSerializedType(response)) {
        returnFuture.set(Boolean.valueOf(DataExistsReply.fromSerializable(response).exists()));
    } else {
        returnFuture.setException(new ReadFailedException("Invalid response checking exists for path "
                + getPath()));
    }
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:10,代碼來源:DataExists.java

示例12: testFireOnceMajorityFailed1

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Test
public void testFireOnceMajorityFailed1() {

    SettableFuture<Boolean> f1 = SettableFuture.create();
    SettableFuture<Boolean> f2 = SettableFuture.create();

    List<ListenableFuture<Boolean>> responses = Lists.newArrayList(f1, f2, Futures.<Boolean> immediateFuture(Boolean.TRUE));

    ListenableFuture<Boolean> collector = majorityResponse(responses, Identity);

    f1.setException(new Exception());
    assertFalse(collector.isDone());

    f2.setException(new Exception());
    assertTrue(collector.isDone());

    assertFalse(Futures.getUnchecked(collector));

}
 
開發者ID:lemonJun,項目名稱:TakinRPC,代碼行數:20,代碼來源:MajorityCollectorTest.java

示例13: testFireOnceMajorityFailed

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Test
public void testFireOnceMajorityFailed() {

    SettableFuture<Boolean> f1 = SettableFuture.create();
    SettableFuture<Boolean> f2 = SettableFuture.create();
    SettableFuture<Boolean> f3 = SettableFuture.create();

    List<ListenableFuture<Boolean>> responses = Lists.newArrayList(f1, f2, f3, Futures.<Boolean> immediateFuture(Boolean.TRUE));

    ListenableFuture<Boolean> collector = majorityResponse(responses, Identity);

    f1.setException(new Exception());
    assertFalse(collector.isDone());

    f2.setException(new Exception());
    assertFalse(collector.isDone());

    f3.set(Boolean.TRUE);
    assertTrue(collector.isDone());

    assertTrue(Futures.getUnchecked(collector));

}
 
開發者ID:lemonJun,項目名稱:TakinRPC,代碼行數:24,代碼來源:MajorityCollectorTest.java

示例14: sendRequest

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
@Override
public <T extends ApiResponse> ListenableFuture<T> sendRequest( final ApiVersion version, final String path, final Class<T> expectedType ) {
    final SettableFuture<T> apiResponseFuture = SettableFuture.create( );
    try {
        final ApiRequest request = ApiRequestBuilder.newRequest( )
                .to( _configuration.getServerUrl( ) )
                .forUser( _configuration.getCredentialsUser( ) )
                .withPassword( _configuration.getCredentialsPassword( ) )
                .request( path )
                .apiVersion( version )
                .build( );

        LOGGER.info( "<< REQUEST: to {}", request );

        final AsyncHttpClient.BoundRequestBuilder httpRequest = _httpClient
                .prepareGet( request.getURI( ) )
                .addHeader( HttpHeaders.ACCEPT, "application/json" );

        if ( !request.isGuestMode( ) ) {
            final Realm realm = new Realm.RealmBuilder( )
                    .setPrincipal( request.getUsername( ) )
                    .setPassword( request.getPassword( ) )
                    .setUsePreemptiveAuth( true )
                    .setScheme( Realm.AuthScheme.BASIC )
                    .build( );
            httpRequest.setRealm( realm );
        }

        if ( _configuration.isUseProxy( ) ) {
            // CODEREVIEW Let the user choose the protocol ?
            final ProxyServer proxyServer = new ProxyServer( ProxyServer.Protocol.HTTP, checkNotNull( _configuration.getProxyHost( ), "Proxy hostname is not defined" ), _configuration.getProxyPort( ), _configuration.getProxyCredentialsUser( ), _configuration.getProxyCredentialsPassword( ) );
            httpRequest.setProxyServer( proxyServer );
        }

        httpRequest.execute( new AsyncCompletionHandler<Void>( ) {
            @Override
            public void onThrowable( final Throwable t ) {
                super.onThrowable( t );
                apiResponseFuture.setException( t );
            }

            @Override
            public Void onCompleted( final Response response ) throws Exception {

                if ( response.getStatusCode( ) != 200 ) {
                    LOGGER.error( ">> RESPONSE: for {} has status code {}", request, response.getStatusCode( ) );
                    apiResponseFuture.setException( new ApiException( "Http status code is " + response.getStatusCode( ) + " when requesting uri: " + response.getUri( ) ) );
                    return null;
                }

                final String content = response.getResponseBody( Charsets.UTF_8.name( ) );
                LOGGER.debug( ">> RESPONSE: for {} has content: {}", request, content );

                final Gson gson = new GsonBuilder( ).create( );
                final T jsonResponse = gson.fromJson( content, expectedType );
                apiResponseFuture.set( jsonResponse );

                return null;
            }
        } );
    } catch ( Exception e ) {
        apiResponseFuture.setException( e );
    }

    return apiResponseFuture;
}
 
開發者ID:u2032,項目名稱:wall-t,代碼行數:67,代碼來源:ApiRequestController.java

示例15: testOptimisticAdoptPostResolveFailure

import com.google.common.util.concurrent.SettableFuture; //導入方法依賴的package包/類
/**
 * Test the completion and callback invocation of {@link RedFutureHub}
 * optimistic union of adopted futures that later were failed
 */
@Test
public void testOptimisticAdoptPostResolveFailure() throws Throwable {
    AtomicBoolean reachedSuccessBlock = new AtomicBoolean(false);
    AtomicBoolean reachedFailureBlock = new AtomicBoolean(false);
    AtomicBoolean reachedFinallyBlock = new AtomicBoolean(false);
    RedFutureHub hub = RedFuture.hub();
    OpenRedFuture future1 = RedFuture.future();
    OpenRedFuture future2 = RedFuture.future();
    OpenRedFuture future3 = RedFuture.future();
    OpenRedFutureOf<Object> futureOf1 = hub.provideFutureOf();
    OpenRedFutureOf<Object> futureOf2 = hub.provideFutureOf();
    SettableFuture<Object> settableFuture1 = SettableFuture.create();
    SettableFuture<Object> settableFuture2 = SettableFuture.create();
    SettableFuture<Object> settableFuture3 = SettableFuture.create();
    SettableFuture<Object> settableFuture4 = SettableFuture.create();
    SettableFuture<Object> settableFuture5 = SettableFuture.create();
    List<RedFuture> redFutureCollection = new LinkedList<>();
    redFutureCollection.add(future2);
    redFutureCollection.add(futureOf1);
    List<ListenableFuture> listenableFutureCollection = new LinkedList<>();
    listenableFutureCollection.add(settableFuture1);
    listenableFutureCollection.add(settableFuture2);
    hub.adoptFuture(future1);
    hub.adoptFutures(redFutureCollection);
    hub.adoptFutures(future3, futureOf2);
    hub.adoptListenableFuture(settableFuture3);
    hub.adoptListenableFutures(listenableFutureCollection);
    hub.adoptListenableFutures(settableFuture4, settableFuture5);
    RedFuture union = hub.uniteOptimistically();
    union.addSuccessCallback(() -> reachedSuccessBlock.set(true));
    union.addFailureCallback(throwable -> reachedFailureBlock.set(true));
    union.addFinallyCallback(() -> reachedFinallyBlock.set(true));
    Assert.assertFalse(reachedFinallyBlock.get());
    Assert.assertFalse(reachedSuccessBlock.get());
    Assert.assertFalse(reachedFailureBlock.get());
    settableFuture1.setException(new TestException());
    Assert.assertTrue(reachedFinallyBlock.get());
    Assert.assertFalse(reachedSuccessBlock.get());
    Assert.assertTrue(reachedFailureBlock.get());
}
 
開發者ID:avivcarmis,項目名稱:java-red,代碼行數:45,代碼來源:TestRedFuture.java


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