Skip to content

Commit

Permalink
Fixes a bug where t_cache fails due to a string size being too small (#…
Browse files Browse the repository at this point in the history
…1720)

* Fixes a bug where t_cache fails due to a string size being too small

Recent warning reductions led to an incorrect string size being passed
to h5_fileaccess, causing the test to silently fail. In addition to
fixing the bug, the test will now fail noisily on setup failures.

* Updates the t_cache test to fail noisily on setup errors
  • Loading branch information
derobins authored May 4, 2022
1 parent 08861aa commit 19a59c2
Showing 1 changed file with 6 additions and 4 deletions.
10 changes: 6 additions & 4 deletions testpar/t_cache.c
Original file line number Diff line number Diff line change
Expand Up @@ -1124,6 +1124,8 @@ setup_derived_types(void)
MPI_Aint displs[9];
struct mssg_t sample; /* used to compute displacements */

HDmemset(&sample, 0, sizeof(struct mssg_t));

/* setup the displacements array */
if ((MPI_SUCCESS != MPI_Get_address(&sample.req, &displs[0])) ||
(MPI_SUCCESS != MPI_Get_address(&sample.src, &displs[1])) ||
Expand Down Expand Up @@ -6981,7 +6983,7 @@ main(int argc, char **argv)

/* fix the file names */
for (u = 0; u < sizeof(FILENAME) / sizeof(FILENAME[0]) - 1; ++u) {
if (h5_fixname(FILENAME[u], fapl, filenames[u], sizeof(filenames[u])) == NULL) {
if (h5_fixname(FILENAME[u], fapl, filenames[u], PATH_MAX) == NULL) {
nerrors++;
if (verbose)
HDfprintf(stdout, "%d:%s: h5_fixname() failed.\n", world_mpi_rank, __func__);
Expand Down Expand Up @@ -7085,8 +7087,8 @@ main(int argc, char **argv)
MPI_Barrier(MPI_COMM_WORLD);
if (MAINPROCESS) { /* only process 0 reports */
HDprintf("===================================\n");
if (failures) {
HDprintf("***metadata cache tests detected %d failures***\n", failures);
if (nerrors || failures) {
HDprintf("***metadata cache tests detected %d failures***\n", nerrors + failures);
}
else {
HDprintf("metadata cache tests finished with no failures\n");
Expand All @@ -7103,5 +7105,5 @@ main(int argc, char **argv)
MPI_Finalize();

/* cannot just return (failures) because exit code is limited to 1byte */
return (failures != 0);
return (nerrors != 0 || failures != 0);
}

0 comments on commit 19a59c2

Please sign in to comment.