TPCCLIB
Loading...
Searching...
No Matches
libtpcmodels.c
1/******************************************************************************
2 * This file is not compiled into the library, but it contains main()
3 * which is compiled to an executable, used to test the library functions.
4 *****************************************************************************/
5
6/*****************************************************************************/
7#include "tpcclibConfig.h"
8/*****************************************************************************/
9#include <stdio.h>
10#include <stdlib.h>
11#include <math.h>
12#include <time.h>
13#include <string.h>
14#include <ctype.h>
15#include <unistd.h>
16/*****************************************************************************/
17#include "tpcextensions.h"
18/*****************************************************************************/
19#include "tpcmodels.h"
20#include "test_tpcmodels.h"
21/*****************************************************************************/
22
23/*****************************************************************************/
24static char *info[] = {
25 "Usage: @P [options]",
26 " ",
27 "Options:",
28 " -stdoptions", // List standard options like --help, -v, etc
29 " -t, --test",
30 " Run all tests for library functions.",
31 0};
32/*****************************************************************************/
33
34/*****************************************************************************/
39int main(
41 int argc,
43 char *argv[ ]
44) {
45 int i, help=0, version=0, verbose=1, error=0, test=0;
46 int ret;
47 char *cptr;
48
49 if(argc==1) {tpcPrintUsage(argv[0], info, stdout); return(0);}
50 for(i=1; i<argc; i++) {
51 if(tpcProcessStdOptions(argv[i], &help, &version, &verbose)==0) continue;
52 cptr=argv[i]; if(*cptr=='-') cptr++; if(*cptr=='-') cptr++;
53 if(strncasecmp(cptr, "TEST", 1)==0) {
54 test=1; continue;
55 } else {
56 error++; break;
57 }
58 }
59 if(error>0) {
60 fprintf(stderr, "Error: specify --help for usage.\n");
61 return(1);
62 }
63 /* Print help or version? */
64 if(help) {tpcPrintUsage(argv[0], info, stdout); return(0);}
65 if(version) {tpcPrintBuild(argv[0], stdout); return(0);}
66
67 if(test==0) return(0);
68
69 if(verbose>0) printf("running tests for library functions...\n");
70 TPCSTATUS status; statusInit(&status); status.verbose=verbose;
71 statusSet(&status, __func__, __FILE__, __LINE__, 0);
72 i=10;
73 /* modell */
74 i++; if((ret=test_tpc_model(&status))!=0) {
75 fprintf(stderr, "failed (%d).\n", ret);
76 statusPrint(stderr, &status); statusFree(&status);
77 return(i);
78 }
79 i++; if((ret=test_modelNr(&status))!=0) {
80 fprintf(stderr, "failed (%d).\n", ret);
81 statusPrint(stderr, &status); statusFree(&status);
82 return(i);
83 }
84 i++; if((ret=test_modelCode(&status))!=0) {
85 fprintf(stderr, "failed (%d).\n", ret);
86 statusPrint(stderr, &status); statusFree(&status);
87 return(i);
88 }
89 i++; if((ret=test_modelOldId(&status))!=0) {
90 fprintf(stderr, "failed (%d).\n", ret);
91 statusPrint(stderr, &status); statusFree(&status);
92 return(i);
93 }
94 i++; if((ret=test_modelOld2New(&status))!=0) {
95 fprintf(stderr, "failed (%d).\n", ret);
96 statusPrint(stderr, &status); statusFree(&status);
97 return(i);
98 }
99 i++; if((ret=test_modelDesc(&status))!=0) {
100 fprintf(stderr, "failed (%d).\n", ret);
101 statusPrint(stderr, &status); statusFree(&status);
102 return(i);
103 }
104 i++; if((ret=test_modelCodeIndex(&status))!=0) {
105 fprintf(stderr, "failed (%d).\n", ret);
106 statusPrint(stderr, &status); statusFree(&status);
107 return(i);
108 }
109 i++; if((ret=test_modelParNr(&status))!=0) {
110 fprintf(stderr, "failed (%d).\n", ret);
111 statusPrint(stderr, &status); statusFree(&status);
112 return(i);
113 }
114 /* aic */
115 i++; if((ret=test_aicSS(&status))!=0) {
116 fprintf(stderr, "failed (%d).\n", ret);
117 statusPrint(stderr, &status); statusFree(&status);
118 return(i);
119 }
120 i++; if((ret=test_parFreeNr(&status))!=0) {
121 fprintf(stderr, "failed (%d).\n", ret);
122 statusPrint(stderr, &status); statusFree(&status);
123 return(i);
124 }
125 /* optcrit */
126 i++; if((ret=test_optcritNr(&status))!=0) {
127 fprintf(stderr, "failed (%d).\n", ret);
128 statusPrint(stderr, &status); statusFree(&status);
129 return(i);
130 }
131 i++; if((ret=test_optcritCode(&status))!=0) {
132 fprintf(stderr, "failed (%d).\n", ret);
133 statusPrint(stderr, &status); statusFree(&status);
134 return(i);
135 }
136 i++; if((ret=test_optcritDesc(&status))!=0) {
137 fprintf(stderr, "failed (%d).\n", ret);
138 statusPrint(stderr, &status); statusFree(&status);
139 return(i);
140 }
141 i++; if((ret=test_optcritId(&status))!=0) {
142 fprintf(stderr, "failed (%d).\n", ret);
143 statusPrint(stderr, &status); statusFree(&status);
144 return(i);
145 }
146
147 if(verbose>0) printf("\nAll tests passed.\n\n");
148 statusFree(&status);
149 return(0);
150}
151/*****************************************************************************/
152
153/*****************************************************************************/
int tpcProcessStdOptions(const char *s, int *print_usage, int *print_version, int *verbose_level)
Definition proginfo.c:47
void tpcPrintBuild(const char *program, FILE *fp)
Definition proginfo.c:339
void tpcPrintUsage(const char *program, char *text[], FILE *fp)
Definition proginfo.c:114
void statusPrint(FILE *fp, TPCSTATUS *s)
Definition statusmsg.c:82
void statusInit(TPCSTATUS *s)
Definition statusmsg.c:104
void statusSet(TPCSTATUS *s, const char *func, const char *srcfile, int srcline, tpcerror error)
Definition statusmsg.c:142
void statusFree(TPCSTATUS *s)
Definition statusmsg.c:126
int verbose
Verbose level, used by statusPrint() etc.
Header file for library libtpcextensions.
Header file for libtpcmodels.