From d163008b63254661055ac7b66469b7409820ca7a Mon Sep 17 00:00:00 2001 From: Leonard Lyubich Date: Wed, 16 Feb 2022 18:43:46 +0300 Subject: [PATCH] [#1175] storage engine: Fix `Lock` implementation `Lock` must return `apistatus.IrregularObjectLock` error instead of `apistatus.ObjectLocked` one. Signed-off-by: Leonard Lyubich --- pkg/local_object_storage/engine/lock.go | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/pkg/local_object_storage/engine/lock.go b/pkg/local_object_storage/engine/lock.go index 9b2ac7c628..8329c408c6 100644 --- a/pkg/local_object_storage/engine/lock.go +++ b/pkg/local_object_storage/engine/lock.go @@ -32,11 +32,11 @@ func (e *StorageEngine) lock(idCnr cid.ID, locker oid.ID, locked []oid.ID) error for i := range locked { switch e.lockSingle(idCnr, locker, locked[i], true) { case 1: - return apistatus.ObjectLocked{} + return apistatus.IrregularObjectLock{} case 0: - switch e.lockSingle(idCnr, locker, locked[i], true) { + switch e.lockSingle(idCnr, locker, locked[i], false) { case 1: - return apistatus.ObjectLocked{} + return apistatus.IrregularObjectLock{} case 0: return errLockFailed } @@ -48,12 +48,12 @@ func (e *StorageEngine) lock(idCnr cid.ID, locker oid.ID, locked []oid.ID) error // Returns: // 0 - fail -// 1 - object locked +// 1 - locking irregular object // 2 - ok func (e *StorageEngine) lockSingle(idCnr cid.ID, locker, locked oid.ID, checkExists bool) (status uint8) { // code is pretty similar to inhumeAddr, maybe unify? root := false - var errLocked apistatus.ObjectLocked + var errIrregular apistatus.IrregularObjectLock var addrLocked address.Address addrLocked.SetContainerID(&idCnr) @@ -89,7 +89,7 @@ func (e *StorageEngine) lockSingle(idCnr cid.ID, locker, locked oid.ID, checkExi if err != nil { e.reportShardError(sh, "could not lock object in shard", err) - if errors.As(err, &errLocked) { + if errors.As(err, &errIrregular) { status = 1 return true }