Skip to content
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

Move DeleteMachine call outside Eventually block in integration tests #232

Closed
wants to merge 9 commits into from

Conversation

kasabe28
Copy link
Contributor

Fixes #218

@kasabe28 kasabe28 requested a review from a team as a code owner March 14, 2024 07:29
@kasabe28 kasabe28 added the integration-tests to run integration tests label Mar 14, 2024
@kasabe28 kasabe28 self-assigned this Mar 14, 2024
Copy link
Contributor

@so-sahu so-sahu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Function call's result can be directly checked for success.

provider/server/machine_annotations_update_test.go Outdated Show resolved Hide resolved
provider/server/machine_create_test.go Outdated Show resolved Hide resolved
@github-actions github-actions bot added size/L and removed size/M labels Mar 19, 2024
Copy link
Contributor

@so-sahu so-sahu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Eventually block for delete can be simplified.

MatchError(ContainSubstring("NotFound")),
))
g.Expect(err).Should(Succeed())
}).Should(Succeed())
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It can be simplified:

Suggested change
}).Should(Succeed())
Eventually(func() error {
_, err := machineClient.DeleteMachine(ctx, &iri.DeleteMachineRequest{MachineId: createResp.Machine.Metadata.Id})
return err
}).Should(Succeed())

This eliminates the need for the additional Gomega argument as well. Please update other occurrences accordingly.

Copy link
Contributor

@lukas016 lukas016 Mar 19, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what are benefits? it looks more as cosmetic change. both solution are valid for gomega and this solution is more similar another eventually blocks.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The functionality remains the same, but this approach offers advantages in terms of:

Readability: It explicitly conveys that the DeleteMachine call is expected to eventually succeed, eliminating the need for an additional Expect statement.

Clarity: Using Eventually(func() error { ... }).Should(Succeed()) directly signifies the expectation that an operation will ultimately succeed, avoiding the need for explicit error handling within the function.

However, this approach is optional and may vary based on preference.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i will implement it.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed

@@ -38,12 +38,14 @@ var _ = Describe("Exec", func() {
Expect(createResp).NotTo(BeNil())

DeferCleanup(func(ctx SpecContext) {
Eventually(func(g Gomega) bool {
Eventually(func(g Gomega) {
Copy link
Member

@afritzler afritzler Mar 19, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think it is a good idea to call DeleteMachine in an Eventually block. We should call the delete method once and then ensure that the domain has been removed.

Copy link
Contributor

@lukas016 lukas016 Mar 20, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

no, it is DeferCleanup. It has to guarantee ideally clean environment. It is important, if you want to run test in loop on one environment. What you suggest we implemented in _delete.go test file.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@afritzler do you understand why i want to have Eventually block for delete call? Can i close your comment?

@lukas016 lukas016 force-pushed the refactor-integration-tests branch from 1e7e3db to fdad6b6 Compare March 21, 2024 13:29
@lukas016 lukas016 requested review from so-sahu and afritzler March 21, 2024 13:30
@lukas016 lukas016 closed this Jul 23, 2024
@lukas016
Copy link
Contributor

test will be rewritten

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

Refactor Machine Deletion Logic in Integration Tests
4 participants