ci: run test round with parallel-checkout enabled
We already have tests for the basic parallel-checkout operations. But this code can also run be executed by other commands, such as git-read-tree and git-sparse-checkout, which are currently not tested with multiple workers. To promote a wider test coverage without duplicating tests: 1. Add the GIT_TEST_CHECKOUT_WORKERS environment variable, to optionally force parallel-checkout execution during the whole test suite. 2. Set this variable (with a value of 2) in the second test round of our linux-gcc CI job. This round runs `make test` again with some optional GIT_TEST_* variables enabled, so there is no additional overhead in exercising the parallel-checkout code here. Note that tests checking out less than two parallel-eligible entries will fall back to the sequential mode. Nevertheless, it's still a good exercise for the parallel-checkout framework as the fallback codepath also writes the queued entries using the parallel-checkout functions (only without spawning any worker). Signed-off-by: Matheus Tavares <matheus.bernardino@usp.br> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
d5904220bc
commit
87094fc2da
@ -35,6 +35,20 @@ static const int DEFAULT_NUM_WORKERS = 1;
|
||||
|
||||
void get_parallel_checkout_configs(int *num_workers, int *threshold)
|
||||
{
|
||||
char *env_workers = getenv("GIT_TEST_CHECKOUT_WORKERS");
|
||||
|
||||
if (env_workers && *env_workers) {
|
||||
if (strtol_i(env_workers, 10, num_workers)) {
|
||||
die("invalid value for GIT_TEST_CHECKOUT_WORKERS: '%s'",
|
||||
env_workers);
|
||||
}
|
||||
if (*num_workers < 1)
|
||||
*num_workers = online_cpus();
|
||||
|
||||
*threshold = 0;
|
||||
return;
|
||||
}
|
||||
|
||||
if (git_config_get_int("checkout.workers", num_workers))
|
||||
*num_workers = DEFAULT_NUM_WORKERS;
|
||||
else if (*num_workers < 1)
|
||||
|
Reference in New Issue
Block a user