Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

513 lines
16 KiB

//+------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1993.
//
// File: bmdriver.cxx
//
// Contents: Main module of the benchmark test
//
// Classes: CBenchMarkDriver
//
// Functions: WinMain
//
// History: 30-June-93 t-martig Created
// 07-June-94 t-vadims Added Storage tests
//
//--------------------------------------------------------------------------
#include <benchmrk.hxx>
#include <bmdriver.hxx>
#include <bm_activ.hxx>
#include <bm_alloc.hxx>
#include <bm_api.hxx>
#include <bm_cgps.hxx>
#include <bm_iid.hxx>
#include <bm_init.hxx>
#include <bm_marsh.hxx>
#include <bm_mrsh2.hxx>
#include <bm_noise.hxx>
#include <bm_nest.hxx>
#include <bm_obind.hxx>
#include <bm_props.hxx>
#include <bm_qi.hxx>
#include <bm_regis.hxx>
#include <bm_rot.hxx>
#include <bm_rpc.hxx>
#include <bm_rpc2.hxx>
#include <bm_rrpc.hxx>
#include <bm_sbind.hxx>
#include <bm_filio.hxx>
#include <bm_stg.hxx>
#include <bm_nstg.hxx>
#include <bmp_stg.hxx>
#include "..\cairole\ui\hlp_iocs.hxx"
#include "..\cairole\ui\hlp_ias.hxx"
#include "..\cairole\ui\hlp_site.hxx"
#include "..\cairole\ui\hlp_doc.hxx"
#include "..\cairole\ui\bm_crt.hxx"
#include "..\cairole\ui\bm_crtl.hxx"
//#include "..\cairole\ui\bm_clip.hxx"
#include "..\cairole\ui\bm_load.hxx"
#include "..\cairole\ui\bm_link.hxx"
#include "..\cairole\ui\bm_cache.hxx"
#define REGISTRY_ENTRY_LEN 256
typedef struct
{
const char *key;
const char *value;
} RegistryKeyValue;
const RegistryKeyValue REG_CONST_KEY[] =
{
".bm1", "CLSID\\{99999999-0000-0008-C000-000000000052}",
".bm2", "CLSID\\{99999999-0000-0008-C000-000000000051}",
"CLSID\\{20730701-0001-0008-C000-000000000046}", "OleTestClass",
"CLSID\\{20730711-0001-0008-C000-000000000046}", "OleTestClass1",
"CLSID\\{20730712-0001-0008-C000-000000000046}", "OleTestClass2",
"CLSID\\{20730713-0001-0008-C000-000000000046}", "OleTestClass3",
"CLSID\\{20730714-0001-0008-C000-000000000046}", "OleTestClass4",
"CLSID\\{20730715-0001-0008-C000-000000000046}", "OleTestClass5",
"CLSID\\{20730716-0001-0008-C000-000000000046}", "OleTestClass6",
"CLSID\\{20730717-0001-0008-C000-000000000046}", "OleTestClass7",
"CLSID\\{20730718-0001-0008-C000-000000000046}", "OleTestClass8",
"CLSID\\{00000138-0001-0008-C000-000000000046}", "CPrxyBalls",
"Interface\\{00000138-0001-0008-C000-000000000046}", "IBalls",
"Interface\\{00000139-0001-0008-C000-000000000046}", "ICube",
"Interface\\{00000136-0001-0008-C000-000000000046}", "ILoops",
"Interface\\{00000137-0001-0008-C000-000000000046}", "IRpcTest",
"Interface\\{00000138-0001-0008-C000-000000000046}\\ProxyStubClsid32", "{00000138-0001-0008-C000-000000000046}",
"Interface\\{00000139-0001-0008-C000-000000000046}\\ProxyStubClsid32", "{00000138-0001-0008-C000-000000000046}",
"Interface\\{00000136-0001-0008-C000-000000000046}\\ProxyStubClsid32", "{00000138-0001-0008-C000-000000000046}",
"Interface\\{00000137-0001-0008-C000-000000000046}\\ProxyStubClsid32", "{00000138-0001-0008-C000-000000000046}",
"CLSID\\{0000013a-0001-0008-C000-000000000046}\\ProgID", "ProgID60",
"CLSID\\{0000013a-0001-0008-C000-000000000046}", "CBallsClassFactory",
"CLSID\\{0000013b-0001-0008-C000-000000000046}", "CCubesClassFactory",
"CLSID\\{0000013c-0001-0008-C000-000000000046}", "CLoopClassFactory",
"CLSID\\{0000013d-0001-0008-C000-000000000046}", "CRpcTestClassFactory",
"CLSID\\{00000140-0000-0008-C000-000000000046}", "CQueryInterface",
"CLSID\\{00000142-0000-0008-C000-000000000046}", "Dummy",
".ut4", "ProgID50",
".ut5", "ProgID51",
".ut6", "ProgID52",
".ut7", "ProgID53",
".ut8", "ProgID54",
".ut9", "ProgID55",
".bls", "ProgID60",
"CLSID\\{99999999-0000-0008-C000-000000000050}", "SDI",
"CLSID\\{99999999-0000-0008-C000-000000000051}", "MDI",
"CLSID\\{99999999-0000-0008-C000-000000000052}", "InprocNoRegister",
"CLSID\\{99999999-0000-0008-C000-000000000053}", "InprocRegister",
"CLSID\\{99999999-0000-0008-C000-000000000054}", "InprocRegister",
"CLSID\\{99999999-0000-0008-C000-000000000054}\\TreatAs", "{99999999-0000-0008-C000-000000000050}",
"CLSID\\{99999999-0000-0008-C000-000000000055}", "MDI",
"CLSID\\{99999999-0000-0008-C000-000000000055}\\ActivateAtBits", "Y",
"ProgID50", "objact sdi",
"ProgID50\\CLSID", "{99999999-0000-0008-C000-000000000050}",
"ProgID51", "objact mdi",
"ProgID51\\CLSID", "{99999999-0000-0008-C000-000000000051}",
"ProgID52", "objact dll",
"ProgID52\\CLSID", "{99999999-0000-0008-C000-000000000052}",
"ProgID53", "objact dll reg",
"ProgID53\\CLSID", "{99999999-0000-0008-C000-000000000053}",
"ProgID54", "objact dll reg",
"ProgID54\\CLSID", "{99999999-0000-0008-C000-000000000054}",
"ProgID55", "remote activation",
"ProgID55\\CLSID", "{99999999-0000-0008-C000-000000000055}",
"ProgID60", "CLSIDFromProgID test",
"ProgID60\\CLSID", "{0000013a-0001-0008-C000-000000000046}",
// Indicates end of list.
"", ""
};
const RegistryKeyValue REG_EXE_KEY[] =
{
"CLSID\\{20730701-0001-0008-C000-000000000046}\\InprocServer32", "oletest.dll",
"CLSID\\{20730711-0001-0008-C000-000000000046}\\InprocServer32", "oletest.dll",
"CLSID\\{20730712-0001-0008-C000-000000000046}\\InprocServer32", "oletest.dll",
"CLSID\\{20730713-0001-0008-C000-000000000046}\\InprocServer32", "oletest.dll",
"CLSID\\{20730714-0001-0008-C000-000000000046}\\InprocServer32", "oletest.dll",
"CLSID\\{20730715-0001-0008-C000-000000000046}\\InprocServer32", "oletest.dll",
"CLSID\\{20730716-0001-0008-C000-000000000046}\\InprocServer32", "oletest.dll",
"CLSID\\{20730717-0001-0008-C000-000000000046}\\InprocServer32", "oletest.dll",
"CLSID\\{20730718-0001-0008-C000-000000000046}\\InprocServer32", "oletest.dll",
"CLSID\\{20730712-0001-0008-C000-000000000046}\\LocalServer32", "bmtstsvr.exe",
"CLSID\\{20730701-0001-0008-C000-000000000046}\\LocalServer32", "bmtstsvr.exe",
"CLSID\\{0000013a-0001-0008-C000-000000000046}\\LocalServer32", "ballsrv.exe",
"CLSID\\{00000138-0001-0008-C000-000000000046}\\InprocServer32", "iballs.dll",
"CLSID\\{0000013b-0001-0008-C000-000000000046}\\LocalServer32", "cubesrv.exe",
"CLSID\\{0000013c-0001-0008-C000-000000000046}\\LocalServer32", "loopsrv.exe",
"CLSID\\{0000013d-0001-0008-C000-000000000046}\\LocalServer32", "rpctst.exe",
"CLSID\\{00000140-0000-0008-C000-000000000046}\\LocalServer32", "qisrv.exe",
"CLSID\\{00000140-0000-0008-C000-000000000046}\\InprocServer32", "qisrv.dll",
"CLSID\\{00000142-0000-0008-C000-000000000046}\\InprocServer32", "ballsrv.dll",
"CLSID\\{99999999-0000-0008-C000-000000000050}\\LocalServer32", "sdi.exe",
"CLSID\\{99999999-0000-0008-C000-000000000051}\\LocalServer32", "mdi.exe",
"CLSID\\{99999999-0000-0008-C000-000000000052}\\InprocServer32", "dlltest.dll",
"CLSID\\{99999999-0000-0008-C000-000000000053}\\InprocServer32", "dlltest.dll",
"CLSID\\{99999999-0000-0008-C000-000000000055}\\LocalServer32", "db.exe",
// Indicates end of list.
"", ""
};
DWORD g_fFullInfo = 0; // write full info or not
DWORD g_dwPauseBetweenTests = 0; // time delay between running tests
//+-------------------------------------------------------------------
//
// Member: CBenchMarkDriver::RunTest, public
//
// Synopsis: Sets up, runs, reports and cleans up test procedure
// of specified class
//
// Parameters: [output] Output class for results
// [pTest] Test object
//
// History: 30-June-93 t-martig Created
//
//--------------------------------------------------------------------
SCODE CBenchMarkDriver::RunTest (CTestInput &input,
CTestOutput &output, CTestBase *pTest)
{
TCHAR szConfigString[80];
SCODE sc;
input.GetConfigString (TEXT("Tests"), pTest->Name(),
TEXT("OFF"), szConfigString, 80);
if (lstrcmpi (szConfigString, TEXT("OFF")) != 0 &&
lstrcmpi (szConfigString, TEXT("FALSE")) != 0)
{
LogSection (pTest->Name());
sc=pTest->Setup(&input);
if (FAILED(sc))
return sc;
// pause between test invocations
Sleep(g_dwPauseBetweenTests);
sc = pTest->Run();
pTest->Report(output);
pTest->Cleanup();
if (FAILED(sc))
{
output.WriteString (TEXT("\nStatus:\tERROR, see log file\n"));
}
// pause between test invocations
Sleep(g_dwPauseBetweenTests);
}
return sc;
}
//+-------------------------------------------------------------------
//
// Member: CBenchMarkDriver::WriteHeader, public
//
// Synopsis: Prints test form header into output file
//
// History: 5-August-93 t-martig Created
//
//--------------------------------------------------------------------
void CBenchMarkDriver::WriteHeader (CTestInput &input, CTestOutput &output)
{
_SYSTEMTIME stTimeDate;
output.WriteString (TEXT("CairOLE Benchmarks\n"));
output.WriteConfigEntry (input, TEXT("Driver"), TEXT("Tester"), TEXT(""));
GetLocalTime (&stTimeDate);
output.WriteDate (&stTimeDate);
output.WriteString (TEXT("\t"));
output.WriteTime (&stTimeDate);
output.WriteString (TEXT("\n\n"));
}
//+-------------------------------------------------------------------
//
// Member: CBenchMarkDriver::Run, public
//
// Synopsis: Runs all tests specified in .ini file
//
// History: 30-June-93 t-martig Created
//
//--------------------------------------------------------------------
#define RUN_TEST(CMyTestClass) \
{ \
CTestBase *pTest; \
pTest = new CMyTestClass; \
RunTest (input, output, pTest); \
delete pTest; \
output.Flush(); \
}
SCODE CBenchMarkDriver::Run (LPSTR lpCmdLine)
{
TCHAR szBenchMarkIniFile[MAX_PATH];
TCHAR szOutputFileName[MAX_PATH];
TCHAR szLogFileName[MAX_PATH];
TCHAR szTemp[MAX_PATH];
// Get file name of .ini file. if not specified in the command
// line, use the default BM.INI in the local directory
GetCurrentDirectory (MAX_PATH, szTemp);
lstrcpy(szBenchMarkIniFile, szTemp);
lstrcat (szBenchMarkIniFile, TEXT("\\BM.INI"));
// create the names for the temporary files. uses pid.xxx. Its the
// current directory appended with the pid and a file extension.
OLECHAR szPid[9];
DWORD pid = GetCurrentProcessId();
CHAR aszPid[9];
_itoa(pid, aszPid, 16);
mbstowcs(szPid, aszPid, strlen(aszPid)+1);
#ifdef UNICODE
wcscpy(aszPerstName[0], szTemp);
#else
mbstowcs(aszPerstName[0], szTemp, strlen(szTemp)+1);
#endif
wcscat(aszPerstName[0], L"\\");
wcscat(aszPerstName[0], szPid);
wcscpy(aszPerstName[1], aszPerstName[0]);
wcscpy(aszPerstNameNew[0], aszPerstName[0]);
wcscpy(aszPerstNameNew[1], aszPerstName[0]);
wcscat(aszPerstName[0], L".BM1");
wcscat(aszPerstNameNew[0], L"NEW.BM1");
wcscat(aszPerstName[1], L".BM2");
wcscat(aszPerstNameNew[1], L"NEW.BM2");
// Define input, output and log file
CTestInput input (szBenchMarkIniFile);
CTestOutput output (input.GetConfigString (TEXT("Driver"), TEXT("Report"),
TEXT("BM.RES"), szOutputFileName, MAX_PATH));
CTestOutput log (input.GetConfigString (TEXT("Driver"), TEXT("Log"),
TEXT("BM.LOG"), szLogFileName, MAX_PATH));
LogTo (&log);
// Get the pause time between test invocations
g_dwPauseBetweenTests = input.GetConfigInt (TEXT("Driver"),
TEXT("PauseBetweenTests"),
2000);
// Get global info level flag
g_fFullInfo = input.GetInfoLevelFlag();
// Write the correct OleInitialize flag to win.ini for the various
// OLE servers to use, based on the init flag in bm.ini.
LPTSTR pszOleInit;
#ifdef THREADING_SUPPORT
if (input.GetOleInitFlag() == COINIT_MULTITHREADED)
{
// pszOleInit = TEXT("MultiThreaded");
}
else
#endif
{
// pszOleInit = TEXT("ApartmentThreaded");
}
// WriteProfileString(TEXT("TestSrv"), TEXT("ThreadMode"), pszOleInit);
// WriteProfileString(TEXT("OleSrv"), TEXT("ThreadMode"), pszOleInit);
// Write header and configuration info
WriteHeader (input, output);
ReportBMConfig (input, output);
// Run all the tests
// To add tests, use macro RUN_TEST, the parameter is the name of
// the test class. Be sure to include a sction called [<TestClass>] in
// the BM.INI file, as well as a switch under the [Tests] section
// (<TestClass> = ON, e.g.)
Sleep(1000);
RUN_TEST (COleMarshalTest2);
RUN_TEST (CNoiseTest);
RUN_TEST (CRawRpc); // NOTE: must come before any OLE tests
RUN_TEST (COleInitializeTest);
RUN_TEST (COleRegistrationTest);
RUN_TEST (COleActivationTest);
RUN_TEST (CFileMonikerStorageBindTest);
RUN_TEST (CFileMonikerObjBindTest);
RUN_TEST (CROTTest);
RUN_TEST (COlePropertyTest);
RUN_TEST (COleMarshalTest);
RUN_TEST (CRpcTest);
RUN_TEST (CRpcTest2);
RUN_TEST (CNestTest);
RUN_TEST (CQueryInterfaceTest);
RUN_TEST (CApiTest);
RUN_TEST (CCGPSTest);
RUN_TEST (COleAllocTest);
RUN_TEST (CGuidCompareTest);
RUN_TEST (CFileIOTest);
RUN_TEST (CStorageTest);
RUN_TEST (CNestedStorageTest);
RUN_TEST (CStorageParserTest);
//Upper layer tests
RUN_TEST (CCreateTest);
RUN_TEST (CCreateLinkTest);
// RUN_TEST (CClipbrdTest);
RUN_TEST (COleLoadTest);
RUN_TEST (CIOLTest);
RUN_TEST (COleCacheTest);
return S_OK;
}
//+-------------------------------------------------------------------
//
// Function: RegistrySetup
//
// Synopsis: If the registry entries for this program are not set,
// write them
//
// Note: This function uses all Ascii characters and character
// arithmatic because it has to run on NT and Chicago.
//
// History: 16 Dec 94 AlexMit Created
//
//--------------------------------------------------------------------
BOOL RegistrySetup()
{
char value[REGISTRY_ENTRY_LEN];
LONG value_size;
LONG result;
char directory[MAX_PATH];
char *appname;
BOOL success = FALSE;
// Write constant entries.
for (int i = 0; REG_CONST_KEY[i].key[0] != '\0'; i++)
{
result = RegSetValueA(
HKEY_CLASSES_ROOT,
REG_CONST_KEY[i].key,
REG_SZ,
REG_CONST_KEY[i].value,
strlen(REG_CONST_KEY[i].value) );
if (result != ERROR_SUCCESS)
goto cleanup;
}
// Compute the path to the application.
result = GetFullPathNameA("benchmrk", sizeof(directory), directory, &appname);
if (result == 0)
goto cleanup;
// Add the path to all the dll and exe entries.
for (i = 0; REG_EXE_KEY[i].key[0] != '\0'; i++)
{
// Verify that the path will fit in the buffer and compute the path
// to the next executable.
if (strlen(REG_EXE_KEY[i].value) >=
(ULONG)(MAX_PATH - (appname - directory)))
goto cleanup;
strcpy(appname, REG_EXE_KEY[i].value);
// Write the next entry.
result = RegSetValueA(
HKEY_CLASSES_ROOT,
REG_EXE_KEY[i].key,
REG_SZ,
directory,
strlen(directory));
if (result != ERROR_SUCCESS)
goto cleanup;
}
success = TRUE;
cleanup:
return success;
}
//+-------------------------------------------------------------------
//
// Function: WinMain
//
// Synopsis: Program entry point, starts benchmark driver
//
// History: 30-June-93 t-martig Created
//
//--------------------------------------------------------------------
int APIENTRY WinMain(
HINSTANCE hInstance,
HINSTANCE hPrevInstance,
LPSTR lpCmdLine,
int nCmdShow)
{
CBenchMarkDriver driver;
if (!_stricmp(lpCmdLine, "/r") || !_stricmp(lpCmdLine, "-r"))
{
if (!RegistrySetup())
{
printf("Registry Updated\n");
return 0;
}
else
{
printf("Registry Update Failed\n");
return 1;
}
}
driver.Run (lpCmdLine);
return 0;
}