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

Group Tests Based on Thread Affinity - Follow-up to Issue #2236 #2491

Open
syedali237 opened this issue Aug 30, 2024 · 29 comments
Open

Group Tests Based on Thread Affinity - Follow-up to Issue #2236 #2491

syedali237 opened this issue Aug 30, 2024 · 29 comments
Labels
feature request test Testing application

Comments

@syedali237
Copy link
Contributor

Is your feature request related to a problem? Please describe.
Summary:
We have recently modified our test configuration to run tests using threads and disabled file parallelism to reduce the overall test runtime. However, parallelism may lead to race conditions, making certain tests flaky or unreliable.

To ensure the stability of our test suite, we need to:

Review and identify tests that may be prone to race conditions.
Adjust the configuration to run such tests sequentially where necessary.
Document any identified issues and the steps taken to mitigate them.
This issue will track the investigation and any necessary changes to ensure our tests run reliably without unintended interference from parallel execution.

Describe the solution you'd like
As a follow-up to issue #2236, we need to group different tests together based on their thread affinity. The goal is to ensure that certain tests run on the same threads to avoid race conditions and improve the reliability of our test suite. This approach will help maintain stability when tests are run in parallel by reducing potential interference between tests that share resources.

Describe alternatives you've considered
Before parallelization, the test run time was 20 minutes. However, after PR #2490, it has been reduced to 4 minutes.

Potential internship candidates
Please read this if you are planning to apply for a Palisadoes Foundation internship PalisadoesFoundation/talawa#359

@github-actions github-actions bot added test Testing application unapproved Unapproved for Pull Request labels Aug 30, 2024
Copy link

Congratulations on making your first Issue! 🎊 If you haven't already, check out our Contributing Guidelines and Issue Reporting Guidelines to ensure that you are following our guidelines for contributing and making issues.

@palisadoes
Copy link
Contributor

@syedali237 Are you willing to work on this?

@varshith257
Copy link
Member

Maybe this guide will helps for this task

@syedali237
Copy link
Contributor Author

@palisadoes I'd love to help, but I'm currently tied up with two other assigned issues. Please feel free to reassign this one. Happy to assist in the future if needed!

@ARYANSHAH1567
Copy link
Contributor

I would like to work on this issue but am unsure of the exact steps to take. If someone could guide me, I would be happy to take on the responsibility of addressing this issue.

@Cioppolo14
Copy link
Contributor

@ARYANSHAH1567 I will assign you the issue. Reaching out to our slack community is a great place to start getting guidance.

@palisadoes
Copy link
Contributor

@ARYANSHAH1567

Our policy is to assign no more than two issues to each contributor across all repositories. This way everyone gets a chance to participate in the projects. We sometimes give exceptions for more urgent cases and sometimes we lose track, but the policy stands. You have reached your limit, please wait until your existing issues are closed before requesting more issues. You could unassign yourself from one of the other issues too.

unassigning

@prayanshchh
Copy link
Contributor

I can work on this issue, but I will need guidance

@Cioppolo14
Copy link
Contributor

@prayanshchh I will assign you, please utilize our slack community for guidance.

@prayanshchh
Copy link
Contributor

alright i will ask on slack then, thanks!

@varshith257
Copy link
Member

@prayanshchh You can identify dependency tests in test suites by checking the dependency on other tests something which have to be run first and then next test something like Test A depends on Test B

@prayanshchh
Copy link
Contributor

so based on this, if Test A runs before Test B and passes then Test B potentially might depend on A, but this might also overestimate dependencies, if this is okay then I can track dependencies based on no.of tests before a particular test.

@prayanshchh
Copy link
Contributor

or while checking all the tests that come before a test, can we also compare the state of two tests, if there is a overlap then test A depends on test B.

@akshayw1
Copy link

akshayw1 commented Sep 9, 2024

I would like work on this issue

@Cioppolo14
Copy link
Contributor

@akshayw1 I meant to assign @prayanshchh but somehow missed ensuring the assignment was made. Sorry about that.

@prayanshchh
Copy link
Contributor

or while checking all the tests that come before a test, can we also compare the state of two tests, if there is a overlap then test A depends on test B.

can someone help me out with the query as I am not able to move forward with the issue, I have also asked the same on slack.

@prayanshchh
Copy link
Contributor

I am unassigning myself as nobody is responding

@prayanshchh prayanshchh removed their assignment Sep 15, 2024
Copy link

This issue did not get any activity in the past 10 days and will be closed in 180 days if no update occurs. Please check if the develop branch has fixed it and report again or close the issue.

@github-actions github-actions bot added the no-issue-activity No issue activity label Sep 26, 2024
@nilaygit-10721
Copy link

please assign me this issue?

@github-actions github-actions bot removed the no-issue-activity No issue activity label Nov 15, 2024
Copy link

This issue did not get any activity in the past 10 days and will be closed in 180 days if no update occurs. Please check if the develop branch has fixed it and report again or close the issue.

@github-actions github-actions bot added the no-issue-activity No issue activity label Nov 27, 2024
@palisadoes
Copy link
Contributor

unassigning, inactivity, no PR

@github-actions github-actions bot removed the no-issue-activity No issue activity label Nov 28, 2024
Copy link

github-actions bot commented Dec 8, 2024

This issue did not get any activity in the past 10 days and will be closed in 180 days if no update occurs. Please check if the develop branch has fixed it and report again or close the issue.

@github-actions github-actions bot added the no-issue-activity No issue activity label Dec 8, 2024
@nilaygit-10721
Copy link

open?

@github-actions github-actions bot removed the no-issue-activity No issue activity label Dec 10, 2024
@AkashMundari
Copy link

Can i work on this??

Copy link

This issue did not get any activity in the past 10 days and will be closed in 180 days if no update occurs. Please check if the develop branch has fixed it and report again or close the issue.

@github-actions github-actions bot added the no-issue-activity No issue activity label Dec 31, 2024
@Cioppolo14
Copy link
Contributor

unassigning due to no activity or open PR

@NishantSinghhhhh
Copy link

NishantSinghhhhh commented Dec 31, 2024

@Cioppolo14 ,@palisadoes , can I start working on this issue ??

I want to take up this challenging problem

@Suyash878
Copy link
Contributor

I would like to work on this

@NishantSinghhhhh
Copy link

NishantSinghhhhh commented Jan 6, 2025

I will refactor the tests to ensure they run independently by following these steps:

Creating a Test Helper Utility: This will manage isolated resources such as in-memory databases and test data for each test.

Using a Base Test Class: I’ll create a standardized setup and teardown mechanism to streamline resource management.

Refactor Each Test File:

Import the BaseTest class.
Initialize resources in beforeEach for test isolation.
Replace shared data with uniquely prefixed test data.
Clean up resources in afterEach.
Remove Shared State:

Eliminate shared beforeAll hooks and global database connections.
Avoid static or shared test data to ensure complete isolation.
Outcome:
This will allow true parallel execution, improve reliability, and eliminate race conditions while making the tests easier to maintain.

@palisadoes , Should I go with this approach or is there anyy better way there ??

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature request test Testing application
Projects
Status: Backlog
Development

No branches or pull requests