⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 perfsendinviteack.cxx

📁 SIP 1.5.0源代码
💻 CXX
字号:
/* ==================================================================== * The Vovida Software License, Version 1.0  *  * Copyright (c) 2000 Vovida Networks, Inc.  All rights reserved. *  * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: *  * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. *  * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in *    the documentation and/or other materials provided with the *    distribution. *  * 3. The names "VOCAL", "Vovida Open Communication Application Library", *    and "Vovida Open Communication Application Library (VOCAL)" must *    not be used to endorse or promote products derived from this *    software without prior written permission. For written *    permission, please contact vocal@vovida.org. * * 4. Products derived from this software may not be called "VOCAL", nor *    may "VOCAL" appear in their name, without prior written *    permission of Vovida Networks, Inc. *  * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND * NON-INFRINGEMENT ARE DISCLAIMED.  IN NO EVENT SHALL VOVIDA * NETWORKS, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT DAMAGES * IN EXCESS OF $1,000, NOR FOR ANY INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH * DAMAGE. *  * ==================================================================== *  * This software consists of voluntary contributions made by Vovida * Networks, Inc. and many individuals on behalf of Vovida Networks, * Inc.  For more information on Vovida Networks, Inc., please see * <http://www.vovida.org/>. * */#include <cstdlib>#include <fstream>#include "Sptr.hxx"#include "Data.hxx"#include "VovidaSipStack.hxx"#include "InviteMsg.hxx"#include "AckMsg.hxx"#include "PerfDuration.hxx"#include "PerformanceDb.hxx"#include "TickCount.hxx"using namespace Vocal;using Vocal::Statistics::PerfDuration;using Vocal::Statistics::PerformanceDb;    using Vocal::Statistics::TickCount;using Vocal::Statistics::Statistic;    ///intmain( int argc, char* argv[] ){    if ( argc < 3)    {        cerr << "Usage: "        << argv[0]        << " <local_SIP_port>"        << " <msg_file_name>"        << " [  <#messages> ]"        << endl;        exit( -1 );    }     int numOfMessages = 1;       SipTransceiverFilter stack( "perfsendInviteAck", atoi( argv[1] ) );        stack.setRandomLosePercent(0);    std::ifstream inputFile( argv[2] );    if ( !inputFile )    {        cerr << "Error: Cannot open input file " << argv[2] << endl;        exit( -1 );    }    string str;    char ch;    while ( inputFile.get( ch ) )    {        str += ch;    }    // Optional command line arguments    if ( argc >= 4 )    {        numOfMessages = atoi( argv[3] );    }   #if 0    cout << "\t<<< Send Invite Message test >>>\n" << endl;    cout << "     Local SIP Port : " << argv[1] << endl;    cout << "         Input File : " << argv[2] << endl;    cout << " Number of Messages : " << numOfMessages << endl;    cout << "           Interval : " << interval << endl;    cout << "           Log File : " << logFile.logData() << endl;    cout << endl << "<<< Message to send begin >>>" << endl << str << endl;    cout << "<<< Message to send end >>>" << endl << endl;#endif        Data data(str);    InviteMsg inviteMsg( data );        Sptr < SipMsgQueue > sipRcv;    Sptr < SipMsg > sipMsg;    Sptr < StatusMsg > statusMsg;               PerfDuration stat( Data("sendInviteAck"));       double sum = 0;#if 0    struct timeval tvStart, tvEnd;    struct timezone tz;    tz.tz_minuteswest = 0;    tz.tz_dsttime = 0;    timerclear(&tvStart);    if (gettimeofday(&tvStart,&tz) > 0 ) {	perror("gettimeofday 1 failed:");	return 0;    }#endif    for ( int i = 1; i <= numOfMessages; i++ )    {        //different INVITES, different TransactionIds.        SipCallId callId;        inviteMsg.setCallId( callId );        cout << "sending INVITE: " << inviteMsg.encode().logData() << endl;         stat.start();        // Send INVITE        stack.sendAsync( inviteMsg );            sipRcv = stack.receive(3200);    	if ( sipRcv != 0 )	{	    sipMsg = sipRcv->back();	    if ( sipMsg != 0 )	    {		Sptr <StatusMsg> statusMsg;				statusMsg.dynamicCast(sipMsg); 				if(statusMsg.getPtr() != 0)		{		        cout << "received STATUS: " << statusMsg->encode().logData() << endl;		    //form the ACK		    AckMsg ackMsg(*statusMsg);		    stack.sendAsync(ackMsg);cout << "sending ACK: " << ackMsg.encode().logData() << endl;		    		}	    }	}            stat.stop();        stat.record();	sum+= stat.average();        }//end for.#if 0    timerclear(&tvEnd);    if (gettimeofday(&tvEnd,&tz) > 0 ) {	perror("gettimeofday 2 failed:");	return 0;    }#endif    double avg = sum/numOfMessages;        cout << "average ticks" << avg << endl;    //cout << "total real time: " << tvEnd.tv_sec - tvStart.tv_sec << " seconds" << endl;    #if 0    //gives seg fault    PerfDuration combinedStat = *((PerfDuration*)PerformanceDb::instance().find(stat));        cout << "This stat: " << combinedStat << endl;      cout << "Average: " << combinedStat.average() << endl;        TickCount::calibrate();        cout << "time in seconds: " << combinedStat.average() / TickCount::ticksPerSec << endl;#endif        //other statistics stuff.    return 0;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -