libsnapshot: handle errors in RemoveAllUpdateState appropriately.

In CheckMergeState / HandleCancelledUpdate, if removing update state
fails, just return the previous state. It used to return Cancelled,
and the error goes unnoticed.

Test: pass
Bug: 147696014
Change-Id: I9cb3d20c5c886afa1913740c903eaad08f0cc041
Merged-In: I9cb3d20c5c886afa1913740c903eaad08f0cc041
diff --git a/fs_mgr/libsnapshot/snapshot.cpp b/fs_mgr/libsnapshot/snapshot.cpp
index e13fc87..f1a90c5 100644
--- a/fs_mgr/libsnapshot/snapshot.cpp
+++ b/fs_mgr/libsnapshot/snapshot.cpp
@@ -829,7 +829,9 @@
         // lock, because flock() might have failed.
         AcknowledgeMergeSuccess(lock.get());
     } else if (state == UpdateState::Cancelled) {
-        RemoveAllUpdateState(lock.get(), before_cancel);
+        if (!RemoveAllUpdateState(lock.get(), before_cancel)) {
+            return ReadSnapshotUpdateStatus(lock.get()).state();
+        }
     }
     return state;
 }
@@ -1186,8 +1188,7 @@
     // If all snapshots were reflashed, then cancel the entire update.
     if (AreAllSnapshotsCancelled(lock)) {
         LOG(WARNING) << "Detected re-flashing, cancelling unverified update.";
-        RemoveAllUpdateState(lock, before_cancel);
-        return true;
+        return RemoveAllUpdateState(lock, before_cancel);
     }
 
     // If update has been rolled back, then cancel the entire update.
@@ -1209,8 +1210,7 @@
     }
 
     LOG(WARNING) << "Detected rollback, cancelling unverified update.";
-    RemoveAllUpdateState(lock, before_cancel);
-    return true;
+    return RemoveAllUpdateState(lock, before_cancel);
 }
 
 std::unique_ptr<LpMetadata> SnapshotManager::ReadCurrentMetadata() {