From 93ffc0a5c4b54a8beea10c3fd68e7a2d70c4c771 Mon Sep 17 00:00:00 2001 From: Zach Smith Date: Wed, 5 Sep 2018 13:32:12 -0700 Subject: Catch MessageNotExist errors in alicloud subscriptions to prevent errors on timeout (#210) --- src/main/scala/xyz/driver/core/messaging/AliyunBus.scala | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/main/scala/xyz/driver/core/messaging/AliyunBus.scala b/src/main/scala/xyz/driver/core/messaging/AliyunBus.scala index 66ae377..27e66f6 100644 --- a/src/main/scala/xyz/driver/core/messaging/AliyunBus.scala +++ b/src/main/scala/xyz/driver/core/messaging/AliyunBus.scala @@ -3,6 +3,7 @@ import java.nio.ByteBuffer import java.util import com.aliyun.mns.client.{AsyncCallback, CloudAccount} +import com.aliyun.mns.common.ServiceException import com.aliyun.mns.model import com.aliyun.mns.model._ @@ -53,7 +54,11 @@ class AliyunBus( pullTimeout, new AsyncCallback[util.List[model.Message]] { override def onSuccess(result: util.List[model.Message]): Unit = promise.success(result.asScala) - override def onFail(ex: Exception): Unit = promise.failure(ex) + override def onFail(ex: Exception): Unit = ex match { + case serviceException: ServiceException if serviceException.getErrorCode == "MessageNotExist" => + promise.success(Nil) + case _ => promise.failure(ex) + } } ) -- cgit v1.2.3