END_TEST START_TEST (test_FunctionDefinition_getArguments) { const ASTNode_t *math; ASTNode_t* math1 = SBML_parseFormula("lambda(x, y, x^y)"); FunctionDefinition_setMath(FD, math1 ); ASTNode_free(math1); fail_unless( FunctionDefinition_getNumArguments(FD) == 2 ); math = FunctionDefinition_getArgument(FD, 0); fail_unless( math != NULL ); fail_unless( ASTNode_isName(math) ); fail_unless( !strcmp(ASTNode_getName(math), "x") ); fail_unless( ASTNode_getNumChildren(math) == 0 ); math = FunctionDefinition_getArgument(FD, 1); fail_unless( math != NULL ); fail_unless( ASTNode_isName(math) ); fail_unless( !strcmp(ASTNode_getName(math), "y") ); fail_unless( ASTNode_getNumChildren(math) == 0 ); fail_unless( FunctionDefinition_getArgument(FD, 0) == FunctionDefinition_getArgumentByName(FD, "x") ); fail_unless( FunctionDefinition_getArgument(FD, 1) == FunctionDefinition_getArgumentByName(FD, "y") ); }
END_TEST START_TEST (test_FunctionDefinition_setMath) { ASTNode_t *math = SBML_parseFormula("lambda(x, x^3)"); const ASTNode_t * math1; char * formula; FunctionDefinition_setMath(FD, math); 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( FunctionDefinition_isSetBody(FD) ); /* Reflexive case (pathological) */ FunctionDefinition_setMath(FD, (ASTNode_t *) FunctionDefinition_getMath(FD)); math1 = FunctionDefinition_getMath(FD); fail_unless( math1 != NULL ); safe_free(formula); formula = SBML_formulaToString(math1); fail_unless( formula != NULL ); fail_unless( !strcmp(formula, "lambda(x, x^3)") ); fail_unless( FunctionDefinition_getMath(FD) != math ); FunctionDefinition_setMath(FD, NULL); fail_unless( !FunctionDefinition_isSetMath(FD) ); fail_unless( !FunctionDefinition_isSetBody(FD) ); if (FunctionDefinition_getMath(FD) != NULL) { fail("FunctionDefinition_setMath(FD, NULL) did not clear ASTNode."); } ASTNode_free(math); safe_free(formula); }
END_TEST START_TEST (test_FunctionDefinition_setMath1) { ASTNode_t *math = SBML_parseFormula("2 * k"); int i = FunctionDefinition_setMath(E, math); fail_unless( i == LIBSBML_OPERATION_SUCCESS); fail_unless( FunctionDefinition_getMath(E) != math ); fail_unless( FunctionDefinition_isSetMath(E) ); i = FunctionDefinition_setMath(E, NULL); fail_unless( i == LIBSBML_OPERATION_SUCCESS); fail_unless( FunctionDefinition_getMath(E) == NULL ); fail_unless( !FunctionDefinition_isSetMath(E) ); ASTNode_free(math); }
END_TEST START_TEST (test_FunctionDefinition_setMath2) { ASTNode_t *math = ASTNode_createWithType(AST_TIMES); int i = FunctionDefinition_setMath(E, math); fail_unless( i == LIBSBML_INVALID_OBJECT); fail_unless( !FunctionDefinition_isSetMath(E) ); ASTNode_free(math); }
END_TEST START_TEST (test_FunctionDefinition_getBody) { const ASTNode_t *math; ASTNode_t * math1 = SBML_parseFormula("lambda(x, x)"); FunctionDefinition_setMath(FD, math1 ); math = FunctionDefinition_getBody(FD); fail_unless( math != NULL ); fail_unless( ASTNode_isName(math) ); fail_unless( !strcmp(ASTNode_getName(math), "x") ); fail_unless( ASTNode_getNumChildren(math) == 0 ); ASTNode_free(math1); }
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); }