#include "LAGraph_test.h"
#include "LG_internal.h"
char msg [LAGRAPH_MSG_LEN] ;
GrB_Matrix A = NULL, B = NULL, C = NULL ;
GrB_Vector w = NULL, u = NULL, z = NULL ;
#define LEN 512
char filename [LEN+1] ;
char btype_name [LAGRAPH_MAX_NAME_LEN] ;
void setup (void)
{
OK (LAGraph_Init (msg)) ;
}
void teardown (void)
{
OK (LAGraph_Finalize (msg)) ;
}
const char *files [ ] =
{
"cover",
"lp_afiro",
"matrix_fp32",
""
} ;
void test_Matrix_Structure (void)
{
setup ( ) ;
for (int k = 0 ; ; k++)
{
const char *aname = files [k] ;
if (strlen (aname) == 0) break;
TEST_CASE (aname) ;
snprintf (filename, LEN, LG_DATA_DIR "%s.mtx", aname) ;
FILE *f = fopen (filename, "r") ;
TEST_CHECK (f != NULL) ;
OK (LAGraph_MMRead (&A, f, msg)) ;
OK (fclose (f)) ;
TEST_MSG ("Loading of valued matrix failed") ;
snprintf (filename, LEN, LG_DATA_DIR "%s_structure.mtx", aname) ;
f = fopen (filename, "r") ;
TEST_CHECK (f != NULL) ;
OK (LAGraph_MMRead (&B, f, msg)) ;
OK (LAGraph_Matrix_TypeName (btype_name, B, msg)) ;
TEST_CHECK (MATCHNAME (btype_name, "bool")) ;
OK (fclose (f)) ;
TEST_MSG ("Loading of structure matrix failed") ;
OK (LAGraph_Matrix_Structure (&C, A, msg)) ;
bool ok ;
OK (LAGraph_Matrix_IsEqual (&ok, C, B, msg)) ;
TEST_CHECK (ok) ;
TEST_MSG ("Test for C and B equal failed") ;
OK (GrB_free (&A)) ;
OK (GrB_free (&B)) ;
OK (GrB_free (&C)) ;
}
teardown ( ) ;
}
#if LG_BRUTAL_TESTS
void test_Matrix_Structure_brutal (void)
{
OK (LG_brutal_setup (msg)) ;
for (int k = 0 ; ; k++)
{
const char *aname = files [k] ;
if (strlen (aname) == 0) break;
TEST_CASE (aname) ;
snprintf (filename, LEN, LG_DATA_DIR "%s.mtx", aname) ;
FILE *f = fopen (filename, "r") ;
TEST_CHECK (f != NULL) ;
OK (LAGraph_MMRead (&A, f, msg)) ;
OK (fclose (f)) ;
TEST_MSG ("Loading of valued matrix failed") ;
snprintf (filename, LEN, LG_DATA_DIR "%s_structure.mtx", aname) ;
f = fopen (filename, "r") ;
TEST_CHECK (f != NULL) ;
OK (LAGraph_MMRead (&B, f, msg)) ;
OK (LAGraph_Matrix_TypeName (btype_name, B, msg)) ;
TEST_CHECK (MATCHNAME (btype_name, "bool")) ;
OK (fclose (f)) ;
TEST_MSG ("Loading of structure matrix failed") ;
LG_BRUTAL (LAGraph_Matrix_Structure (&C, A, msg)) ;
bool ok ;
OK (LAGraph_Matrix_IsEqual (&ok, C, B, msg)) ;
TEST_CHECK (ok) ;
TEST_MSG ("Test for C and B equal failed") ;
OK (GrB_free (&A)) ;
OK (GrB_free (&B)) ;
OK (GrB_free (&C)) ;
}
OK (LG_brutal_teardown (msg)) ;
}
#endif
void test_Matrix_Structure_failures (void)
{
setup ( ) ;
C = NULL ;
int result = LAGraph_Matrix_Structure (NULL, NULL, msg) ;
TEST_CHECK (result == GrB_NULL_POINTER) ;
printf ("\nmsg: [%s]\n", msg) ;
result = LAGraph_Matrix_Structure (&C, NULL, msg) ;
TEST_CHECK (result == GrB_NULL_POINTER) ;
printf ("msg: [%s]\n", msg) ;
TEST_CHECK (C == NULL) ;
teardown ( ) ;
}
TEST_LIST =
{
{ "Matrix_Structure", test_Matrix_Structure },
{ "Matrix_Structure_failures", test_Matrix_Structure_failures },
#if LG_BRUTAL_TESTS
{ "Matrix_Structure_brutal", test_Matrix_Structure_brutal },
#endif
{ NULL, NULL }
} ;