-
Notifications
You must be signed in to change notification settings - Fork 2
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
Support for parallelization by test suite #154
Comments
Hi @jameskraus thanks for raising this issue! I'd like to understand a bit more of your use case. It sounds like you want to select files for splitting across a number of different test suites? What is the output of your I'm assuming all test files within a test suite are subpaths of the test suite? Like would it be possible to construct a file glob across multiple directories that select all tests from all selected test suites? We could then use that as an input into the test splitter |
Yes, sort of! We have a lot of different unit test suites and they all have different amounts of time they take. It would be very helpful to be able to parallelize over not just individual files, but also suites.
The output of the // Get all the suites to run for a given PR
const allSuites: Array<string> = await getAllSuitesToRun()
// Figure out which subset of suites to run for the current agent
const suitesBin: Array<string> = deterministicRandomPartition({
seed: process.env['BUILDKITE_BUILD_NUMBER'],
partitionIndex: process.env['BUILDKITE_PARALLEL_JOB'],
totalPartitions: process.env['BUILDKITE_PARALLEL_JOB_COUNT']
xs: allSuites
})
// Run the suites via nx, equivalent to for loop over `nx run {suite}:test`
try {
execSync(`nx run-many --target=test --projects=${projects.join(',')`)
} catch (e) {
// failure handling
}
Hmm, we're basically wrapping the Given that jest has startup/shutdown costs, it may be more efficient to run an entire suite at once, e.g. |
Right now it seems like test-splitter is designed to run a lot of tests for a single test suite. It would be nice if it could support the idea of parallelizing across test suites. This feedback is directed at future support for non-rspec test suites.
For example in our javascript monorepo pipeline right now we have many (100+) test suites which we dynamically look up and run. Our pipeline looks something like this right now:
Where
run-unit-tests.js
will find a list of all test suites to run and deterministically run a random subset of those suites based on its batch # out of the total batches. In our particular example, running a suite looks like running a commandnx run {suite}:test
.Maybe the main difference in this proposed approach vs. the current approach is to alter the assumption that
test-splitter
would be operating on a per-file basis? Another way to look at this is running groups of tests independent of the underlying individual files.The text was updated successfully, but these errors were encountered: