END_TEST START_TEST (test_FunctionDefinition_setId) { const char *id = "pow3"; FunctionDefinition_setId(FD, id); fail_unless( !strcmp(FunctionDefinition_getId(FD), id) ); fail_unless( FunctionDefinition_isSetId(FD) ); if (FunctionDefinition_getId(FD) == id) { fail("FunctionDefinition_setId(...) did not make a copy of string."); } /* Reflexive case (pathological) */ FunctionDefinition_setId(FD, FunctionDefinition_getId(FD)); fail_unless( !strcmp(FunctionDefinition_getId(FD), id) ); FunctionDefinition_setId(FD, NULL); fail_unless( !FunctionDefinition_isSetId(FD) ); if (FunctionDefinition_getId(FD) != NULL) { fail("FunctionDefinition_setId(FD, NULL) did not clear string."); } }
END_TEST START_TEST (test_FunctionDefinition_setId2) { char *id = "e1"; int i = FunctionDefinition_setId(E, id); fail_unless( i == LIBSBML_OPERATION_SUCCESS ); fail_unless( !strcmp(FunctionDefinition_getId(E), id) ); fail_unless( FunctionDefinition_isSetId(E) ); i = FunctionDefinition_setId(E, NULL); fail_unless( i == LIBSBML_OPERATION_SUCCESS ); fail_unless( !FunctionDefinition_isSetId(E) ); }
END_TEST START_TEST (test_FunctionDefinition_createWith) { ASTNode_t *math = SBML_parseFormula("lambda(x, x^3)"); FunctionDefinition_t *fd = FunctionDefinition_create(2, 4); FunctionDefinition_setId(fd, "pow3"); FunctionDefinition_setMath(fd, math); const ASTNode_t * math1; char * formula; fail_unless( SBase_getTypeCode((SBase_t *) fd) == SBML_FUNCTION_DEFINITION ); fail_unless( SBase_getMetaId ((SBase_t *) fd) == NULL ); fail_unless( SBase_getNotes ((SBase_t *) fd) == NULL ); fail_unless( SBase_getAnnotation((SBase_t *) fd) == NULL ); fail_unless( FunctionDefinition_getName(fd) == NULL ); math1 = FunctionDefinition_getMath(fd); fail_unless( math1 != NULL ); formula = SBML_formulaToString(math1); fail_unless( formula != NULL ); fail_unless( !strcmp(formula, "lambda(x, x^3)") ); fail_unless( FunctionDefinition_getMath(fd) != math ); fail_unless( FunctionDefinition_isSetMath(fd) ); fail_unless( !strcmp(FunctionDefinition_getId(fd), "pow3") ); fail_unless( FunctionDefinition_isSetId(fd) ); ASTNode_free(math); safe_free(formula); FunctionDefinition_free(fd); }