- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.2k
Adds support to delete old versions when successful deployment #7414
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
base: develop
Are you sure you want to change the base?
Conversation
f414471    to
    26d1e47      
    Compare
  
    | Hi, Thanks for bringing up this PR. The code looks good to me so Ill run the approval workflow to get the testing process started, but can you also create an integration tests testing the happy path from beginning to end? | 
| Can you also run  | 
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.
Thanks for opening this PR, left some comments. Additionally, we might want to consider adding this to the sam deploy command. This might need some more thought though if this makes sense to you and the team.
| ) | ||
| if self._delete_old_alias and current_alias_version: | ||
| function_name_w_version = "{}:{}".format(function_physical_id, current_alias_version) | ||
| self._lambda_client.delete_function(FunctionName=function_name_w_version) | 
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.
Will it ever be possible for this to be my_function:$LATEST? Just wanted to ask what happens if the Lambda alias resolved to the latest version of the function, and if deleting my_function:$LATEST just deletes the function.
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.
No, because there is no current alias. It only deletes old alias if there is an existing alias
current_alias_version is the lambda.get_alias operation. Does $LATEST qualify as an alias?
| Hi @driverpt, just wanted to check in about the state of this PR and if you had the capacity to work on it or if there was anything you needed to move forward | 
| Hello. I can work on it. But I'm waiting on the CF Spec to be discussed | 
| I've chatted with some team members, and the  | 
| Hey @driverpt looking at the discussion here, I saw that recommendation is to use  Thanks! | 
| Hi @driverpt, following up to check if you were planning to make the above requested changes and had any questions the team could help with. | 
| Hello. Haven't yet had the time to implement this. I'll probably take a look at it this weekend | 
0826cfa    to
    fb51370      
    Compare
  
    f05e3c1    to
    0698b03      
    Compare
  
    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.
Thanks for your contribution, left a comment about one method response where you wrapped it up with str method.
0698b03    to
    3f3a2a0      
    Compare
  
    | Seems some lint issue, please help to run  | 
98e409c    to
    3a70d2a      
    Compare
  
    | Thank you for the update. | 
Co-authored-by: Mehmet Nuri Deveci <[email protected]>
7c2c25b    to
    920f79a      
    Compare
  
    | any ETA on this one? | 
| The PR is still failing some checks. Looks like a formatting issue. I think you should be able to solve it by running  | 
| Done, can you please re-review ? | 
| Thank you. I am taking a look. | 
| Everything looks good. The only lingering point is the the naming that I'll discuss with the team members. I'll get back to you soon. Once again, thank you for your amazing contribution. | 
| self._function_identifier = function_identifier | ||
| self._alias_name = alias_name | ||
| self._lambda_client = None | ||
| self._delete_old_alias = delete_old_alias | 
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.
I would like to clarify the naming and purpose of the _delete_old_alias flag. if I understand correctly:
- We are not deleting the alias itself - the alias continues to exist.
 - What we are actually deleting is the previous function version that was referenced by the alias
 Therefore, a more accurate name for this flag might be something like_delete_previous_versionor_delete_old_versionto better reflect its actual behavior.
Which issue(s) does this change fix?
#7398
Why is this change necessary?
Because there's a limit on how many versions a Lambda has.
How does it address the issue?
Automatically deletes old version. Very useful when on SnapStart
What side effects does this change have?
None, it's disabled by default
Mandatory Checklist
PRs will only be reviewed after checklist is complete
make prpassesmake update-reproducible-reqsif dependencies were changedBy submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.