-
Notifications
You must be signed in to change notification settings - Fork 51
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
tools/bumper: Refactor using DeferCleanup #1978
base: main
Are you sure you want to change the base?
Conversation
/cherry-pick release-0.97 |
@RamLavi: once the present PR merges, I will cherry-pick it on top of In response to this:
Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository. |
defer func(path string) { | ||
Expect(os.RemoveAll(path)).To(Succeed()) | ||
}(gitCnaoRepo.gitRepo.localDir) | ||
DeferCleanup(os.RemoveAll, gitCnaoRepo.gitRepo.localDir) |
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.
Aint DeferCleanup
should be used on BeforeAll
and such ?
It meant to auto create a corresponding AfterAll
block for example,
Here it feels that defer is more suitable,
unless the docs etc says otherwise
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, that ok. See the question here https://gophers.slack.com/archives/CQQ50BBNW/p173627601851229, and the answer here https://gophers.slack.com/archives/CQQ50BBNW/p1736281169698839
defer func(path string) { | ||
Expect(os.RemoveAll(path)).To(Succeed()) | ||
}(gitCnaoRepo.gitRepo.localDir) | ||
DeferCleanup(os.RemoveAll, gitCnaoRepo.gitRepo.localDir) |
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 think that now, after moving to DeferCleanup, it's possible, and so it is proffered, to check the error; e.g.
DeferCleanup(os.RemoveAll, gitCnaoRepo.gitRepo.localDir) | |
DeferCleanup(func(){ | |
Expect(os.RemoveAll(gitCnaoRepo.gitRepo.localDir)).To(Succeed()) | |
}) |
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 say better to keep it simple
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 say that in go, you must check errors
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.
defer func(path string) { | ||
Expect(os.RemoveAll(path)).To(Succeed()) | ||
}(gitCnaoRepo.gitRepo.localDir) | ||
DeferCleanup(os.RemoveAll, gitCnaoRepo.gitRepo.localDir) |
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.
same
defer func(path string) { | ||
Expect(os.RemoveAll(path)).To(Succeed()) | ||
}(gitCnaoRepo.gitRepo.localDir) | ||
DeferCleanup(os.RemoveAll, gitCnaoRepo.gitRepo.localDir) |
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.
same
defer func(path string) { | ||
Expect(os.RemoveAll(path)).To(Succeed()) | ||
}(gitCnaoRepo.gitRepo.localDir) | ||
DeferCleanup(os.RemoveAll, gitCnaoRepo.gitRepo.localDir) |
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.
same
Not related to this PR does this require some retry on either core / test ? or just an uninteresting flake ? Thanks |
Nit: the PR desc should be under the "What this PR does / why we need it:" line |
I'm monitoring it as a flake (see on kmp) and also trying to investigate further. |
Signed-off-by: Ram Lavi <[email protected]>
Currently the DeferCleanup is performed on every unit test. Move it to be more centralized - where the repo is first created. Signed-off-by: Ram Lavi <[email protected]>
c57f313
to
81abf78
Compare
New changes are detected. LGTM label has been removed. |
[APPROVALNOTIFIER] This PR is NOT APPROVED This pull-request has been approved by: The full list of commands accepted by this bot can be found here.
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
@nunnatsa PTAL |
@@ -28,6 +28,11 @@ var _ = Describe("Testing internal git CNAO Repo", func() { | |||
githubApi = newFakeGithubApi(repoDir) | |||
|
|||
gitCnaoRepo = newFakeGitCnaoRepo(githubApi, repoDir, &component{}, expectedTagCommitMap) | |||
|
|||
DeferCleanup(func() { | |||
Expect(os.RemoveAll(gitCnaoRepo.gitRepo.localDir)).To(Succeed()) |
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.
Do you need both of them? Isn't the first dir under the 2nd?
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 though about keeping them both but maybe it's an overkill.
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.
The tests creates a temporary test directory on every run. Removing it after each test to prevent leftovers. Signed-off-by: Ram Lavi <[email protected]>
81abf78
to
09764ad
Compare
Quality Gate passedIssues Measures |
What this PR does / why we need it:
This PR is refactoring the bumper unit tests to use DeferCleanup, following a discussion in anotherPR
Special notes for your reviewer:
Release note: