-
Notifications
You must be signed in to change notification settings - Fork 15
codeartifact copy-package-versions should allow copying only the last (or select) version asset #770
Comments
Thanks for the feature request. I'll share this with the CodeArtifact team, who owns and maintains the CopyPackageVersions API (ref: P138888390). In the meantime I'll transfer this to our cross-SDK repository for tracking, since service APIs like this are used across AWS SDKs. |
@tim-finnigan Thank you for following up. Much appreciated. Also, I re-read my post and realized that I wasn't explicit in that all of these promotions are just steps on the way to releasing a single package version. It is probably clear from the context, but I wanted to mention anyway :) |
@tim-finnigan I was trying to use In generic packages, package assets can be uploaded only to unfinished versions, so a version may have a bunch of assets that are considered as a complete asset set for that version. This is distinctly different from It is almost as if the twine tool (i.e. the one in CodeArtifact, not the actual If this is how it works, then In the broader sense, my suggestion would be for the backend team to introduce package asset sets, so an unfinished version would add new package assets to the current unfinished package asset set, but would maintain multiple sets per version, which would allow CI/CD pipelines to keep adding build artifacts to a version, as it matures towards a release, so only the last (or select) package asset set is downloaded when a given package version is requested from the repository. This would allow all CodeArtifact repositories to behave as development repositories, not just |
Thanks again for the feature request. I don't have any updates as of now, but the CodeArtifact team is continuing to track this in their backlog for consideration. We're going to close this on our end as the service team would need to take the next steps here. Please refer to the blog or CHANGELOG for updates, or feel free to reach out through support if you have a support plan. |
This issue is now closed. Comments on closed issues are hard for our team to see. |
Describe the feature
CodeArtifact is a development package repository, so for packages that allow multiple version assets, such as Python wheels with a build number in the package name, a single version would have multiple wheel packages listed as assets. All of those assets, except one, would have failed verification and the one that passed all tests would be expected to be promoted to the next-level repository.
This way candidate packages from a CI pipeline can be published into a CI repository after passing unit and integration tests, then upon completing staging tests promoted to a staging one, then to the production one, and then to a public repository, possibly with the build number stripped of, depending on how people want their package seen publicly.
However, current implementation of
copy-package-versions
copies all version assets, good and bad (those that failed the verification) to the destination repository. Only the selected version asset, which typically is the last one that passed all the tests, should be copied into the destination repository. Doing so leaves a good tracking record of what packages made it to each repository and can be linked to work items associated with that build.Use Case
Today, higher level package repositories keep receiving version assets that failed some tests because
copy-package-versions
copies all assets for a given version revision. This muddies the waters in those repositories in that one cannot see only the good package assets for any given version revision.My typical build/publish/promote steps would be like this, where
24
is the build number:That last bit with version revision is problematic in that it will fail if the repository was updated since the package was pulled for testing, as there's no version revision snapshot and there is no way to promote the exact version asset that passed the tests.
Proposed Solution
What would be helpful if instead of the version revision in
copy-package-versions
I could specify a version asset, similar to how I can list it today, along with a version revision, with this command for the last one:This way the destination repository will have only version assets that passed the tests needed for each promoted level. Besides just being cleaner in the sense that it will not have as many packages as a CI repository, it will also provide an added benefit of being able to pick some previous package in a rare case when the latest package has some unexpected bug.
Other Information
I use version revisions to ensure that the package asset that was downloaded from a repository for testing is the same as when
copy-package-versions
runs, but version revision has no history, so if there is another version asset uploaded in between, version revision changes andcopy-package-versions
just fails, so I have to start over. If I could promote specifically the package (version asset) I just tested, this would make the process more straightforward.Acknowledgements
CLI version used
aws-cli/2.15.49
Environment details (OS name and version, etc.)
Ubuntu 22
The text was updated successfully, but these errors were encountered: