Ошибка обновления с вложенными классами дел в Scala Mongo DB - PullRequest
0 голосов
/ 05 февраля 2019

Я использую Scala 2.12.6 и

У меня есть класс Alert, который выглядит следующим образом:

case class Alert(
                  _id: org.mongodb.scala.bson.ObjectId,
                  uuid: String,
                  created: ZonedDateTime,
                  resolved: Option[ZonedDateTime],
                  status: String,
                  activity: Seq[AlertActivity]
                )

, а вложенный класс выглядит так:

sealed class AlertActivity {
}

У меня есть DAO, в котором есть методы для сохранения оповещения, которые отлично работают, когда activity - это пустое Seq, и метод для обновления раздела активности каждый раз, когда оповещение обновляется, например, пользователь что-то делает.Соответствующие разделы класса выглядят так:

private val customCodecs = fromProviders(
  classOf[Alert],
  classOf[AlertActivity],
  classOf[UserDetails]
)

private val javaCodecs = CodecRegistries.fromCodecs(new ZonedDateTimeStringCodec())

private val codecRegistry = fromRegistries(
  customCodecs,
  javaCodecs,
  DEFAULT_CODEC_REGISTRY
)

private val alerts: MongoCollection[Alert] = mongoClient.getDatabase("shepherd").withCodecRegistry(codecRegistry).getCollection("alerts")

override def getAlert(alertId: String): Future[Option[Alert]] = 
    alerts.find(equal("uuid", alertId)).first().head().map(Option(_))

override def addAlertActivity(uuid: String, activity: AlertActivity): Future[Option[Alert]] =
    alerts.updateOne(equal("uuid", uuid), push("activity", activity)).toFuture().flatMap(_ => getAlert(uuid))

Если у меня есть один подкласс AlertActivity, он отлично работает, например,

case class AlertCreated(timestamp: Long) extends AlertActivity {
  override def toString: String = "Alert created at " + ZonedDateTime.ofInstant(Instant.ofEpochMilli(timestamp), ZoneOffset.UTC)
}

Однако, если я добавлю второй подклассэто начинает терпеть неудачу.например,

case class EmailNotification(notificationId: String, timestamp: Long, userDetails: UserDetails) extends AlertActivity {
  override def toString: String = s"Email sent to ${userDetails.email} at " + ZonedDateTime.ofInstant(Instant.ofEpochMilli(timestamp), ZoneOffset.UTC)
}

Я получаю ошибку:

Error:(25, 12) No known subclasses of the sealed class
classOf[AlertActivity],

Error:(25, 12) type mismatch;
found   : Class[model.AlertActivity](classOf[model.AlertActivity])
required: org.bson.codecs.configuration.CodecProvider
classOf[AlertActivity],

Или иногда тест действительно запускается, и я получаю

Boxed Error
java.util.concurrent.ExecutionException: Boxed Error
at scala.concurrent.impl.Promise$.resolver(Promise.scala:83)
at scala.concurrent.impl.Promise$.scala$concurrent$impl$Promise$$resolveTry(Promise.scala:75)
at scala.concurrent.impl.Promise$DefaultPromise.tryComplete(Promise.scala:280)
at scala.concurrent.Promise.complete(Promise.scala:49)
at scala.concurrent.Promise.complete$(Promise.scala:48)
at scala.concurrent.impl.Promise$DefaultPromise.complete(Promise.scala:183)
at scala.concurrent.Promise.failure(Promise.scala:100)
at scala.concurrent.Promise.failure$(Promise.scala:100)
at scala.concurrent.impl.Promise$DefaultPromise.failure(Promise.scala:183)
at org.mongodb.scala.ObservableImplicits$ScalaObservable$$anon$2.$anonfun$onError$1(ObservableImplicits.scala:369)
at org.mongodb.scala.ObservableImplicits$ScalaObservable$$anon$2$$Lambda$239/949581868.apply(Unknown Source)
at org.mongodb.scala.ObservableImplicits$ScalaObservable$$anon$2.completeWith(ObservableImplicits.scala:383)
at org.mongodb.scala.ObservableImplicits$ScalaObservable$$anon$2.onError(ObservableImplicits.scala:369)
at org.mongodb.scala.ObservableImplicits$ToSingleObservable$$anon$3.$anonfun$onError$2(ObservableImplicits.scala:445)
at org.mongodb.scala.ObservableImplicits$ToSingleObservable$$anon$3$$Lambda$238/1537772520.apply$mcV$sp(Unknown Source)
at scala.runtime.java8.JFunction0$mcV$sp.apply(JFunction0$mcV$sp.java:12)
at org.mongodb.scala.ObservableImplicits$ToSingleObservable$$anon$3.completeWith(ObservableImplicits.scala:462)
at org.mongodb.scala.ObservableImplicits$ToSingleObservable$$anon$3.onError(ObservableImplicits.scala:445)
at org.mongodb.scala.internal.SubscriptionCheckingObserver.onError(SubscriptionCheckingObserver.scala:38)
at com.mongodb.async.client.AbstractSubscription.onError(AbstractSubscription.java:123)
at com.mongodb.async.client.AbstractSubscription.tryRequestInitialData(AbstractSubscription.java:153)
at com.mongodb.async.client.AbstractSubscription.request(AbstractSubscription.java:84)
at org.mongodb.scala.ObservableImplicits$BoxedSubscription.request(ObservableImplicits.scala:490)
at org.mongodb.scala.ObservableImplicits$ScalaObservable$$anon$2.onSubscribe(ObservableImplicits.scala:366)
at org.mongodb.scala.ObservableImplicits$ToSingleObservable$$anon$3.onSubscribe(ObservableImplicits.scala:441)
at org.mongodb.scala.internal.SubscriptionCheckingObserver.onSubscribe(SubscriptionCheckingObserver.scala:28)
at org.mongodb.scala.Observer.onSubscribe(Observer.scala:85)
at org.mongodb.scala.Observer.onSubscribe$(Observer.scala:85)
at org.mongodb.scala.internal.SubscriptionCheckingObserver.onSubscribe(SubscriptionCheckingObserver.scala:21)
at com.mongodb.async.client.SingleResultCallbackSubscription.<init>(SingleResultCallbackSubscription.java:33)
at com.mongodb.async.client.Observables$2.subscribe(Observables.java:78)
at org.mongodb.scala.ObservableImplicits$BoxedObservable.subscribe(ObservableImplicits.scala:474)
at org.mongodb.scala.ObservableImplicits$ToSingleObservable.subscribe(ObservableImplicits.scala:433)
at org.mongodb.scala.ObservableImplicits$ScalaObservable.headOption(ObservableImplicits.scala:358)
at org.mongodb.scala.ObservableImplicits$ScalaObservable.head(ObservableImplicits.scala:344)
at org.mongodb.scala.ObservableImplicits$ScalaSingleObservable.toFuture(ObservableImplicits.scala:411)
at daos.MongoAlertDao.addAlertActivity(MongoAlertDao.scala:68) <----- THIS IS THE addActivity method

Я также использую IntellijIDEA 2018.3.4 (Ultimate Edition), сборка # IU-183.5429.30 JRE: 1.8.0_152-release-1343-b26 x86_64 JVM: виртуальная машина OpenJDK с 64-разрядным сервером от JetBrains sro macOS 10.14.1

Любая помощьс благодарностью

1 Ответ

0 голосов
/ 05 февраля 2019

Итак, я удалил свои .idea файлы и заново импортировал проект, и ошибки исчезли

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...