Hi @atripp,
to be honest, I am still confused. Let me explain my approach in more detail:
So I created a test project which does not contain any builds yet:
data:image/s3,"s3://crabby-images/43f39/43f39f24b0f2a64ac5cc774a8104f3716a02e4c4" alt="630820af-5644-4c14-80d5-138e252fc7b7-image.png"
I want to add build 1.0.0 to this project. To do so, I upload an SBOM file containing the information about version 1.0.0. I also promote this version to the stage "Release":
data:image/s3,"s3://crabby-images/a737f/a737f80d5fdd0ebabc9b0626beb21ec10dc79de8" alt="2d973bc6-90b4-4606-985e-edf695f2e74c-image.png"
Now the worst case scenario happens. After months someone uploads a different sbom with version 1.0.0 to this project. I can confirm that the information from the "new" sbom gets added. But the build is also moved back to the stage "Build":
data:image/s3,"s3://crabby-images/f1da2/f1da288fcb39ca8f46cefe08d107ef68d466f015" alt="e7a25898-06c3-4cba-b5d5-d7edbeef579a-image.png"
I would expect that the build remains in its stage. But maybe you have a valid reason to do it like this?
So now I used "Create Build" from the dropdown to manually create version 1.0.0 again, which leads to two versions 1.0.0:
data:image/s3,"s3://crabby-images/1f26b/1f26bb6593d234fa1e4f76ac68582fbd4aabb169" alt="581939e7-a20c-4f9d-a5e3-b7d35ee9d6fc-image.png"
If I now upload a SBOM for version 1.0.0 only the first version 1.0.0 gets modified. The second, manually created version 1.0.0 remains unchanged.
Further, I created a version 2.0.0 manually using "Create Build". Then I uploaded a SBOM for version 2.0.0, which again results in two builds with version 2.0.0:
data:image/s3,"s3://crabby-images/789bb/789bb15ca8e5f2a8fe3171aba196a76b8d5f7c77" alt="20ee196b-5ae5-4673-abff-e3096b2c084a-image.png"
As far as I understood your explanation, uploading a SBOM should have added the information to the already existing build 2.0.0 instead of creating a new build?
You also said that the constraint for duplicates is <Project_Id, Release_Number, Build_Number>
.
So for versions 1.0.0 the Project_Id as well as the Build_Number are the same. The Release_Number is empty for both builds (or not set):
data:image/s3,"s3://crabby-images/ffb97/ffb97efd0ccd128ef129f6c172ac1d694e80362b" alt="ff2c5814-96e8-4dde-b64f-37050822600b-image.png"
Maybe that's a problem leading to having a build twice? But this seems to be the default when using pgutil to create and upload a SBOM. I am not really sure how this Release_Number property should be used and how it is set using pgutil.
But if this behavior is on purpose maybe you can again explain to me why?
Thanks
Caterina