java.util.NoSuchElementException: исходный издатель пуст - PullRequest
0 голосов
/ 24 августа 2018

У меня проблема с исключением

getCurrentUpdateDateFromStorage () java.util.NoSuchElementException: исходный издатель пуст

Код работал долгое время и сегодняУ меня есть эта проблема.

  private fun getCurrentUpdateDateFromStorage(sentDate: Date) {
    LogMgr.d(TAG, "getCurrentUpdateDateFromStorage()")
    val flotaUserId = getCurrentFlotaUserId()

    if (flotaUserId > 0) {
        compositeDisposable.add(wfmStorageDomain.getLastUpdateDate(flotaUserId)
                .subscribe(
                        { lastLocalUpdateDate ->
                            LogMgr.d(TAG, "lastLocalUpdateDate: $lastLocalUpdateDate, time: " + (lastLocalUpdateDate?.time
                                    ?: "null"))
                            if (lastLocalUpdateDate == null || lastLocalUpdateDate.time < sentDate.time) {
                                LogMgr.d(TAG, "update needs to be done")
                                updateEventPlannersFromServer(lastLocalUpdateDate)
                            } else {
                                LogMgr.d(TAG, "update not necessary, or invalid data -> localDate:$lastLocalUpdateDate : sentDate:$sentDate")
                            }
                        },
                        { error ->
                            LogMgr.e(TAG, "getCurrentUpdateDateFromStorage() $error")
                        }))
    } else {
        LogMgr.e(TAG, "getCurrentUpdateDateFromStorage() Invalid flotaUserId:$flotaUserId")
    }
}

=================

   override fun getLastUpdateDate(flotaUserId: Int): Single<Date> {
    LogMgr.d(TAG, "getLastUpdateDate(): $flotaUserId")
    return Single.fromPublisher({ subscriber ->
        RXSQLite.rx(
                SQLite.select().from(EventPlanner::class.java)
                        .orderBy(EventPlanner_Table.sentDate, false))
                .queryList()
                .subscribeOn(getSubscriptionScheduler())
                .subscribe({ eventPlanner ->
                    LogMgr.d(TAG, "getLastUpdateDate() $eventPlanner")

                    if (eventPlanner.isEmpty()) {
                        subscriber.onNext(Date(0L))
                    } else {
                        subscriber.onNext(eventPlanner[0].sentDate)
                    }
                    subscriber.onComplete()
                }, { error ->
                    LogMgr.e(TAG, "getLastUpdateDate()", error)
                    subscriber.onError(error)
                })
    })
}

Есть идеи, как это исправить? Спасибо за любые советы и подсказки.

РЕДАКТИРОВАТЬ: StackTrace

java.util.NoSuchElementException: The source Publisher is empty
    at io.reactivex.internal.operators.single.SingleFromPublisher$ToSingleObserver.onComplete(SingleFromPublisher.java:99)
    at com.fs.wfm.storage.dbflow.DBFlowWfmStorageRepo$getLastUpdateDate$1$1.accept(DBFlowWfmStorageRepo.kt:211)
    at com.fs.wfm.storage.dbflow.DBFlowWfmStorageRepo$getLastUpdateDate$1$1.accept(DBFlowWfmStorageRepo.kt:22)
    at io.reactivex.internal.observers.ConsumerSingleObserver.onSuccess(ConsumerSingleObserver.java:63)
    at io.reactivex.internal.operators.single.SingleSubscribeOn$SubscribeOnObserver.onSuccess(SingleSubscribeOn.java:68)
    at io.reactivex.internal.operators.single.SingleFromCallable.subscribeActual(SingleFromCallable.java:56)
    at io.reactivex.Single.subscribe(Single.java:3310)
    at io.reactivex.internal.operators.single.SingleSubscribeOn$SubscribeOnObserver.run(SingleSubscribeOn.java:89)
    at io.reactivex.Scheduler$DisposeTask.run(Scheduler.java:579)
    at io.reactivex.internal.schedulers.ScheduledRunnable.run(ScheduledRunnable.java:66)
    at io.reactivex.internal.schedulers.ScheduledRunnable.call(ScheduledRunnable.java:57)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:301)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636)
    at java.lang.Thread.run(Thread.java:764)

enter image description here enter image description here

...