-
Notifications
You must be signed in to change notification settings - Fork 5.6k
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
chore: Parallelize EnsureCleanState for e2e tests, adding timing information #20998
chore: Parallelize EnsureCleanState for e2e tests, adding timing information #20998
Conversation
…rmation Closes argoproj#20968 Closes argoproj#20967 A number of cleanup and create steps can be done in parallel, reducing the total runtime. Gather timing information as well and log it. Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
❌ Preview Environment deleted from BunnyshellAvailable commands (reply to this comment):
|
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
…n't fit in Github logs and gets truncated Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
…emoving namespaces Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
…king based on timings Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
… no wait commands Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
…o server watcher seems to fail Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #20998 +/- ##
==========================================
- Coverage 55.07% 55.02% -0.05%
==========================================
Files 324 324
Lines 55472 55472
==========================================
- Hits 30550 30524 -26
- Misses 22308 22327 +19
- Partials 2614 2621 +7 ☔ View full report in Codecov by Sentry. |
Can we remove the timing info code to simplify things now that you've done the initial speedup/analysis? |
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
I'm not done yet :) I'm trying another commit to only do updates when necessary for slowest parts. |
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
I'd only leave it in place if there's also documentation on how to use the logging for further optimization and if there's a strong likelihood that someone will actually use it to significantly improve performance. If the upper bound to improvement is ~30s, I say kill the code. |
Okay, I'll clean it up when done with optimizations here. |
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
@crenshaw-dev, I think this is ready to go now. |
test/e2e/fixture/fixture.go
Outdated
wg.Add(1) | ||
go func() { | ||
defer wg.Done() | ||
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.
Are we relying on os.Exit
s in the parallel functions for error handling?
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.
Hm, that's a good point, probably need to return the errors to the main 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.
It's not that easy. I've checked and it's relying on os.Exit
after logging Fatal
. Is that okay?
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've figured out a way.
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
"delete_applications_resources_namespace": func() error { | ||
// Delete the applicationset-e2e namespace, if it exists | ||
err := fixtureClient.KubeClientset.CoreV1().Namespaces().Delete(context.Background(), ApplicationsResourcesNamespace, v1.DeleteOptions{PropagationPolicy: &policy}) | ||
if err != nil && !strings.Contains(err.Error(), "not found") { // 'not found' error is expected |
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 believe there's a k8s library function that checks whether an error is a "not found" error.
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.
Updated to use that
So total savings here is around 5min? |
About 6-7 minutes. |
…2e-tests Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
I've merged master in and let's wait for the test run. |
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
@crenshaw-dev, new results are in, with this PR we are down to ~30 min to run e2e tests. |
For some reason the tests for v1.29 and v1.28 were slower. |
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.
Last requested change :-)
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com>
…rmation (argoproj#20998) * chore: Parallelize EnsureCleanState for e2e tests, adding timing information Closes argoproj#20968 Closes argoproj#20967 A number of cleanup and create steps can be done in parallel, reducing the total runtime. Gather timing information as well and log it. Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Add underscores to function map keys Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Have separate log statements for timing fields, since everything doesn't fit in Github logs and gets truncated Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Re-run tests Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Fix duplicate removal attempts, cleanup things in namespaces before removing namespaces Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Combine config map cleanups, since they seem to have some kind of locking based on timings Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Re-order some cleanups to not wait if something is already covered by no wait commands Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Move rm temp dir to be together with re-creation, since otherwise repo server watcher seems to fail Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Only update config maps and login as admin if there were any changes Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Also check for user being logged in Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Improve config maps equivalency check Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Remove timing information Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Improve loops with sleep Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Properly propagate and handle errors for parallel functions Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Add missing CheckError Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Fix import Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Fix imports linter error (try 2) Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Parallelize EnsureCleanState for application sets Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Fix errors.IsNotFound Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Use errgroup to run functions in parallel Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Remove name keys for functions as unused Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> * Use apierr directly Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> --------- Signed-off-by: Andrii Korotkov <andrii.korotkov@verkada.com> Signed-off-by: Adrian Aneci <aneci@adobe.com>
Closes #20968
Closes #20967
A number of cleanup and create steps can be done in parallel, reducing the total runtime. Gather timing information as well and log it.
Checklist: