Как написать модульный тест для akka UntypedProcessor

1

Я создал актера, который расширяет UnTypedProcessor. Я намерен использовать этого актера, чтобы перенести некоторые его сообщения на диск. Актер выглядит так,

public class Shard extends UntypedProcessor {

  LoggingAdapter log = Logging.getLogger(getContext().system(), this);

  @Override
  public void onReceive(Object message) throws Exception {
    if(message instanceof CreateTransactionChain) {
      System.out.println("Received a CreateTransactionChain message");
      ActorRef transactionChain = getContext().actorOf(Props.create(TransactionChain.class), "transactionChain");
      Address address = transactionChain.path().address();
      getSender().tell(new CreateTransactionReply(address), getSelf());
    }
  }
}

У меня есть единичный тест, написанный для этого так,

public class ShardTest extends AbstractActorTest{
  @Test
  public void testOnReceiveCreateTransaction() throws Exception {
System.out.println("running tests");

new JavaTestKit(getSystem()) {{
  final Props props = Props.create(Shard.class);
  final TestActorRef<Shard> subject = TestActorRef.create(getSystem(), props, "test");

  // can also use JavaTestKit "from the outside"
  final JavaTestKit probe = new JavaTestKit(getSystem());

  // the run() method needs to finish within 3 seconds
  new Within(duration("3 seconds")) {
    protected void run() {

      subject.tell(new CreateTransactionChain(), getRef());

      final String out = new ExpectMsg<String>("match hint") {
        // do not put code outside this method, will run afterwards
        protected String match(Object in) {
          if (in instanceof CreateTransactionReply) {
            return "match";
          } else {
            throw noMatch();
          }
        }
      }.get(); // this extracts the received message

      assertEquals("match", out);

      // Will wait for the rest of the 3 seconds
      expectNoMsg();
    }


      };
    }};
  }
}

Когда я запускаю этот тест, метод onReceive для UntypeProcessor не запускается. Если бы я расширил свой класс из UntypedActor, то все будет хорошо. Любые идеи, почему расширение UntypedProcessor не работает? Есть ли какая-то конфигурация, которую мне нужно добавить, чтобы заставить это работать? Есть что-то, что нужно издеваться?

Теги:
unit-testing
akka
akka-persistence

1 ответ

1
Лучший ответ

akka-persistence не работает с тем же диспетчером потоков, который предоставляет TestActorRef. Нам нужно переключиться на использование простого ActorRef, чтобы для теста можно было использовать многопоточный диспетчер.

Этот вопрос github касается одной и той же проблемы: https://github.com/akka/akka/issues/15293

Ещё вопросы

Сообщество Overcoder
Наверх
Меню