mirror of
https://github.com/TREX-CoE/trexio.git
synced 2024-12-22 20:35:44 +01:00
Added test
This commit is contained in:
parent
8262b97104
commit
15c8e10184
@ -117,7 +117,8 @@ TESTS_C = \
|
|||||||
tests/io_dset_str_text \
|
tests/io_dset_str_text \
|
||||||
tests/delete_group_text \
|
tests/delete_group_text \
|
||||||
tests/overwrite_all_text \
|
tests/overwrite_all_text \
|
||||||
tests/io_all
|
tests/io_all \
|
||||||
|
tests/pre_close
|
||||||
|
|
||||||
if HAVE_HDF5
|
if HAVE_HDF5
|
||||||
TESTS_C += \
|
TESTS_C += \
|
||||||
|
@ -1422,7 +1422,7 @@ trexio_pre_close (trexio_t* file)
|
|||||||
rc = trexio_read_electron_dn_num(file, &ndn);
|
rc = trexio_read_electron_dn_num(file, &ndn);
|
||||||
if (rc != TREXIO_SUCCESS) return rc;
|
if (rc != TREXIO_SUCCESS) return rc;
|
||||||
|
|
||||||
rc = trexio_read_electron_elec_num(file, &nelec);
|
rc = trexio_read_electron_num(file, &nelec);
|
||||||
if (rc != TREXIO_SUCCESS) return rc;
|
if (rc != TREXIO_SUCCESS) return rc;
|
||||||
|
|
||||||
if (nelec != nup + ndn) {
|
if (nelec != nup + ndn) {
|
||||||
|
@ -13,6 +13,7 @@ set(Tests_text
|
|||||||
io_str_text
|
io_str_text
|
||||||
delete_group_text
|
delete_group_text
|
||||||
overwrite_all_text
|
overwrite_all_text
|
||||||
|
pre_close.c
|
||||||
)
|
)
|
||||||
|
|
||||||
if(ENABLE_HDF5)
|
if(ENABLE_HDF5)
|
||||||
@ -28,6 +29,7 @@ if(ENABLE_HDF5)
|
|||||||
io_str_hdf5
|
io_str_hdf5
|
||||||
delete_group_hdf5
|
delete_group_hdf5
|
||||||
overwrite_all_hdf5
|
overwrite_all_hdf5
|
||||||
|
pre_close
|
||||||
)
|
)
|
||||||
|
|
||||||
# Set ${Tests} variable to the complete list of tests.
|
# Set ${Tests} variable to the complete list of tests.
|
||||||
|
124
tests/pre_close.c
Normal file
124
tests/pre_close.c
Normal file
@ -0,0 +1,124 @@
|
|||||||
|
#include "trexio.h"
|
||||||
|
#include <assert.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#define TEST_BACKEND TREXIO_TEXT
|
||||||
|
#define TREXIO_FILE "test_dset_sparse.dir"
|
||||||
|
#define RM_COMMAND "rm -rf " TREXIO_FILE
|
||||||
|
|
||||||
|
static int test_pre_close_1 (const char* file_name, const back_end_t backend)
|
||||||
|
{
|
||||||
|
/* Check if nelec = nup + ndn */
|
||||||
|
|
||||||
|
trexio_t* file = NULL;
|
||||||
|
trexio_exit_code rc;
|
||||||
|
|
||||||
|
/*================= START OF TEST ==================*/
|
||||||
|
|
||||||
|
// open file in 'write' mode
|
||||||
|
file = trexio_open(file_name, 'w', backend, &rc);
|
||||||
|
assert (file != NULL);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
// write parameters
|
||||||
|
int32_t nup = 4;
|
||||||
|
int32_t ndn = 3;
|
||||||
|
int32_t nelec = 0;
|
||||||
|
|
||||||
|
rc = trexio_write_electron_up_num(file, nup);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
rc = trexio_write_electron_dn_num(file, ndn);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
// close file
|
||||||
|
rc = trexio_close(file);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
|
||||||
|
// re-open file
|
||||||
|
file = trexio_open(file_name, 'r', backend, &rc);
|
||||||
|
assert (file != NULL);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
rc = trexio_read_electron_num(file, &nelec);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
printf("nup : %d\n", nup);
|
||||||
|
printf("ndn : %d\n", ndn);
|
||||||
|
printf("nelec: %d\n", nelec);
|
||||||
|
assert (nelec == nup + ndn);
|
||||||
|
|
||||||
|
// close file
|
||||||
|
rc = trexio_close(file);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
/*================= END OF TEST ==================*/
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int test_pre_close_2 (const char* file_name, const back_end_t backend)
|
||||||
|
{
|
||||||
|
/* Check if nelec = nup */
|
||||||
|
|
||||||
|
trexio_t* file = NULL;
|
||||||
|
trexio_exit_code rc;
|
||||||
|
|
||||||
|
/*================= START OF TEST ==================*/
|
||||||
|
|
||||||
|
// open file in 'write' mode
|
||||||
|
file = trexio_open(file_name, 'w', backend, &rc);
|
||||||
|
assert (file != NULL);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
// write parameters
|
||||||
|
int32_t nup = 4;
|
||||||
|
int32_t nelec = 0;
|
||||||
|
|
||||||
|
rc = trexio_write_electron_up_num(file, nup);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
// close file
|
||||||
|
rc = trexio_close(file);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
|
||||||
|
// re-open file
|
||||||
|
file = trexio_open(file_name, 'r', backend, &rc);
|
||||||
|
assert (file != NULL);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
rc = trexio_read_electron_num(file, &nelec);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
assert (nelec == nup);
|
||||||
|
|
||||||
|
// close file
|
||||||
|
rc = trexio_close(file);
|
||||||
|
assert (rc == TREXIO_SUCCESS);
|
||||||
|
|
||||||
|
/*================= END OF TEST ==================*/
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
/*============== Test launcher ================*/
|
||||||
|
|
||||||
|
int rc;
|
||||||
|
rc = system(RM_COMMAND);
|
||||||
|
assert (rc == 0);
|
||||||
|
|
||||||
|
test_pre_close_1 (TREXIO_FILE, TEST_BACKEND);
|
||||||
|
rc = system(RM_COMMAND);
|
||||||
|
|
||||||
|
test_pre_close_2 (TREXIO_FILE, TEST_BACKEND);
|
||||||
|
|
||||||
|
rc = system(RM_COMMAND);
|
||||||
|
assert (rc == 0);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user