Home | History | Annotate | Download | only in rpc_createdestroy_clntudp_bufcreate
      1 /*
      2 * Copyright (c) Bull S.A.  2007 All Rights Reserved.
      3 *
      4 * This program is free software; you can redistribute it and/or modify it
      5 * under the terms of version 2 of the GNU General Public License as
      6 * published by the Free Software Foundation.
      7 *
      8 * This program is distributed in the hope that it would be useful, but
      9 * WITHOUT ANY WARRANTY; without even the implied warranty of
     10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
     11 *
     12 * Further, this software is distributed without any warranty that it is
     13 * free of the rightful claim of any third person regarding infringement
     14 * or the like.  Any license provided herein, whether implied or
     15 * otherwise, applies only to this software file.  Patent licenses, if
     16 * any, provided herein do not apply to combinations of this program with
     17 * other software, or any other product whatsoever.
     18 *
     19 * You should have received a copy of the GNU General Public License along
     20 * with this program; if not, write the Free Software Foundation, Inc.,
     21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
     22 *
     23 * History:
     24 * Created by: Cyril Lacabanne (Cyril.Lacabanne (at) bull.net)
     25 *
     26 */
     27 
     28 #include <stdio.h>
     29 #include <stdlib.h>
     30 #include <time.h>
     31 #include <rpc/rpc.h>
     32 #include <sys/socket.h>
     33 #include <utmp.h>
     34 #include <sys/time.h>
     35 #include <netdb.h>
     36 
     37 //Standard define
     38 #define PROCNUM 1
     39 #define VERSNUM 1
     40 
     41 //Other define
     42 #define NBCASE 2
     43 
     44 typedef struct {
     45 	//List parameters here
     46 	int bufsnd;
     47 	int bufrec;
     48 } params;
     49 
     50 int main(int argn, char *argc[])
     51 {
     52 	//Program parameters : argc[1] : HostName or Host IP
     53 	//                                         argc[2] : Server Program Number
     54 	//                                         other arguments depend on test case
     55 
     56 	//run_mode can switch into stand alone program or program launch by shell script
     57 	//1 : stand alone, debug mode, more screen information
     58 	//0 : launch by shell script as test case, only one printf -> result status
     59 	int run_mode = 0;
     60 	int test_status = 0;	//Default test result set to PASS
     61 	int progNum = atoi(argc[2]);
     62 	int i;
     63 	params paramList[NBCASE];
     64 	CLIENT *clnt = NULL;
     65 	struct sockaddr_in server_addr;
     66 	struct hostent *hp = NULL;
     67 	struct timeval pertry_timeout;
     68 	int sock = RPC_ANYSOCK;
     69 
     70 	//Test initialization
     71 	if ((hp = gethostbyname(argc[1])) == NULL) {
     72 		fprintf(stderr, "can't get addr for %s\n", argc[1]);
     73 		exit(-1);
     74 	}
     75 
     76 	pertry_timeout.tv_sec = 1;
     77 	pertry_timeout.tv_usec = 0;
     78 
     79 	bcopy(hp->h_addr, (caddr_t) & server_addr.sin_addr, hp->h_length);
     80 	server_addr.sin_family = AF_INET;
     81 	server_addr.sin_port = 0;
     82 
     83 	//Test initialization
     84 	paramList[0].bufsnd = 2147483647;
     85 	paramList[0].bufrec = 0;
     86 	paramList[1].bufsnd = 0;
     87 	paramList[1].bufrec = 2147483647;
     88 
     89 	//Call tested function using all tests cases
     90 	for (i = 0; i < NBCASE; i++) {
     91 		//Debug mode prints
     92 		if (run_mode == 1) {
     93 			printf("Test using values : %d ", paramList[i].bufsnd);
     94 			printf("%d", paramList[i].bufrec);
     95 			printf("\n");
     96 		}
     97 		//Call function
     98 		clnt =
     99 		    clntudp_bufcreate(&server_addr, progNum, VERSNUM,
    100 				      pertry_timeout, &sock,
    101 				      paramList[i].bufsnd, paramList[i].bufrec);
    102 
    103 		//Check result
    104 		if (clnt == NULL) {
    105 			//test has failed
    106 			test_status = 1;
    107 			break;
    108 		}
    109 	}
    110 
    111 	//This last printf gives the result status to the tests suite
    112 	//normally should be 0: test has passed or 1: test has failed
    113 	printf("%d\n", test_status);
    114 
    115 	return test_status;
    116 }
    117