-
Notifications
You must be signed in to change notification settings - Fork 58
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(RELEASE-1246): make publish-to-cgw
task idempotent
#781
base: development
Are you sure you want to change the base?
Conversation
Skipping CI for Draft Pull Request. |
c301b54
to
8074e4d
Compare
I still need to add my tests, but I'm nearly there. 😌 |
8074e4d
to
14d80d6
Compare
This update makes the task idempotent by checking if files already exist under the specified product name and version before processing. If files are present, they are skipped to avoid errors. Additionally, the pubtools-content-gateway command has been removed and we are now directly calling the CGW api. Signed-off-by: Sean Conroy <[email protected]>
14d80d6
to
58b7516
Compare
@pkhander @swickersh can you take a look at this change please? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It looks sane to me, but you will need to add test(s) for this change I think
@@ -16,6 +15,12 @@ Tekton task to publish content to Red Hat's Developer portal using pubtools-cont | |||
| cgwHostname | The hostname of the content-gateway to publish the metadata to | yes | https://developers.redhat.com/content-gateway/rest/admin | | |||
| cgwSecret | The kubernetes secret to use to authenticate to content-gateway | yes | publish-to-cgw-secret | | |||
|
|||
## Changes in 0.3.0 | |||
* Make the task idempotent by checking if files |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
s/if files/if files are/
I would like to point out that there is another (copy) script that interacts with CGW for another pipeline - https://github.com/konflux-ci/release-service-utils/blob/main/developer-portal-wrapper/developer_portal_wrapper.py Please keep that in mind with this work. Not ALL publishing to cgw will be idempotent when this is merged. Ideally just the developer_portal_wrapper should be updated and used inside this task but I will let you decide the implementation details. |
Not having Python code directly in the task script would also help with testing - when Python is used directly, it's not possible to use our task testing framework and you can't do Python unit testing this way either. So I agree that switching to developer_portal_wrapper sounds like a good idea. |
Sweet, I will just move it over there, then ... and use pytest |
It wont be that simple. The two have deviated slightly. developer_portal_wrapper.py was created as a modified version of the python section nested in this task to work with rhel_ai. We want to be careful not to break either workflow when combining these. IMO, you're running into some scope creep here. You might ask to increase your jira story points and allow some capacity for testing. Maybe these should be separate commits? Alternatively, you could make another developer_portal_wrapper.py (slight different name) to work with this workflow. Keep the existing one for rhel-ai to continue utilizing. Then in a future Jira we can make a unified script that works with both. |
Yeah, I think this sounds like a good option - that way the scope of this story doesn't grow too much. And we can have a followup story for unifying the two scripts. |
I am cool with either of these approaches as long as it is tracked (so it sounds like the second option, in which case @seanconroy2021 can you open a jira about the unified script? It can go in refinement state. Bonus points if you link it as related to RELEASE-1246) |
Describe your changes
This update makes the
publish-to-cgw
task idempotent by checking if files already exist under the specified product name and version before processing. If files are present, they are skipped to avoid errors. Additionally, the pubtools-content-gateway command has been removed and we are now calling the CGW api directly.Relevant Jira
CGW Docs
Checklist before requesting a review
do not merge
label if there's a dependency PRrelease-service-maintainers
handle if you are unsure who to tagSigned-off-by: My name <email>