当前位置: 首页>>代码示例>>Java>>正文


Java Promise.failure方法代码示例

本文整理汇总了Java中scala.concurrent.Promise.failure方法的典型用法代码示例。如果您正苦于以下问题:Java Promise.failure方法的具体用法?Java Promise.failure怎么用?Java Promise.failure使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在scala.concurrent.Promise的用法示例。


在下文中一共展示了Promise.failure方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: moveToLocation

import scala.concurrent.Promise; //导入方法依赖的package包/类
@Override
final protected void moveToLocation(Promise<Void> v, double latitude, double longitude, double altitude) {
    synchronized (navigationLock) {
        if (navigationState.getRawValue() == NavigationState.IN_PROGRESS) {
            v.failure(new DroneException("Already navigating to " + getNavigator().getGoal() + ", abort this first."));
        } else if (navigationState.getRawValue() == NavigationState.UNAVAILABLE) {
            v.failure(new DroneException("Unable to navigate to goal"));
        } else if (!gpsFix.getRawValue()) {
            v.failure(new DroneException("No GPS fix yet."));
        } else {
            getNavigator().setCurrentLocation(location.getRawValue());
            getNavigator().setGoal(new Location(latitude, longitude, altitude));

            setNavigationState(NavigationState.IN_PROGRESS, NavigationStateReason.REQUESTED);
            v.success(null);
        }
    }
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:19,代码来源:NavigatedDroneActor.java

示例2: prematureExit

import scala.concurrent.Promise; //导入方法依赖的package包/类
private <T> boolean prematureExit(Promise<T> p) {
    if(connectionLost) {
        return true;
    }

    if(!initialized) {
        p.failure(new DroneException("Failed to send command. Not initialized yet."));
        return true;
    }

    if(crashed) {
        p.failure(new DroneException("Drone crashed, unable to execute commands"));
        return true;
    }
    return false;
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:17,代码来源:BepopSimulator.java

示例3: sendCommand

import scala.concurrent.Promise; //导入方法依赖的package包/类
private void sendCommand(Promise<Void> p, Serializable command) {
    if (sendMessage(command)) {
        p.success(null);
    } else {
        p.failure(new DroneException("Failed to send command. Not initialized yet."));
    }
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:8,代码来源:ArDrone2.java

示例4: takeOff

import scala.concurrent.Promise; //导入方法依赖的package包/类
@Override
protected void takeOff(Promise<Void> p) {
    //TODO: only return when status changes to taking off promises
    if (sendMessage(new TakeOffCommand())) {
        p.success(null);
    } else {
        p.failure(new DroneException("Failed to send command. Not initialized yet."));
    }
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:10,代码来源:Bebop.java

示例5: move3d

import scala.concurrent.Promise; //导入方法依赖的package包/类
@Override
protected void move3d(Promise<Void> p, double vx, double vy, double vz, double vr) {
    if (sendMessage(new MoveCommand(vx, vy, vz, vr))) {
        p.success(null); //ack the command
    } else {
        p.failure(new DroneException("Failed to send command. Not initialized yet."));
    }
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:9,代码来源:Bebop.java

示例6: setMaxTilt

import scala.concurrent.Promise; //导入方法依赖的package包/类
@Override
protected void setMaxTilt(Promise<Void> p, float degrees) {
    if (sendMessage(new SetMaxTiltCommand(degrees))) {
        p.success(null);
    } else {
        p.failure(new DroneException("Failed to send command. Not initialized yet."));
    }
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:9,代码来源:Bebop.java

示例7: setOutdoor

import scala.concurrent.Promise; //导入方法依赖的package包/类
@Override
protected void setOutdoor(Promise<Void> p, boolean outdoor) {
    if (sendMessage(new SetOutdoorCommand(outdoor))) {
        p.success(null);
    } else {
        p.failure(new DroneException("Failed to send command. Not initialized yet."));
    }
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:9,代码来源:Bebop.java

示例8: flatTrim

import scala.concurrent.Promise; //导入方法依赖的package包/类
@Override
protected void flatTrim(Promise<Void> p) {
    if (sendMessage(new FlatTrimCommand())) {
        p.success(null);
    } else {
        p.failure(new DroneException("Failed to send command. Not initialized yet."));
    }
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:9,代码来源:Bebop.java

示例9: flip

import scala.concurrent.Promise; //导入方法依赖的package包/类
@Override
protected void flip(Promise<Void> p, FlipType type) {
    if (sendMessage(new FlipCommand(type))) {
        p.success(null);
    } else {
        p.failure(new DroneException("Failed to send command. Not initialized yet."));
    }
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:9,代码来源:Bebop.java

示例10: initVideo

import scala.concurrent.Promise; //导入方法依赖的package包/类
@Override
protected void initVideo(Promise<Void> p) {
   if(sendMessage(new InitVideoCommand())){
       p.success(null);
   } else {
       p.failure(new DroneException("Failed to send command. Not initialized yet."));
   }
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:9,代码来源:Bebop.java

示例11: emergency

import scala.concurrent.Promise; //导入方法依赖的package包/类
@Override
protected void emergency(Promise<Void> p) {

    if (connectionLost) return;

    //  Land
    p.failure(new DroneException("action not implemented"));
}
 
开发者ID:ugent-cros,项目名称:cros-core,代码行数:9,代码来源:BepopSimulator.java

示例12: notifyWaitersOfFailure

import scala.concurrent.Promise; //导入方法依赖的package包/类
protected void notifyWaitersOfFailure(Throwable exception) {
	for (Promise<Object> waiter: awaitListeners){
		if (!waiter.isCompleted()){
			waiter.failure(exception);
		}
	}
	taskList.clear();
}
 
开发者ID:ranoble,项目名称:Megapode,代码行数:9,代码来源:ConcurrantCallable.java

示例13: handleCallbackException

import scala.concurrent.Promise; //导入方法依赖的package包/类
private void handleCallbackException(final String field,
		final SetterFailure onFailure, Throwable exception, Promise<Object> promise) {
	if (onFailure != null) {
		onFailure.handleFailure(getThis(), field, exception, promise);
	} else {
		getLogger().error(exception, "Failed without failure handler, falling back.");
	}
	if (!promise.isCompleted()){
		promise.failure(exception);
	}
}
 
开发者ID:ranoble,项目名称:Megapode,代码行数:12,代码来源:WidgetBase.java

示例14: findPrimaryShard

import scala.concurrent.Promise; //导入方法依赖的package包/类
/**
 * This method is overridden to ensure the previous Tx's ready operations complete
 * before we initiate the next Tx in the chain to avoid creation failures if the
 * previous Tx's ready operations haven't completed yet.
 */
@SuppressWarnings({ "unchecked", "rawtypes" })
@Override
protected Future<PrimaryShardInfo> findPrimaryShard(final String shardName, final TransactionIdentifier txId) {
    // Read current state atomically
    final State localState = currentState;

    // There are no outstanding futures, shortcut
    Future<?> previous = localState.previousFuture();
    if (previous == null) {
        return combineFutureWithPossiblePriorReadOnlyTxFutures(parent.findPrimaryShard(shardName, txId), txId);
    }

    final String previousTransactionId;

    if (localState instanceof Pending) {
        previousTransactionId = ((Pending) localState).getIdentifier().toString();
        LOG.debug("Tx: {} - waiting for ready futures with pending Tx {}", txId, previousTransactionId);
    } else {
        previousTransactionId = "";
        LOG.debug("Waiting for ready futures on chain {}", getHistoryId());
    }

    previous = combineFutureWithPossiblePriorReadOnlyTxFutures(previous, txId);

    // Add a callback for completion of the combined Futures.
    final Promise<PrimaryShardInfo> returnPromise = Futures.promise();

    final OnComplete onComplete = new OnComplete() {
        @Override
        public void onComplete(final Throwable failure, final Object notUsed) {
            if (failure != null) {
                // A Ready Future failed so fail the returned Promise.
                LOG.error("Tx: {} - ready future failed for previous Tx {}", txId, previousTransactionId);
                returnPromise.failure(failure);
            } else {
                LOG.debug("Tx: {} - previous Tx {} readied - proceeding to FindPrimaryShard",
                        txId, previousTransactionId);

                // Send the FindPrimaryShard message and use the resulting Future to complete the
                // returned Promise.
                returnPromise.completeWith(parent.findPrimaryShard(shardName, txId));
            }
        }
    };

    previous.onComplete(onComplete, getActorContext().getClientDispatcher());
    return returnPromise.future();
}
 
开发者ID:hashsdn,项目名称:hashsdn-controller,代码行数:54,代码来源:TransactionChainProxy.java

示例15: testJobClientRecovery

import scala.concurrent.Promise; //导入方法依赖的package包/类
/**
 * Tests whether the JobClientActor can connect to a newly elected leading job manager to obtain
 * the JobExecutionResult. The submitted job blocks for the first execution attempt. The
 * leading job manager will be killed so that the second job manager will be elected as the
 * leader. The newly elected leader has to retrieve the checkpointed job from ZooKeeper
 * and continue its execution. This time, the job does not block and, thus, can be finished.
 * The execution result should be sent to the JobClientActor which originally submitted the
 * job.
 *
 * @throws Exception
 */
@Test
public void testJobClientRecovery() throws Exception {
	File rootFolder = tempFolder.getRoot();

	Configuration config = ZooKeeperTestUtils.createZooKeeperHAConfig(
		zkServer.getConnectString(),
		rootFolder.getPath());

	config.setInteger(ConfigConstants.LOCAL_NUMBER_JOB_MANAGER, 2);
	config.setInteger(ConfigConstants.LOCAL_NUMBER_TASK_MANAGER, 1);

	final TestingCluster cluster = new TestingCluster(config);
	cluster.start();

	JobVertex blockingVertex = new JobVertex("Blocking Vertex");
	blockingVertex.setInvokableClass(BlockingTask.class);
	blockingVertex.setParallelism(1);
	final JobGraph jobGraph = new JobGraph("Blocking Test Job", blockingVertex);
	final Promise<JobExecutionResult> promise = new scala.concurrent.impl.Promise.DefaultPromise<>();

	Deadline deadline = new FiniteDuration(2, TimeUnit.MINUTES).fromNow();

	try {
		Thread submitter = new Thread(new Runnable() {
			@Override
			public void run() {
				try {
					JobExecutionResult result = cluster.submitJobAndWait(jobGraph, false);
					promise.success(result);
				} catch (Exception e) {
					promise.failure(e);
				}
			}
		});

		submitter.start();

		synchronized (BlockingTask.waitLock) {
			while (BlockingTask.HasBlockedExecution < 1 && deadline.hasTimeLeft()) {
				BlockingTask.waitLock.wait(deadline.timeLeft().toMillis());
			}
		}

		if (deadline.isOverdue()) {
			Assert.fail("The job has not blocked within the given deadline.");
		}

		ActorGateway gateway = cluster.getLeaderGateway(deadline.timeLeft());

		gateway.tell(TestingJobManagerMessages.getDisablePostStop());
		gateway.tell(PoisonPill.getInstance());

		// if the job fails then an exception is thrown here
		Await.result(promise.future(), deadline.timeLeft());
	} finally {
		cluster.stop();
	}
}
 
开发者ID:axbaretto,项目名称:flink,代码行数:70,代码来源:JobClientActorRecoveryITCase.java


注:本文中的scala.concurrent.Promise.failure方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。