Windows NT 4.0 source code leak
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

800 lines
21 KiB

/*++
Copyright (c) 1995 Microsoft Corporation
Module Name:
itlpm.c
Abstract:
This module contains the test functions for lineProxyMessage
Author:
Xiao Ying Ding (XiaoD) 20-Dec-1995
Revision History:
--*/
#include "windows.h"
#include "malloc.h"
#include "string.h"
#include "tapi.h"
#include "trapper.h"
#include "tcore.h"
#include "ttest.h"
#include "doline.h"
#include "vars.h"
#include "line20.h"
// lineProxyMessage
//
// The following tests are made:
//
// Tested Notes
// -------------------------------------------------------------------------
// 1. Go/No-Go test
// 2. Bad hLine
// 3. Bad hCall
// 4. Bad dwMsg
// 5. Bad dwParam1
// 6. Bad dwParam2
// 7. Bad dwParam3
// 8. Open with no PROXY request
//
// * = Stand-alone test case
//
//
BOOL TestLineProxyMessage(BOOL fQuietMode, BOOL fStandAlone)
{
LPTAPILINETESTINFO lpTapiLineTestInfo;
INT i;
BOOL fTestPassed = TRUE;
LPDWORD lpRequestBuf;
LONG lret;
LPTAPIMSG lpTapiMsg = NULL;
LPTAPIMSG lpMatch;
dwTestCasePassed = 0;
dwTestCaseFailed = 0;
dwTestCase = 0;
OutputTAPIDebugInfo(
DBUG_SHOW_PASS,
"\n***************************************************************");
OutputTAPIDebugInfo(
DBUG_SHOW_PASS,
">> Test lineProxyMessage");
// ===================================================================
// ===================================================================
//
// 1. Test Case: Go/No-Go test for owner.
//
// ===================================================================
// ===================================================================
TapiLineTestInit();
lpTapiLineTestInfo = GetLineTestInfo();
fTestPassed = TRUE;
//
// Initialize a line app
//
lpTapiLineTestInfo->lpLineInitializeExParams =
(LPLINEINITIALIZEEXPARAMS) AllocFromTestHeap (
sizeof(LINEINITIALIZEEXPARAMS));
lpTapiLineTestInfo->lpLineInitializeExParams->dwTotalSize =
sizeof(LINEINITIALIZEEXPARAMS);
lpTapiLineTestInfo->lpLineInitializeExParams->dwOptions =
LINEINITIALIZEEXOPTION_USEHIDDENWINDOW;
lpTapiLineTestInfo->lpdwAPIVersion = &lpTapiLineTestInfo->dwAPIVersion;
lpTapiLineTestInfo->dwAPIVersion = TAPI_VERSION2_0;
if(! DoLineInitializeEx (lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
lpTapiLineTestInfo->dwDeviceID =
(*(lpTapiLineTestInfo->lpdwNumDevs) == 0 ?
0 : *(lpTapiLineTestInfo->lpdwNumDevs)-1);
if(IsUNIMDMLineDevice(lpTapiLineTestInfo))
{
TapiLogDetail(
DBUG_SHOW_DETAIL,
"## ProxyMessage: unimodem didn't support");
return fTestPassed;
}
lpTapiLineTestInfo->dwAPIVersion = HIGH_APIVERSION;
lpTapiLineTestInfo->dwExtLowVersion = LOW_APIVERSION;
lpTapiLineTestInfo->dwExtHighVersion = HIGH_APIVERSION;
lpTapiLineTestInfo->lpdwExtVersion = &lpTapiLineTestInfo->dwExtVersion;
//
// Negotiate the API Ext Version
//
if (! DoLineNegotiateExtVersion(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
//
// Open a line
//
lpTapiLineTestInfo->dwMediaModes = LINEMEDIAMODE_DATAMODEM;
lpTapiLineTestInfo->dwPrivileges = LINECALLPRIVILEGE_OWNER |
LINEOPENOPTION_PROXY;
lpTapiLineTestInfo->lpCallParams = (LPLINECALLPARAMS) AllocFromTestHeap (
sizeof(LINECALLPARAMS) + sizeof(DWORD));
lpTapiLineTestInfo->lpCallParams->dwTotalSize =
sizeof(LINECALLPARAMS) + sizeof(DWORD);
lpTapiLineTestInfo->lpCallParams->dwDevSpecificSize =
sizeof(DWORD);
lpTapiLineTestInfo->lpCallParams->dwDevSpecificOffset =
sizeof(LINECALLPARAMS);
lpRequestBuf = (LPDWORD) (((LPBYTE)lpTapiLineTestInfo->lpCallParams) +
lpTapiLineTestInfo->lpCallParams->dwDevSpecificOffset);
*lpRequestBuf = LINEPROXYREQUEST_GETAGENTACTIVITYLIST;
if (! DoLineOpen(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
TapiLogDetail(
DBUG_SHOW_PASS,
"#### Test Case %ld: lineProxyMessage for go/no-go",
dwTestCase+1);
lpTapiLineTestInfo->dwMsg = LINE_AGENTSTATUS;
lpTapiLineTestInfo->dwParam1 = 0;
lpTapiLineTestInfo->dwParam2 = LINEAGENTSTATUS_ACTIVITY;
lpTapiLineTestInfo->dwParam3 = 0;
if (! DoLineProxyMessage(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
AddMessage (LINE_REPLY,
0,
0,
0,
lpTapiLineTestInfo->dwResult,
0,
TAPIMSG_DWMSG | TAPIMSG_DWPARAM2);
WaitForAllMessages();
fTestPassed = ShowTestCase(fTestPassed);
//
// Close the line
//
if (! DoLineClose(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
//
// Shutdown
//
if (! DoLineShutdown(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
FreeTestHeap();
// ===================================================================
// ===================================================================
//
// 2. Test Case: Bad hLine
//
// ===================================================================
// ===================================================================
TapiLineTestInit();
lpTapiLineTestInfo = GetLineTestInfo();
fTestPassed = TRUE;
//
// Initialize a line app
//
lpTapiLineTestInfo->lpLineInitializeExParams =
(LPLINEINITIALIZEEXPARAMS) AllocFromTestHeap (
sizeof(LINEINITIALIZEEXPARAMS));
lpTapiLineTestInfo->lpLineInitializeExParams->dwTotalSize =
sizeof(LINEINITIALIZEEXPARAMS);
lpTapiLineTestInfo->lpLineInitializeExParams->dwOptions =
LINEINITIALIZEEXOPTION_USEHIDDENWINDOW;
lpTapiLineTestInfo->lpdwAPIVersion = &lpTapiLineTestInfo->dwAPIVersion;
lpTapiLineTestInfo->dwAPIVersion = TAPI_VERSION2_0;
if(! DoLineInitializeEx (lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
lpTapiLineTestInfo->dwDeviceID =
(*(lpTapiLineTestInfo->lpdwNumDevs) == 0 ?
0 : *(lpTapiLineTestInfo->lpdwNumDevs)-1);
if(IsUNIMDMLineDevice(lpTapiLineTestInfo))
{
TapiLogDetail(
DBUG_SHOW_DETAIL,
"## ProxyMessage: unimodem didn't support");
return fTestPassed;
}
lpTapiLineTestInfo->dwAPIVersion = HIGH_APIVERSION;
lpTapiLineTestInfo->dwExtLowVersion = LOW_APIVERSION;
lpTapiLineTestInfo->dwExtHighVersion = HIGH_APIVERSION;
lpTapiLineTestInfo->lpdwExtVersion = &lpTapiLineTestInfo->dwExtVersion;
//
// Negotiate the API Ext Version
//
if (! DoLineNegotiateExtVersion(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
//
// Open a line
//
lpTapiLineTestInfo->dwMediaModes = LINEMEDIAMODE_DATAMODEM;
lpTapiLineTestInfo->dwPrivileges = LINECALLPRIVILEGE_OWNER |
LINEOPENOPTION_PROXY;
lpTapiLineTestInfo->lpCallParams = (LPLINECALLPARAMS) AllocFromTestHeap (
sizeof(LINECALLPARAMS) + sizeof(DWORD));
lpTapiLineTestInfo->lpCallParams->dwTotalSize =
sizeof(LINECALLPARAMS) + sizeof(DWORD);
lpTapiLineTestInfo->lpCallParams->dwDevSpecificSize =
sizeof(DWORD);
lpTapiLineTestInfo->lpCallParams->dwDevSpecificOffset =
sizeof(LINECALLPARAMS);
lpRequestBuf = (LPDWORD) (((LPBYTE)lpTapiLineTestInfo->lpCallParams) +
lpTapiLineTestInfo->lpCallParams->dwDevSpecificOffset);
*lpRequestBuf = LINEPROXYREQUEST_GETAGENTACTIVITYLIST;
if (! DoLineOpen(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
TapiLogDetail(
DBUG_SHOW_PASS,
"#### Test Case %ld: Bad hLine",
dwTestCase+1);
lpTapiLineTestInfo->dwMsg = LINE_AGENTSTATUS;
lpTapiLineTestInfo->dwParam1 = 0;
lpTapiLineTestInfo->dwParam2 = LINEAGENTSTATUS_ACTIVITY;
lpTapiLineTestInfo->dwParam3 = 0;
//
// save previous hLine
//
lpTapiLineTestInfo->hLine_Orig = lpTapiLineTestInfo->hLine1;
//
// Test invalid handles
//
for(i = 0; i < NUMINVALIDHANDLES; i++)
{
*lpTapiLineTestInfo->lphLine = (HLINE)gdwInvalidHandles[i];
if (! DoLineProxyMessage(lpTapiLineTestInfo,
LINEERR_INVALLINEHANDLE))
{
TLINE_FAIL();
}
}
//
// Reset hLine
//
lpTapiLineTestInfo->hLine1 = lpTapiLineTestInfo->hLine_Orig;
fTestPassed = ShowTestCase(fTestPassed);
//
// Close the line
//
if (! DoLineClose(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
//
// Shutdown
//
if (! DoLineShutdown(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
FreeTestHeap();
// ===================================================================
// ===================================================================
//
// 3. Test Case: Bad dwMsg
// 4. Bad dwParam1
// 5. Bad dwParam2
// 6. Bad dwParam3
//
// ===================================================================
// ===================================================================
TapiLineTestInit();
lpTapiLineTestInfo = GetLineTestInfo();
fTestPassed = TRUE;
//
// Initialize a line app
//
lpTapiLineTestInfo->lpLineInitializeExParams =
(LPLINEINITIALIZEEXPARAMS) AllocFromTestHeap (
sizeof(LINEINITIALIZEEXPARAMS));
lpTapiLineTestInfo->lpLineInitializeExParams->dwTotalSize =
sizeof(LINEINITIALIZEEXPARAMS);
lpTapiLineTestInfo->lpLineInitializeExParams->dwOptions =
LINEINITIALIZEEXOPTION_USEHIDDENWINDOW;
lpTapiLineTestInfo->lpdwAPIVersion = &lpTapiLineTestInfo->dwAPIVersion;
lpTapiLineTestInfo->dwAPIVersion = TAPI_VERSION2_0;
if(! DoLineInitializeEx (lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
lpTapiLineTestInfo->dwDeviceID =
(*(lpTapiLineTestInfo->lpdwNumDevs) == 0 ?
0 : *(lpTapiLineTestInfo->lpdwNumDevs)-1);
if(IsUNIMDMLineDevice(lpTapiLineTestInfo))
{
TapiLogDetail(
DBUG_SHOW_DETAIL,
"## ProxyMessage: unimodem didn't support");
return fTestPassed;
}
lpTapiLineTestInfo->dwAPIVersion = HIGH_APIVERSION;
lpTapiLineTestInfo->dwExtLowVersion = LOW_APIVERSION;
lpTapiLineTestInfo->dwExtHighVersion = HIGH_APIVERSION;
lpTapiLineTestInfo->lpdwExtVersion = &lpTapiLineTestInfo->dwExtVersion;
//
// Negotiate the API Ext Version
//
if (! DoLineNegotiateExtVersion(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
//
// Open a line
//
lpTapiLineTestInfo->dwMediaModes = LINEMEDIAMODE_DATAMODEM;
lpTapiLineTestInfo->dwPrivileges = LINECALLPRIVILEGE_OWNER |
LINEOPENOPTION_PROXY;
lpTapiLineTestInfo->lpCallParams = (LPLINECALLPARAMS) AllocFromTestHeap (
sizeof(LINECALLPARAMS) + sizeof(DWORD));
lpTapiLineTestInfo->lpCallParams->dwTotalSize =
sizeof(LINECALLPARAMS) + sizeof(DWORD);
lpTapiLineTestInfo->lpCallParams->dwDevSpecificSize =
sizeof(DWORD);
lpTapiLineTestInfo->lpCallParams->dwDevSpecificOffset =
sizeof(LINECALLPARAMS);
lpRequestBuf = (LPDWORD) (((LPBYTE)lpTapiLineTestInfo->lpCallParams) +
lpTapiLineTestInfo->lpCallParams->dwDevSpecificOffset);
*lpRequestBuf = LINEPROXYREQUEST_GETAGENTACTIVITYLIST;
if (! DoLineOpen(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
TapiLogDetail(
DBUG_SHOW_PASS,
"#### Test Case %ld: Bad dwMsg",
dwTestCase+1);
lpTapiLineTestInfo->dwMsg = (DWORD)~LINE_AGENTSTATUS;
lpTapiLineTestInfo->dwParam1 = 0;
lpTapiLineTestInfo->dwParam2 = LINEAGENTSTATUS_ACTIVITY;
lpTapiLineTestInfo->dwParam3 = 0;
if (! DoLineProxyMessage(lpTapiLineTestInfo, LINEERR_INVALPARAM))
{
TLINE_FAIL();
}
fTestPassed = ShowTestCase(fTestPassed);
TapiLogDetail(
DBUG_SHOW_PASS,
"#### Test Case %ld: Bad dwParam1",
dwTestCase+1);
lpTapiLineTestInfo->dwMsg = LINE_AGENTSTATUS;
lpTapiLineTestInfo->dwParam1 = 0xFFFFFFFF;
lpTapiLineTestInfo->dwParam2 = LINEAGENTSTATUS_ACTIVITY;
lpTapiLineTestInfo->dwParam3 = 0;
if (! DoLineProxyMessage(lpTapiLineTestInfo, LINEERR_INVALPARAM))
{
TLINE_FAIL();
}
fTestPassed = ShowTestCase(fTestPassed);
TapiLogDetail(
DBUG_SHOW_PASS,
"#### Test Case %ld: Bad dwParam2",
dwTestCase+1);
lpTapiLineTestInfo->dwMsg = LINE_AGENTSTATUS;
lpTapiLineTestInfo->dwParam1 = 0;
lpTapiLineTestInfo->dwParam2 = (DWORD)~0x1FF;
lpTapiLineTestInfo->dwParam3 = 0;
if (! DoLineProxyMessage(lpTapiLineTestInfo, LINEERR_INVALPARAM))
{
TLINE_FAIL();
}
fTestPassed = ShowTestCase(fTestPassed);
TapiLogDetail(
DBUG_SHOW_PASS,
"#### Test Case %ld: Bad dwParam3",
dwTestCase+1);
lpTapiLineTestInfo->dwMsg = LINE_AGENTSTATUS;
lpTapiLineTestInfo->dwParam1 = 0;
lpTapiLineTestInfo->dwParam2 = LINEAGENTSTATUS_STATE;
lpTapiLineTestInfo->dwParam3 = 0;
if (! DoLineProxyMessage(lpTapiLineTestInfo, LINEERR_INVALPARAM))
{
TLINE_FAIL();
}
fTestPassed = ShowTestCase(fTestPassed);
//
// Close the line
//
if (! DoLineClose(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
//
// Shutdown
//
if (! DoLineShutdown(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
FreeTestHeap();
// ===================================================================
// ===================================================================
//
// 7. Test Case: Open with no proxy request
//
// ===================================================================
// ===================================================================
TapiLineTestInit();
lpTapiLineTestInfo = GetLineTestInfo();
fTestPassed = TRUE;
//
// Initialize a line app
//
lpTapiLineTestInfo->lpLineInitializeExParams =
(LPLINEINITIALIZEEXPARAMS) AllocFromTestHeap (
sizeof(LINEINITIALIZEEXPARAMS));
lpTapiLineTestInfo->lpLineInitializeExParams->dwTotalSize =
sizeof(LINEINITIALIZEEXPARAMS);
lpTapiLineTestInfo->lpLineInitializeExParams->dwOptions =
LINEINITIALIZEEXOPTION_USEHIDDENWINDOW;
lpTapiLineTestInfo->lpdwAPIVersion = &lpTapiLineTestInfo->dwAPIVersion;
lpTapiLineTestInfo->dwAPIVersion = TAPI_VERSION2_0;
if(! DoLineInitializeEx (lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
lpTapiLineTestInfo->dwDeviceID =
(*(lpTapiLineTestInfo->lpdwNumDevs) == 0 ?
0 : *(lpTapiLineTestInfo->lpdwNumDevs)-1);
if(IsUNIMDMLineDevice(lpTapiLineTestInfo))
{
TapiLogDetail(
DBUG_SHOW_DETAIL,
"## ProxyMessage: unimodem didn't support");
return fTestPassed;
}
lpTapiLineTestInfo->dwAPIVersion = HIGH_APIVERSION;
lpTapiLineTestInfo->dwExtLowVersion = LOW_APIVERSION;
lpTapiLineTestInfo->dwExtHighVersion = HIGH_APIVERSION;
lpTapiLineTestInfo->lpdwExtVersion = &lpTapiLineTestInfo->dwExtVersion;
//
// Negotiate the API Ext Version
//
if (! DoLineNegotiateExtVersion(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
//
// Open a line
//
lpTapiLineTestInfo->dwMediaModes = LINEMEDIAMODE_DATAMODEM;
lpTapiLineTestInfo->dwPrivileges = LINECALLPRIVILEGE_OWNER ;//|
// LINEOPENOPTION_PROXY;
lpTapiLineTestInfo->lpCallParams = (LPLINECALLPARAMS) AllocFromTestHeap (
sizeof(LINECALLPARAMS) + sizeof(DWORD));
lpTapiLineTestInfo->lpCallParams->dwTotalSize =
sizeof(LINECALLPARAMS) + sizeof(DWORD);
lpTapiLineTestInfo->lpCallParams->dwDevSpecificSize =
sizeof(DWORD);
lpTapiLineTestInfo->lpCallParams->dwDevSpecificOffset =
sizeof(LINECALLPARAMS);
lpRequestBuf = (LPDWORD) (((LPBYTE)lpTapiLineTestInfo->lpCallParams) +
lpTapiLineTestInfo->lpCallParams->dwDevSpecificOffset);
*lpRequestBuf = LINEPROXYREQUEST_GETAGENTACTIVITYLIST;
if (! DoLineOpen(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
TapiLogDetail(
DBUG_SHOW_PASS,
"#### Test Case %ld: open with no PROXY request",
dwTestCase+1);
lpTapiLineTestInfo->dwMsg = LINE_AGENTSTATUS;
lpTapiLineTestInfo->dwParam1 = 0;
lpTapiLineTestInfo->dwParam2 = LINEAGENTSTATUS_ACTIVITY;
lpTapiLineTestInfo->dwParam3 = 0;
if (! DoLineProxyMessage(lpTapiLineTestInfo, LINEERR_NOTREGISTERED))
{
TLINE_FAIL();
}
fTestPassed = ShowTestCase(fTestPassed);
//
// Close the line
//
if (! DoLineClose(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
//
// Shutdown
//
if (! DoLineShutdown(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
FreeTestHeap();
// ===================================================================
// ===================================================================
//
// 8. Test Case: Bad hCall
//
// ===================================================================
// ===================================================================
TapiLineTestInit();
lpTapiLineTestInfo = GetLineTestInfo();
fTestPassed = TRUE;
//
// Initialize a line app
//
lpTapiLineTestInfo->lpLineInitializeExParams =
(LPLINEINITIALIZEEXPARAMS) AllocFromTestHeap (
sizeof(LINEINITIALIZEEXPARAMS));
lpTapiLineTestInfo->lpLineInitializeExParams->dwTotalSize =
sizeof(LINEINITIALIZEEXPARAMS);
lpTapiLineTestInfo->lpLineInitializeExParams->dwOptions =
LINEINITIALIZEEXOPTION_USEHIDDENWINDOW;
lpTapiLineTestInfo->lpdwAPIVersion = &lpTapiLineTestInfo->dwAPIVersion;
lpTapiLineTestInfo->dwAPIVersion = TAPI_VERSION2_0;
if(! DoLineInitializeEx (lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
lpTapiLineTestInfo->dwDeviceID =
(*(lpTapiLineTestInfo->lpdwNumDevs) == 0 ?
0 : *(lpTapiLineTestInfo->lpdwNumDevs)-1);
if(IsUNIMDMLineDevice(lpTapiLineTestInfo))
{
TapiLogDetail(
DBUG_SHOW_DETAIL,
"## ProxyMessage: unimodem didn't support");
return fTestPassed;
}
lpTapiLineTestInfo->dwAPIVersion = HIGH_APIVERSION;
lpTapiLineTestInfo->dwExtLowVersion = LOW_APIVERSION;
lpTapiLineTestInfo->dwExtHighVersion = HIGH_APIVERSION;
lpTapiLineTestInfo->lpdwExtVersion = &lpTapiLineTestInfo->dwExtVersion;
//
// Negotiate the API Ext Version
//
if (! DoLineNegotiateExtVersion(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
//
// Open a line
//
lpTapiLineTestInfo->dwMediaModes = LINEMEDIAMODE_DATAMODEM;
lpTapiLineTestInfo->dwPrivileges = LINECALLPRIVILEGE_OWNER |
LINEOPENOPTION_PROXY;
lpTapiLineTestInfo->lpCallParams = (LPLINECALLPARAMS) AllocFromTestHeap (
sizeof(LINECALLPARAMS) + sizeof(DWORD));
lpTapiLineTestInfo->lpCallParams->dwTotalSize =
sizeof(LINECALLPARAMS) + sizeof(DWORD);
lpTapiLineTestInfo->lpCallParams->dwDevSpecificSize =
sizeof(DWORD);
lpTapiLineTestInfo->lpCallParams->dwDevSpecificOffset =
sizeof(LINECALLPARAMS);
lpRequestBuf = (LPDWORD) (((LPBYTE)lpTapiLineTestInfo->lpCallParams) +
lpTapiLineTestInfo->lpCallParams->dwDevSpecificOffset);
*lpRequestBuf = LINEPROXYREQUEST_GETAGENTACTIVITYLIST;
if (! DoLineOpen(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
TapiLogDetail(
DBUG_SHOW_PASS,
"#### Test Case %ld: Bad hCall",
dwTestCase+1);
lpTapiLineTestInfo->dwMsg = LINE_AGENTSPECIFIC;
lpTapiLineTestInfo->dwParam1 = 0;
lpTapiLineTestInfo->dwParam2 = 0;
lpTapiLineTestInfo->dwParam3 = 0;
//
// save previous hCall
//
lpTapiLineTestInfo->hCall_Orig = lpTapiLineTestInfo->hCall1;
//
// Test invalid handles
//
for(i = 1; i < NUMINVALIDHANDLES; i++)
{
*lpTapiLineTestInfo->lphCall = (HCALL)gdwInvalidHandles[i];
if (! DoLineProxyMessage(lpTapiLineTestInfo,
LINEERR_INVALCALLHANDLE))
{
TLINE_FAIL();
}
}
//
// Reset hCall
//
lpTapiLineTestInfo->hCall1 = lpTapiLineTestInfo->hCall_Orig;
fTestPassed = ShowTestCase(fTestPassed);
//
// Close the line
//
if (! DoLineClose(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
//
// Shutdown
//
if (! DoLineShutdown(lpTapiLineTestInfo, TAPISUCCESS))
{
TLINE_FAIL();
}
FreeTestHeap();
//
// +----------------------edit above this line-------------------------
//
TapiLogDetail(
DBUG_SHOW_PASS,
"@@ LineProxyMessage: Total Test Case = %ld, Passed = %ld, Failed = %ld",
dwTestCase, dwTestCasePassed, dwTestCaseFailed);
TapiLogDetail(
DBUG_SHOW_PASS,
"@@ Total Test Case = %ld, Passed = %ld, Failed = %ld",
dwglTestCase, dwglTestCasePassed, dwglTestCaseFailed);
TapiLogDetail(
DBUG_SHOW_PASS,
">>>>>>>> End testing LineProxyMessage <<<<<<<<");
if(dwTestCaseFailed > 0)
fTestPassed = FALSE;
return fTestPassed;
}