#include "LAGraph_test.h"
#include "LG_internal.h"
LAGraph_Graph G = NULL ;
char msg [LAGRAPH_MSG_LEN] ;
GrB_Matrix A = NULL, AT = NULL ;
#define LEN 512
char filename [LEN+1] ;
char atype_name [LAGRAPH_MAX_NAME_LEN] ;
void setup (void)
{
OK (LAGraph_Init (msg)) ;
}
void teardown (void)
{
OK (LAGraph_Finalize (msg)) ;
}
const char *prwhat (int pr)
{
switch (pr)
{
case 0: return ("nothing") ;
case 1: return ("terse") ;
case 2: return ("summary") ;
case 3: return ("all") ;
case 4: return ("summary (doubles in full precision)") ;
case 5: return ("all (doubles in full precision)") ;
default: ;
}
return (NULL) ;
}
typedef struct
{
LAGraph_Kind kind ;
int nself_edges ;
const char *name ;
}
matrix_info ;
const matrix_info files [ ] =
{
LAGraph_ADJACENCY_DIRECTED, 0, "cover.mtx",
LAGraph_ADJACENCY_DIRECTED, 0, "ldbc-directed-example.mtx",
LAGraph_ADJACENCY_UNDIRECTED, 0, "ldbc-undirected-example.mtx",
LAGraph_ADJACENCY_DIRECTED, 2, "west0067.mtx",
LAGRAPH_UNKNOWN, 0, ""
} ;
void test_Graph_Print (void)
{
setup ( ) ;
for (int k = 0 ; ; k++)
{
const char *aname = files [k].name ;
LAGraph_Kind kind = files [k].kind ;
if (strlen (aname) == 0) break;
TEST_CASE (aname) ;
snprintf (filename, LEN, LG_DATA_DIR "%s", aname) ;
FILE *f = fopen (filename, "r") ;
TEST_CHECK (f != NULL) ;
OK (LAGraph_MMRead (&A, f, msg)) ;
OK (fclose (f)) ;
TEST_MSG ("Loading of adjacency matrix failed") ;
OK (LAGraph_Matrix_TypeName (atype_name, A, msg)) ;
if (MATCHNAME (atype_name, "double"))
{
OK (GrB_Matrix_setElement (A, 3.14159265358979323, 0, 1)) ;
}
OK (LAGraph_New (&G, &A, kind, msg)) ;
TEST_CHECK (A == NULL) ;
for (int trial = 0 ; trial <= 1 ; trial++)
{
printf ("\n############################# TRIAL: %d\n", trial) ;
for (int pr = 0 ; pr <= 5 ; pr++)
{
printf ("\n########### %s: pr: %d (%s)\n",
aname, pr, prwhat (pr)) ;
LAGraph_PrintLevel prl = pr ;
OK (LAGraph_Graph_Print (G, prl, stdout, msg)) ;
}
int ok_result = (kind == LAGraph_ADJACENCY_UNDIRECTED) ?
LAGRAPH_CACHE_NOT_NEEDED : GrB_SUCCESS ;
int result = LAGraph_Cached_AT (G, msg) ;
TEST_CHECK (result == ok_result) ;
OK (LAGraph_Cached_IsSymmetricStructure (G, msg)) ;
OK (LAGraph_Cached_NSelfEdges (G, msg)) ;
TEST_CHECK (G->nself_edges == files [k].nself_edges) ;
}
OK (LAGraph_Delete (&G, msg)) ;
TEST_CHECK (G == NULL) ;
}
TEST_CHECK (prwhat (999) == NULL) ;
teardown ( ) ;
}
void test_Graph_Print_failures (void)
{
setup ( ) ;
int result = LAGraph_New (NULL, NULL, 0, msg) ;
printf ("\nresult: %d, msg: %s\n", result, msg) ;
TEST_CHECK (result == GrB_NULL_POINTER) ;
OK (LAGraph_New (&G, NULL, LAGraph_ADJACENCY_UNDIRECTED, msg)) ;
LAGraph_PrintLevel pr = LAGraph_COMPLETE_VERBOSE ;
result = LAGraph_Graph_Print (G, pr, stdout, msg) ;
printf ("result: %d, msg: %s\n", result, msg) ;
TEST_CHECK (result == LAGRAPH_INVALID_GRAPH) ;
OK (LAGraph_Delete (&G, msg)) ;
TEST_CHECK (G == NULL) ;
OK (GrB_Matrix_new (&A, GrB_FP32, 5, 5)) ;
OK (LAGraph_New (&G, &A, LAGraph_ADJACENCY_UNDIRECTED, msg)) ;
result = LAGraph_Graph_Print (G, pr, stdout, msg) ;
printf ("result: %d, msg: %s\n", result, msg) ;
TEST_CHECK (result == GrB_SUCCESS) ;
G->kind = -1 ;
result = LAGraph_Graph_Print (G, pr, stdout, msg) ;
printf ("result: %d, msg: %s\n", result, msg) ;
TEST_CHECK (result == LAGRAPH_INVALID_GRAPH) ;
G->kind = LAGraph_ADJACENCY_UNDIRECTED ;
OK (GrB_Matrix_new (&(G->AT), GrB_FP32, 6, 5)) ;
result = LAGraph_Graph_Print (G, pr, stdout, msg) ;
printf ("result: %d, msg: %s\n", result, msg) ;
TEST_CHECK (result == LAGRAPH_INVALID_GRAPH) ;
OK (GrB_free (&G->AT)) ;
OK (GrB_Matrix_new (&(G->AT), GrB_FP32, 5, 5)) ;
#if LAGRAPH_SUITESPARSE
OK (GrB_set (G->AT, GrB_COLMAJOR, GrB_STORAGE_ORIENTATION_HINT)) ;
result = LAGraph_Graph_Print (G, pr, stdout, msg) ;
printf ("result: %d, msg (AT colmajor): %s\n", result, msg) ;
TEST_CHECK (result == LAGRAPH_INVALID_GRAPH) ;
#endif
OK (GrB_free (&G->AT)) ;
OK (GrB_Matrix_new (&(G->AT), GrB_FP64, 5, 5)) ;
result = LAGraph_Graph_Print (G, pr, stdout, msg) ;
printf ("result: %d, msg: %s\n", result, msg) ;
TEST_CHECK (result == LAGRAPH_INVALID_GRAPH) ;
OK (LAGraph_Delete (&G, msg)) ;
TEST_CHECK (G == NULL) ;
OK (LAGraph_Delete (NULL, msg)) ;
teardown ( ) ;
}
#if LG_BRUTAL_TESTS
void test_Graph_Print_brutal (void)
{
OK (LG_brutal_setup (msg)) ;
for (int k = 0 ; ; k++)
{
const char *aname = files [k].name ;
LAGraph_Kind kind = files [k].kind ;
if (strlen (aname) == 0) break;
TEST_CASE (aname) ;
snprintf (filename, LEN, LG_DATA_DIR "%s", aname) ;
FILE *f = fopen (filename, "r") ;
TEST_CHECK (f != NULL) ;
OK (LAGraph_MMRead (&A, f, msg)) ;
OK (fclose (f)) ;
TEST_MSG ("Loading of adjacency matrix failed") ;
OK (LAGraph_Matrix_TypeName (atype_name, A, msg)) ;
if (MATCHNAME (atype_name, "double"))
{
OK (GrB_Matrix_setElement (A, 3.14159265358979323, 0, 1)) ;
}
OK (GrB_wait (A, GrB_MATERIALIZE)) ;
OK (LAGraph_New (&G, &A, kind, msg)) ;
OK (LAGraph_CheckGraph (G, msg)) ;
for (int trial = 0 ; trial <= 1 ; trial++)
{
printf ("\n############################# TRIAL: %d\n", trial) ;
for (int pr = 0 ; pr <= 5 ; pr++)
{
printf ("\n########### %s: pr: %d (%s)\n",
aname, pr, prwhat (pr)) ;
LAGraph_PrintLevel prl = pr ;
if (pr == 3 || pr == 5)
{
printf ("skipped for brutal tests\n") ;
}
else
{
LG_BRUTAL (LAGraph_Graph_Print (G, prl, stdout, msg)) ;
}
}
int ok_result = (kind == LAGraph_ADJACENCY_UNDIRECTED) ?
LAGRAPH_CACHE_NOT_NEEDED : GrB_SUCCESS ;
int result = LAGraph_Cached_AT (G, msg) ;
TEST_CHECK (result == ok_result) ;
OK (LAGraph_Cached_IsSymmetricStructure (G, msg)) ;
OK (LAGraph_Cached_NSelfEdges (G, msg)) ;
}
OK (LAGraph_Delete (&G, msg)) ;
}
OK (LG_brutal_teardown (msg)) ;
}
#endif
TEST_LIST =
{
{ "Graph_Print", test_Graph_Print },
#if LG_BRUTAL_TESTS
{ "Graph_Print_brutal", test_Graph_Print_brutal },
#endif
{ "Graph_Print_failures", test_Graph_Print_failures },
{ NULL, NULL }
} ;