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


Java ActorRef類代碼示例

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


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

示例1: run

import akka.actor.ActorRef; //導入依賴的package包/類
@Override
public void run() {
    final Future<ActorRef> localShardFuture =
            context.findLocalShardAsync(ClusterUtils.getCleanShardName(toLookup.getRootIdentifier()));

    localShardFuture.onComplete(new OnComplete<ActorRef>() {
        @Override
        public void onComplete(Throwable throwable, ActorRef actorRef) throws Throwable {
            if (throwable != null) {
                tryReschedule(throwable);
            } else {
                LOG.debug("Local backend for shard[{}] lookup successful, starting leader lookup..", toLookup);

                system.scheduler().scheduleOnce(
                        SHARD_LOOKUP_TASK_INTERVAL,
                        new ShardLeaderLookupTask(system, replyTo, context, clusterWrapper, actorRef,
                                shardingService, toLookup, lookupMaxRetries),
                        system.dispatcher());
            }
        }
    }, system.dispatcher());
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:23,代碼來源:ShardedDataTreeActor.java

示例2: createRoom

import akka.actor.ActorRef; //導入依賴的package包/類
private void createRoom(ApiRequestForward forward) {
    CREATE_ROOM_REQUEST request;
    try {
        request = CREATE_ROOM_REQUEST.parseFrom(forward.getArgs(0));
    } catch (InvalidProtocolBufferException e) {
        getLogger().error("Input args error {}", e);
        return;
    }

    // fixme 加載用戶信息
    // 默認用戶為在線
    final ActorRef roomContext = getContext().actorOf(RoomContext.props(request.getRoomId(), null), "roomContext");
    roomIdToRoomContextActor.put(request.getRoomId(), roomContext);

    // 把當前用戶加入 room Id 列表上
    request.getUserIdsList().forEach(u -> usersToRoomId.put(u, request.getRoomId()));
}
 
開發者ID:freedompy,項目名稱:commelina,代碼行數:18,代碼來源:RoomBackend.java

示例3: getRecommendedContents

import akka.actor.ActorRef; //導入依賴的package包/類
@Test()
public void getRecommendedContents() {

    TestKit probe = new TestKit(system);
    ActorRef subject = system.actorOf(props);

    Request reqObj = new Request();
    reqObj.setRequestId("1");
    reqObj.setOperation(ActorOperations.GET_RECOMMENDED_COURSES.getValue());
    HashMap<String, Object> innerMap = new HashMap<>();
    innerMap.put(JsonKey.REQUESTED_BY, "USR");
    reqObj.setRequest(innerMap);

    subject.tell(reqObj, probe.getRef());
    probe.expectMsgClass(duration("100 second"),ProjectCommonException.class);

}
 
開發者ID:project-sunbird,項目名稱:sunbird-lms-mw,代碼行數:18,代碼來源:RecommendorActorTest.java

示例4: shouldSendCoffeePreparedWithRandomCoffeeForInaccurateResponse

import akka.actor.ActorRef; //導入依賴的package包/類
@Test
public void shouldSendCoffeePreparedWithRandomCoffeeForInaccurateResponse() {
    new JavaTestKit(system) {{
        Integer accuracy = 50;
        Long runs = 1000L;
        ActorRef guest = system.deadLetters();
        ActorRef barista = system.actorOf(Barista.props(duration("0 milliseconds"), accuracy));
        List<Coffee> coffees = new ArrayList<>();
        for (int i = 0; i < runs; i++) {
            barista.tell(new Barista.PrepareCoffee(new Coffee.Akkaccino(), guest), getRef());
            Barista.CoffeePrepared cp = expectMsgClass(duration("50 milliseconds"), Barista.CoffeePrepared.class);
            coffees.add(cp.coffee);
        }
        Long expectedCount = runs * accuracy / 100;
        Long variation = expectedCount / 10;
        Long numberOfCorrectCoffee = coffees.stream().filter(c -> c.equals(new Coffee.Akkaccino())).count();
        assertThat(numberOfCorrectCoffee).isBetween(expectedCount - variation, expectedCount + variation);
    }};
}
 
開發者ID:ironfish,項目名稱:oreilly-reactive-with-akka,代碼行數:20,代碼來源:BaristaTest.java

示例5: testCourseProgressWithInvalidBatchIdNull

import akka.actor.ActorRef; //導入依賴的package包/類
@Test
public void testCourseProgressWithInvalidBatchIdNull(){

  TestKit probe = new TestKit(system);
  ActorRef subject = system.actorOf(props);

  Request actorMessage = new Request();
  actorMessage.put(JsonKey.REQUESTED_BY , userId);
  actorMessage.put(JsonKey.BATCH_ID , null);
  actorMessage.put(JsonKey.PERIOD , "fromBegining");
  actorMessage.setOperation(ActorOperations.COURSE_PROGRESS_METRICS.getValue());

  subject.tell(actorMessage, probe.getRef());
  ProjectCommonException res= probe.expectMsgClass(duration("100 second"),ProjectCommonException.class);

}
 
開發者ID:project-sunbird,項目名稱:sunbird-lms-mw,代碼行數:17,代碼來源:CourseMetricsActorTest.java

示例6: shouldRestartWaiterAndResendPrepareCoffeeToBaristaOnFailure

import akka.actor.ActorRef; //導入依賴的package包/類
@Test
public void shouldRestartWaiterAndResendPrepareCoffeeToBaristaOnFailure() {
    new JavaTestKit(system) {{
        createActor(CoffeeHouse.class, "resend-prepare-coffee", () -> new CoffeeHouse(Integer.MAX_VALUE) {
            @Override
            protected ActorRef createBarista() {
                return getRef();
            }

            @Override
            protected ActorRef createWaiter() { //stubbing out the waiter actor to always throw exception
                return context().actorOf(Props.create(AbstractActor.class, () -> new AbstractActor() {
                    @Override
                    public Receive createReceive() {
                        return receiveBuilder().matchAny(o -> {
                            throw new Waiter.FrustratedException(new Coffee.Akkaccino(), system.deadLetters());
                        }).build();
                    }
                }), "waiter");
            }
        });
        ActorRef waiter = expectActor(this, "/user/resend-prepare-coffee/waiter");
        waiter.tell("Blow up", ActorRef.noSender());
        expectMsgEquals(new Barista.PrepareCoffee(new Coffee.Akkaccino(), system.deadLetters()));
    }};
}
 
開發者ID:ironfish,項目名稱:oreilly-reactive-with-akka,代碼行數:27,代碼來源:CoffeeHouseTest.java

示例7: shouldLogResponseFromCoffeeHouse

import akka.actor.ActorRef; //導入依賴的package包/類
@Test
public void shouldLogResponseFromCoffeeHouse() {
    new JavaTestKit(system) {{
        interceptInfoLogMessage(this, "stub response", 1, () -> {
            new CoffeeHouseApp(system) {
                @Override
                protected ActorRef createCoffeeHouse() {
                    return createStubActor("stub-coffee-house", () -> new AbstractLoggingActor() {
                        @Override
                        public Receive createReceive() {
                            return receiveBuilder().matchAny(o -> getSender().tell("stub response", getSelf())).build();
                        }
                    });
                }
            };
        });
    }};
}
 
開發者ID:ironfish,項目名稱:oreilly-reactive-with-akka,代碼行數:19,代碼來源:CoffeeHouseAppTest.java

示例8: tell

import akka.actor.ActorRef; //導入依賴的package包/類
public static void tell(Request request) {

    if (null != BackgroundRequestRouterActor.routerMap
        && null != BackgroundRequestRouterActor.routerMap.get(request.getOperation())) {
      BackgroundRequestRouterActor.routerMap.get(request.getOperation()).tell(request,
          ActorRef.noSender());
    } else if (null != RequestRouterActor.routerMap
        && null != RequestRouterActor.routerMap.get(request.getOperation())) {
      RequestRouterActor.routerMap.get(request.getOperation()).tell(request, ActorRef.noSender());
    } else {
      Object obj =
          ActorSystemFactory.getActorSystem().initializeActorSystem(request.getOperation());
      if (obj instanceof ActorRef) {
        ProjectLogger
            .log("In ActorUtil(org.sunbird.learner.util) Actor ref is running " + ((ActorRef) obj));
        ((ActorRef) obj).tell(request, ActorRef.noSender());
      } else {
        ProjectLogger.log("In ActorUtil(org.sunbird.learner.util) Actor selection is running "
            + ((ActorSelection) obj));
        ((ActorSelection) obj).tell(request, ActorRef.noSender());
      }
    }
  }
 
開發者ID:project-sunbird,項目名稱:sunbird-lms-mw,代碼行數:24,代碼來源:ActorUtil.java

示例9: testUpdateTanentPreference

import akka.actor.ActorRef; //導入依賴的package包/類
@Test
public void testUpdateTanentPreference(){

  TestKit probe = new TestKit(system);
  ActorRef subject = system.actorOf(props);
  Request actorMessage = new Request();
  List<Map<String , Object>> reqList = new ArrayList<>();

  Map<String , Object> map = new HashMap<>();
  map.put(JsonKey.ROLE , "admin");
  reqList.add(map);

  actorMessage.getRequest().put(JsonKey.TENANT_PREFERENCE , reqList);
  actorMessage.getRequest().put(JsonKey.ROOT_ORG_ID , orgId);
  actorMessage.getRequest().put(JsonKey.REQUESTED_BY , USER_ID);
  actorMessage.setOperation(ActorOperations.UPDATE_TENANT_PREFERENCE.getValue());

  subject.tell(actorMessage, probe.getRef());
  Response res= probe.expectMsgClass(duration("100 second"),Response.class);
}
 
開發者ID:project-sunbird,項目名稱:sunbird-lms-mw,代碼行數:21,代碼來源:TenantPreferenceManagementActorTest.java

示例10: handleCanCommit

import akka.actor.ActorRef; //導入依賴的package包/類
/**
 * This method handles the canCommit phase for a transaction.
 *
 * @param transactionID the ID of the transaction to canCommit
 * @param sender the actor to which to send the response
 * @param shard the transaction's shard actor
 */
void handleCanCommit(final Identifier transactionID, final ActorRef sender, final Shard shard) {
    // Lookup the cohort entry that was cached previously (or should have been) by
    // transactionReady (via the ForwardedReadyTransaction message).
    final CohortEntry cohortEntry = cohortCache.get(transactionID);
    if (cohortEntry == null) {
        // Either canCommit was invoked before ready (shouldn't happen) or a long time passed
        // between canCommit and ready and the entry was expired from the cache or it was aborted.
        IllegalStateException ex = new IllegalStateException(
                String.format("%s: Cannot canCommit transaction %s - no cohort entry found", name, transactionID));
        log.error(ex.getMessage());
        sender.tell(new Failure(ex), shard.self());
        return;
    }

    cohortEntry.setReplySender(sender);
    cohortEntry.setShard(shard);

    handleCanCommit(cohortEntry);
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:27,代碼來源:ShardCommitCoordinator.java

示例11: testOnReceiveFindLocalShardForNonExistentShard

import akka.actor.ActorRef; //導入依賴的package包/類
@Test
public void testOnReceiveFindLocalShardForNonExistentShard() throws Exception {
    new JavaTestKit(getSystem()) {
        {
            final ActorRef shardManager = actorFactory.createActor(newPropsShardMgrWithMockShardActor());

            shardManager.tell(new UpdateSchemaContext(TestModel.createTestContext()), getRef());

            shardManager.tell(new FindLocalShard("non-existent", false), getRef());

            LocalShardNotFound notFound = expectMsgClass(duration("5 seconds"), LocalShardNotFound.class);

            assertEquals("getShardName", "non-existent", notFound.getShardName());
        }
    };
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:17,代碼來源:ShardManagerTest.java

示例12: test11joinUserOrganisationInvalidOrgId

import akka.actor.ActorRef; //導入依賴的package包/類
@Test
public void test11joinUserOrganisationInvalidOrgId(){
  TestKit probe = new TestKit(system);
  ActorRef subject = system.actorOf(props);

  Request reqObj = new Request();
  reqObj.setOperation(ActorOperations.JOIN_USER_ORGANISATION.getValue());

  HashMap<String, Object> innerMap = new HashMap<>();
  reqObj.getRequest().put(JsonKey.USER_ORG , innerMap);

  innerMap.put(JsonKey.ORGANISATION_ID , orgId+"bjic3r9");
  innerMap.put(JsonKey.USER_ID , USER_ID);

  List<String> roles = new ArrayList<>();
  roles.add("ADMIN");
  innerMap.put(JsonKey.ROLES, roles);

  subject.tell(reqObj, probe.getRef());
  ProjectCommonException resp = probe.expectMsgClass(duration("200 second"),ProjectCommonException.class);
}
 
開發者ID:project-sunbird,項目名稱:sunbird-lms-mw,代碼行數:22,代碼來源:OrganisationManagementActorTest.java

示例13: performRegistration

import akka.actor.ActorRef; //導入依賴的package包/類
private synchronized void performRegistration(ActorRef shard) {
    if (isClosed()) {
        return;
    }
    cohortRegistry = shard;
    Future<Object> future =
            Patterns.ask(shard, new DataTreeCohortActorRegistry.RegisterCohort(subtree, actor), TIMEOUT);
    future.onComplete(new OnComplete<Object>() {

        @Override
        public void onComplete(Throwable failure, Object val) {
            if (failure != null) {
                LOG.error("Unable to register {} as commit cohort", getInstance(), failure);
            }
            if (isClosed()) {
                removeRegistration();
            }
        }

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

示例14: testExecuteRemoteOperationAsync

import akka.actor.ActorRef; //導入依賴的package包/類
@Test
@SuppressWarnings("checkstyle:IllegalCatch")
public void testExecuteRemoteOperationAsync() {
    new JavaTestKit(getSystem()) {
        {
            ActorRef shardActorRef = getSystem().actorOf(Props.create(EchoActor.class));

            ActorRef shardManagerActorRef = getSystem().actorOf(MockShardManager.props(true, shardActorRef));

            ActorContext actorContext = new ActorContext(getSystem(), shardManagerActorRef,
                    mock(ClusterWrapper.class), mock(Configuration.class));

            ActorSelection actor = actorContext.actorSelection(shardActorRef.path());

            Future<Object> future = actorContext.executeOperationAsync(actor, "hello");

            try {
                Object result = Await.result(future, Duration.create(3, TimeUnit.SECONDS));
                assertEquals("Result", "hello", result);
            } catch (Exception e) {
                throw new AssertionError(e);
            }
        }
    };
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:26,代碼來源:ActorContextTest.java

示例15: testUpdateUserTcStatus

import akka.actor.ActorRef; //導入依賴的package包/類
@Test
public void testUpdateUserTcStatus(){

  TestKit probe = new TestKit(system);
  ActorRef subject = system.actorOf(props);
  Request actorMessage = new Request();

  Map<String , Object> map = new HashMap<>();
  map.put(JsonKey.TERM_AND_CONDITION_STATUS , "ACCEPTED");


  actorMessage.getRequest().put(JsonKey.TENANT_PREFERENCE , map);
  actorMessage.getRequest().put(JsonKey.ROOT_ORG_ID , orgId);
  actorMessage.getRequest().put(JsonKey.REQUESTED_BY , USER_ID);
  actorMessage.setOperation(ActorOperations.UPDATE_TC_STATUS_OF_USER.getValue());

  subject.tell(actorMessage, probe.getRef());
  Response res= probe.expectMsgClass(duration("100 second"),Response.class);
}
 
開發者ID:project-sunbird,項目名稱:sunbird-lms-mw,代碼行數:20,代碼來源:TenantPreferenceManagementActorTest.java


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