`Packages::Maven::FindOrCreatePackageService` don't use a transaction
data:image/s3,"s3://crabby-images/f246c/f246c93ae9509e6b8d614e36595ba41e3b48f61c" alt=":fire: :fire:"
Problem
data:image/s3,"s3://crabby-images/f246c/f246c93ae9509e6b8d614e36595ba41e3b48f61c" alt=":fire: :fire:"
https://gitlab.com/gitlab-org/gitlab/-/blob/3177ec13ff15b9111aef4e7d6ee2097ef9612e0a/app/services/packages/maven/find_or_create_package_service.rb is not using a single transaction to contain all the write operations.
As such, many transactions (one per write) is created. The problem is that if one of the write operation fails, the others are not rolled back = we have non coherent data.
data:image/s3,"s3://crabby-images/fb5ae/fb5aeb7f1a5d8a54b02e08e4b9dae50ea9ee5c00" alt=":fire_engine: :fire_engine:"
Solution
data:image/s3,"s3://crabby-images/fb5ae/fb5aeb7f1a5d8a54b02e08e4b9dae50ea9ee5c00" alt=":fire_engine: :fire_engine:"
The #execute
function should open a transaction for all the underlying logic. Then each write will automatically join this transaction if needed.
def execute
project.transaction do
# rest of the actual code here.
end
end
project.transaction(requires_new: true)
). This is known to have ~performance issues, see #338346 (closed).