mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
fix: replication of tag removal (#14056)
Currently tag removal leaves replication state as `PENDING` because the `HEAD` api returns just a tag count but not the actual tags, and this is treated as a no-op
This commit is contained in:
parent
737a3f0bad
commit
54a98773f8
@ -769,7 +769,7 @@ func getReplicationAction(oi1 ObjectInfo, oi2 minio.ObjectInfo, opType replicati
|
|||||||
}
|
}
|
||||||
|
|
||||||
t, _ := tags.ParseObjectTags(oi1.UserTags)
|
t, _ := tags.ParseObjectTags(oi1.UserTags)
|
||||||
if !reflect.DeepEqual(oi2.UserTags, t.ToMap()) {
|
if !reflect.DeepEqual(oi2.UserTags, t.ToMap()) || (oi2.UserTagCount != len(t.ToMap())) {
|
||||||
return replicateMetadata
|
return replicateMetadata
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1573,6 +1573,7 @@ func (er erasureObjects) PutObjectTags(ctx context.Context, bucket, object strin
|
|||||||
filterOnlineDisksInplace(fi, metaArr, onlineDisks)
|
filterOnlineDisksInplace(fi, metaArr, onlineDisks)
|
||||||
|
|
||||||
fi.Metadata[xhttp.AmzObjectTagging] = tags
|
fi.Metadata[xhttp.AmzObjectTagging] = tags
|
||||||
|
fi.ReplicationState = opts.PutReplicationState()
|
||||||
for k, v := range opts.UserDefined {
|
for k, v := range opts.UserDefined {
|
||||||
fi.Metadata[k] = v
|
fi.Metadata[k] = v
|
||||||
}
|
}
|
||||||
|
@ -166,6 +166,36 @@ if [ $? -ne 0 ]; then
|
|||||||
exit_1;
|
exit_1;
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
vID=$(./mc stat minio2/newbucket/README.md --json | jq .versionID)
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "expecting object to be present. exiting.."
|
||||||
|
exit_1;
|
||||||
|
fi
|
||||||
|
./mc tag set --version-id "${vID}" minio2/newbucket/README.md "k=v"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "expecting tag set to be successful. exiting.."
|
||||||
|
exit_1;
|
||||||
|
fi
|
||||||
|
sleep 5
|
||||||
|
|
||||||
|
./mc tag remove --version-id "${vID}" minio2/newbucket/README.md
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "expecting tag removal to be successful. exiting.."
|
||||||
|
exit_1;
|
||||||
|
fi
|
||||||
|
sleep 5
|
||||||
|
|
||||||
|
replStatus_minio2=$(./mc stat minio2/newbucket/README.md --json | jq -r .replicationStatus)
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "expecting object to be present. exiting.."
|
||||||
|
exit_1;
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ${replStatus_minio2} != "COMPLETED" ]; then
|
||||||
|
echo "expected tag removal to have replicated, exiting..."
|
||||||
|
exit_1;
|
||||||
|
fi
|
||||||
|
|
||||||
./mc rm minio3/newbucket/README.md
|
./mc rm minio3/newbucket/README.md
|
||||||
sleep 5
|
sleep 5
|
||||||
|
|
||||||
|
@ -158,6 +158,36 @@ if [ $? -ne 0 ]; then
|
|||||||
exit_1;
|
exit_1;
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
vID=$(./mc stat minio2/newbucket/README.md --json | jq .versionID)
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "expecting object to be present. exiting.."
|
||||||
|
exit_1;
|
||||||
|
fi
|
||||||
|
./mc tag set --version-id "${vID}" minio2/newbucket/README.md "k=v"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "expecting tag set to be successful. exiting.."
|
||||||
|
exit_1;
|
||||||
|
fi
|
||||||
|
sleep 5
|
||||||
|
|
||||||
|
./mc tag remove --version-id "${vID}" minio2/newbucket/README.md
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "expecting tag removal to be successful. exiting.."
|
||||||
|
exit_1;
|
||||||
|
fi
|
||||||
|
sleep 5
|
||||||
|
|
||||||
|
replStatus_minio2=$(./mc stat minio2/newbucket/README.md --json | jq -r .replicationStatus )
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "expecting object to be present. exiting.."
|
||||||
|
exit_1;
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ${replStatus_minio2} != "COMPLETED" ]; then
|
||||||
|
echo "expected tag removal to have replicated, exiting..."
|
||||||
|
exit_1;
|
||||||
|
fi
|
||||||
|
|
||||||
./mc rm minio3/newbucket/README.md
|
./mc rm minio3/newbucket/README.md
|
||||||
sleep 5
|
sleep 5
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user