blob: 2aedbcc5982564140eaebfc894d3aca54fca46a2 [file] [log] [blame]
// Copyright 2003-2004 The Apache Software Foundation.
// (c) Copyright IBM Corp. 2004, 2005 All Rights Reserved
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
/* This program will create 10 Threads and each thread will invoke FaultMapping Service
@Author James
*/
#include "MathOps.hpp"
#include <axis/AxisException.hpp>
//#include <exception>
#include <ctype.h>
#include <iostream>
#include <stdlib.h>
#include <axis/Axis.hpp>
#include <signal.h>
/* Defining platform specific constants */
#ifdef WIN32
#include <windows.h>
#define RETTYPE DWORD WINAPI
#define ARGTYPE LPVOID
#else
#include <pthread.h>
#include <unistd.h>
#define RETTYPE void*
#define ARGTYPE void*
#endif
//#define MACRO_NUM_THREADS 10
//int NUM_THREADS = MACRO_NUM_THREADS;
#define NUM_THREADS 10
void sig_handler(int);
/* In windows the entry point function return type is DWORD WINAPI
In linux it is void * */
RETTYPE ThreadFunc(ARGTYPE Param)
{
/*Type casting the url to char * */
char endpoint[256];
const char* server="localhost";
const char* url="http://localhost:80/axis/MathOps";
const char* port="80";
const char* op = 0;
const char* p1 = 0;
const char* p2 = 0;
int i1=0, i2=0;
int iResult;
char* pcDetail;
signal(SIGILL, sig_handler);
signal(SIGABRT, sig_handler);
signal(SIGSEGV, sig_handler);
//signal(SIGQUIT, sig_handler);
//signal(SIGBUS, sig_handler);
signal(SIGFPE, sig_handler);
url = (char *)Param;
sprintf(endpoint, "%s", url);
op = "div";
if (strcmp(op, "div") == 0)
{
for(int i = 0; i < 4; i++)
{
// cout << i << endl;
switch(i)
{
case 0: i1 = 10; i2 = 5; break;
case 1: i1 = 10; i2 = 0; break;
case 2: i1 = 1000; i2 = 5; break;
case 3: i1 = 10; i2 = -5; break;
}
bool bSuccess = false;
int iRetryIterationCount = 3;
do
{
try
{
MathOps ws(endpoint);
//cout << "Trying to " << op << " " << i1 << " by " << i2 << endl;
iResult = ws.div(i1, i2);
//cout << "Result is " << iResult << endl;
bSuccess = true;
}
catch(DivByZeroStruct& dbzs)
{
/*cout << "DivByZeroStruct Fault: \""
<< dbzs.varString
<< "\", "
<< dbzs.varInt
<< ", "
<< dbzs.varFloat
<< endl; */
bSuccess = true;
}
catch(SpecialDetailStruct& sds)
{
/*cout << "SpecialDetailStruct Fault: \""
<< sds.varString
<< "\""
<< endl;*/
bSuccess = true;
}
catch(OutOfBoundStruct& oobs)
{
/*cout << "OutOfBoundStruct Fault: \""
<< oobs.varString
<< "\", "
<< oobs.varInt
<< ", \""
<< oobs.specialDetail->varString
<< "\""
<< endl;*/
if(i==3)
{
cout<<"Success"<<endl;
}
bSuccess = true;
}
catch(SoapFaultException& sfe)
{
cout << "SoapFaultException: " << sfe.what() << endl;
}
catch(AxisException& e)
{
bool bSilent = false;
if( e.getExceptionCode() == CLIENT_TRANSPORT_OPEN_CONNECTION_FAILED)
{
if( iRetryIterationCount > 0)
{
bSilent = true;
}
}
else
{
iRetryIterationCount = 0;
}
if( !bSilent)
{
cout << "AxisException: " << e.what() << endl;
}
}
catch(exception& e)
{
cout << "Unknown Exception: " << endl;
}
catch(...)
{
cout << "Unspecified Exception: " << endl;
}
iRetryIterationCount--;
} while( iRetryIterationCount > 0 && !bSuccess);
}
}
else
{
cout << "Invalid operation " << op << endl;
}
#ifndef WIN32
pthread_exit(0);
#endif
return 0;
}
int main(int argc, char *argv[])
{
Axis::initialize(false);
try{
int i;
#ifdef WIN32
/*Windows specific code comes here */
HANDLE hThread[NUM_THREADS];
for(i=0;i<NUM_THREADS;i++){
DWORD dwThreadId;
//LPVOID dwThrdParam = LPVOID(argv[1]);
hThread[i] = CreateThread(
NULL, // no security attributes
0, // use default stack size
ThreadFunc, // thread function
LPVOID(argv[1]), // argument to thread function
0,
&dwThreadId); // returns the thread identifier
if (hThread[i] == NULL)
{
cout<<"Thread creation Failed";
}
}
/* Waiting for threads to terminate */
WaitForMultipleObjects(NUM_THREADS,hThread,true, INFINITE);
for(i=0;i<NUM_THREADS;i++)
CloseHandle( hThread[i] );
#else
pthread_t thread[NUM_THREADS];
pthread_attr_t attr;
int rc, t;
void *status;
// Initialize and set thread detached attribute
pthread_attr_init(&attr);
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);
for (t = 0; t < NUM_THREADS; t++)
{
/*Creating threads */
rc = pthread_create(&thread[t], &attr, ThreadFunc,(void *)argv[1]);
if (rc)
{
cout<<"Thread Creation Failed";
}
}
//Free attribute and wait for the other threads
pthread_attr_destroy(&attr);
/* Wait for the threads to terminate */
for(t=0;t<NUM_THREADS;t++){
rc = pthread_join(thread[t], &status);
if (rc)
{
cout<<"ERROR from pthread_join()"<<endl;
}
}
#endif
}catch(exception &e){
cout<< e.what();
}
cout<<"----------------------------------TEST COMPLETE--------------------------------"<<endl;
}
void sig_handler(int sig) {
signal(sig, sig_handler);
cout << "SIGNAL RECEIVED " << sig << endl;
exit(1);
}