blob: 27a4509f7e936619f5491c678ecb558b3c4a5b61 [file] [log] [blame]
/*
* Copyright (c) Bull S.A. 2007 All Rights Reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* Further, this software is distributed without any warranty that it is
* free of the rightful claim of any third person regarding infringement
* or the like. Any license provided herein, whether implied or
* otherwise, applies only to this software file. Patent licenses, if
* any, provided herein do not apply to combinations of this program with
* other software, or any other product whatsoever.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
* History:
* Created by: Cyril Lacabanne (Cyril.Lacabanne@bull.net)
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <sys/time.h>
#include "lapi/rpc.h"
//Standard define
#define PROCNUM 1
#define VERSNUM 1
//Set number of test call
int maxIter;
double average(double *tbl)
{
//Return average of values in tbl
int i;
double rslt = 0;
for (i = 0; i < maxIter; i++) {
rslt += tbl[i];
}
rslt = rslt / maxIter;
return rslt;
}
double mini(double *tbl)
{
//Return minimal of values in tbl
int i;
double rslt = tbl[0];
for (i = 0; i < maxIter; i++) {
if (rslt > tbl[i])
rslt = tbl[i];
}
return rslt;
}
double maxi(double *tbl)
{
//Return maximal of values in tbl
int i;
double rslt = tbl[0];
for (i = 0; i < maxIter; i++) {
if (rslt < tbl[i])
rslt = tbl[i];
}
return rslt;
}
int main(int argn, char *argc[])
{
//Program parameters : argc[1] : HostName or Host IP
// argc[2] : Server Program Number
// argc[3] : Number of test call
// other arguments depend on test case
//run_mode can switch into stand alone program or program launch by shell script
//1 : stand alone, debug mode, more screen information
//0 : launch by shell script as test case, only one printf -> result status
int run_mode = 0;
int test_status = 0; //Default test result set to FAILED
int i;
double *resultTbl;
struct timeval tv1, tv2;
struct timezone tz;
long long diff;
double rslt;
int progNum = atoi(argc[2]);
int sndVar = 0;
int recVar = -1;
CLIENT *client = NULL;
struct netconfig *nconf = NULL;
struct timeval tv;
enum clnt_stat cs;
//Test initialisation
maxIter = atoi(argc[3]);
resultTbl = malloc(maxIter * sizeof(double));
nconf = getnetconfigent("udp");
if ((struct netconfig *)nconf == NULL) {
//Test failed
printf("5\n");
return 5;
}
tv.tv_sec = 1;
tv.tv_usec = 1;
client = clnt_tp_create_timed(argc[1], progNum,
VERSNUM, (struct netconfig *)nconf, &tv);
if (client == NULL) {
printf("5\n");
return 5;
}
//Call tested function several times
for (i = 0; i < maxIter; i++) {
//Tic
gettimeofday(&tv1, &tz);
//Call function
cs = clnt_call(client, PROCNUM, (xdrproc_t) xdr_int, (char *)&sndVar, // xdr_in
(xdrproc_t) xdr_int, (char *)&recVar, // xdr_out
tv);
//Toc
gettimeofday(&tv2, &tz);
//Add function execution time (toc-tic)
diff =
(tv2.tv_sec - tv1.tv_sec) * 1000000L + (tv2.tv_usec -
tv1.tv_usec);
rslt = (double)diff / 1000;
if (cs == RPC_SUCCESS) {
resultTbl[i] = rslt;
} else {
test_status = 1;
break;
}
if (run_mode) {
fprintf(stderr, "lf time = %lf usecn\n", resultTbl[i]);
}
}
//This last printf gives the result status to the tests suite
//normally should be 0: test has passed or 1: test has failed
printf("%d\n", test_status);
printf("%lf %d\n", average(resultTbl), maxIter);
printf("%lf\n", mini(resultTbl));
printf("%lf\n", maxi(resultTbl));
return test_status;
}