VirtualBox

Changeset 60169 in vbox for trunk/src/VBox/Main/testcase


Ignore:
Timestamp:
Mar 23, 2016 2:24:23 PM (9 years ago)
Author:
vboxsync
Message:

tstVBoxMultipleVM.cpp:

  • TABS ARE ABSOLUTELY VERBOTEN!!
  • Always space following 'if', 'for', and 'while'.
  • Function line contiunation indentation is on the '('.
  • Doxygen comment (/ xx and / xx */) are always used when document structures members, structures, typedefs, functions, methods and classes, but never inside functions to document stuff like parameters passed in a call or why a call is made.
  • The 'case' statement of a 'switch' are indented so the '{' of the switch and of the case (if necessary) doesn't end up on the same level.
  • Use 'bool' instead of 'BOOL' where possible.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Main/testcase/tstVBoxMultipleVM.cpp

    r60168 r60169  
    4646*   Global Variables & defs                                                                                                         *
    4747*********************************************************************************************************************************/
    48 typedef std::vector<Bstr>       TMachinesList;
    49 static volatile BOOL            g_RunTest = TRUE;
    50 static RTSEMEVENT                       g_PingEevent;
     48typedef std::vector<Bstr>       TMachinesList;
     49static volatile bool            g_RunTest = true;
     50static RTSEMEVENT               g_PingEevent;
    5151static volatile uint64_t        g_Counter = 0;
    52 static RTTEST                           g_hTest;
    53 static Bstr                             tstMachineName = "tstVBoxMultipleVM test multiple VM start/stop";
     52static RTTEST                   g_hTest;
     53static Bstr                     tstMachineName = "tstVBoxMultipleVM test multiple VM start/stop";
    5454
    5555/* Arguments of test thread */
    5656struct TestThreadArgs
    5757{
    58     /* number of machines that should be run simultaneousely */
     58    /** number of machines that should be run simultaneousely */
    5959    uint32_t machinesPackSize;
    60     /* percents of VM Stop operation what should be called */
    61     /* without session unlocking */
     60    /** percents of VM Stop operation what should be called
     61     * without session unlocking */
    6262    uint32_t percentsUnlok;
    63     /* How much time in seconds test will be executed */
    64     uint64_t executionTime;
    65     /* How much machines create for the test */
    66         uint32_t numberMachines;
     63    /** How much time in milliseconds test will be executed */
     64    uint64_t cMsExecutionTime;
     65    /** How much machines create for the test */
     66    uint32_t numberMachines;
    6767};
    6868
     
    211211{
    212212    HRESULT rc;
    213     uint32_t machinesCount = 0;
     213    size_t machinesCount = 0;
    214214    com::SafeIfaceArray<IMachine> machines;
    215215   
     
    217217
    218218    machinesCount = RT_MIN(machines.size(), maxCount);
    219     for (uint32_t i = 0; i < machinesCount; ++i)
     219    for (size_t i = 0; i < machinesCount; ++i)
    220220    {
    221221        // choose random index of machine
    222         uint32_t idx = RTRandU32Ex(0, machines.size() - 1);
     222        uint32_t idx = RTRandU32Ex(0, (uint32_t)machines.size() - 1);
    223223        if (machines[idx])
    224224        {
    225225            Bstr strId;
    226                         Bstr machineName;
     226            Bstr machineName;
    227227            CHECK_ERROR(machines[idx], COMGETTER(Id)(strId.asOutParam()));
    228                         if (SUCCEEDED(rc))
    229                                 CHECK_ERROR(machines[idx], COMGETTER(Name)(machineName.asOutParam()));
    230                         if(SUCCEEDED(rc))
    231                         {
    232                                 if(Utf8Str(machineName).startsWith("umtvm"))
    233                                         listToFill.push_back(strId);
    234                         }
     228            if (SUCCEEDED(rc))
     229                CHECK_ERROR(machines[idx], COMGETTER(Name)(machineName.asOutParam()));
     230            if (SUCCEEDED(rc))
     231            {
     232                if (Utf8Str(machineName).startsWith("umtvm"))
     233                    listToFill.push_back(strId);
     234            }
    235235        }
    236236    }
     
    265265    // start all machines in pack
    266266    for (TMachinesList::iterator it = machinesList.begin();
    267                                         it != machinesList.end() && g_RunTest; ++it)
     267         it != machinesList.end() && g_RunTest;
     268         ++it)
    268269    {
    269270        ComPtr<ISession> session;
     
    278279    // stop all machines in the pack
    279280    for (TMachinesList::iterator it = machinesList.begin();
    280                                         it != machinesList.end() && g_RunTest; ++it)
     281         it != machinesList.end() && g_RunTest;
     282         ++it)
    281283    {
    282284        ComPtr<ISession> session;
     
    296298static Bstr tstMakeMachineName(int i)
    297299{
    298         char szMachineName[32];
    299         RTStrPrintf(szMachineName, sizeof(szMachineName), "umtvm%d", i);
    300         return Bstr(szMachineName);
     300    char szMachineName[32];
     301    RTStrPrintf(szMachineName, sizeof(szMachineName), "umtvm%d", i);
     302    return Bstr(szMachineName);
    301303}
    302304
     
    304306static int tstCreateMachines(IVirtualBox* pVBox)
    305307{
    306         HRESULT rc;
    307         // create machines for the test
    308         for(uint32_t i = 0; i < g_Args.numberMachines; i++)
    309         {
    310                 ComPtr<IMachine> ptrMachine;
    311                 com::SafeArray<BSTR> groups;
    312                
    313                 Bstr machineName(tstMakeMachineName(i));
    314                 /** Default VM settings */
    315                 CHECK_ERROR(pVBox, CreateMachine(NULL,                   /** Settings */
    316                                      machineName.raw(),          /** Name */
    317                                      ComSafeArrayAsInParam(groups), /** Groups */
    318                                      NULL,                          /** OS Type */
    319                                      NULL,                          /** Create flags */
    320                                      ptrMachine.asOutParam()));
     308    HRESULT rc;
     309    // create machines for the test
     310    for (uint32_t i = 0; i < g_Args.numberMachines; i++)
     311    {
     312        ComPtr<IMachine> ptrMachine;
     313        com::SafeArray<BSTR> groups;
     314
     315        Bstr machineName(tstMakeMachineName(i));
     316        /* Default VM settings */
     317        CHECK_ERROR(pVBox, CreateMachine(NULL,                          /* Settings */
     318                                         machineName.raw(),             /* Name */
     319                                         ComSafeArrayAsInParam(groups), /* Groups */
     320                                         NULL,                          /* OS Type */
     321                                         NULL,                          /* Create flags */
     322                                         ptrMachine.asOutParam()));
    321323        if (SUCCEEDED(rc))
    322324        {
     
    325327        }
    326328
    327                 RTSemEventSignal(g_PingEevent);
     329        RTSemEventSignal(g_PingEevent);
    328330        RTThreadSleep(100);
    329         }
    330         return rc;
     331    }
     332    return rc;
    331333}
    332334
     
    334336static int tstClean(IVirtualBox* pVBox, IVirtualBoxClient* pClient)
    335337{
    336         HRESULT rc;
     338    HRESULT rc;
    337339    MachineState_T machineState;
    338340
    339         // stop all machines created for the test
    340         for(uint32_t i = 0; i < g_Args.numberMachines; i++)
    341         {
    342                 ComPtr<IMachine> machine;
    343                 ComPtr<IProgress> progress;
    344                 ComPtr<ISession> session;
    345                 SafeIfaceArray<IMedium> media;
    346                
    347                 Bstr machineName(tstMakeMachineName(i));
    348                
    349                 /** Delete created VM and its files */
     341    // stop all machines created for the test
     342    for (uint32_t i = 0; i < g_Args.numberMachines; i++)
     343    {
     344        ComPtr<IMachine> machine;
     345        ComPtr<IProgress> progress;
     346        ComPtr<ISession> session;
     347        SafeIfaceArray<IMedium> media;
     348
     349        Bstr machineName(tstMakeMachineName(i));
     350
     351        /* Delete created VM and its files */
    350352        CHECK_ERROR(pVBox, FindMachine(machineName.raw(), machine.asOutParam()));
    351353
     
    369371        if (SUCCEEDED(rc))
    370372            RTPrintf("Machine '%ls' deleted.\n", machineName.raw());
    371         }
    372         return rc;
    373 }
    374 
    375 
    376 DECLCALLBACK(int) tstThreadRun(RTTHREAD thread, void *pvUser)
     373    }
     374    return rc;
     375}
     376
     377
     378static DECLCALLBACK(int) tstThreadRun(RTTHREAD thread, void *pvUser)
    377379{
    378380    TestThreadArgs* args = (TestThreadArgs*)pvUser;
     
    388390
    389391        rc = TST_COM_EXPR(ptrVBoxClient.createInprocObject(CLSID_VirtualBoxClient));
    390         if(SUCCEEDED(rc))
     392        if (SUCCEEDED(rc))
    391393            rc = TST_COM_EXPR(ptrVBoxClient->COMGETTER(VirtualBox)(ptrVBox.asOutParam()));
    392394        if (SUCCEEDED(rc))
     
    404406        }
    405407
    406         g_RunTest = FALSE;
     408        g_RunTest = false;
    407409        RTSemEventSignal(g_PingEevent);
    408410        RTThreadSleep(100);
     
    416418
    417419
    418 int ParseArguments(int argc, char **argv, TestThreadArgs* pArgs)
     420static int ParseArguments(int argc, char **argv, TestThreadArgs *pArgs)
    419421{
    420422    RTGETOPTSTATE               GetState;
     
    422424    static const RTGETOPTDEF    s_aOptions[] =
    423425    {
    424     { "--packsize", 'p', RTGETOPT_REQ_UINT32 }, // number of machines to start together
    425     { "--lock", 's', RTGETOPT_REQ_UINT32 }, // percentage of VM sessions closed without Unlok
    426     { "--time", 't', RTGETOPT_REQ_UINT64 }, // required time of load test execution, in seconds
    427         { "--machines" , 'u', RTGETOPT_REQ_UINT64}
     426        { "--packsize", 'p', RTGETOPT_REQ_UINT32 }, // number of machines to start together
     427        { "--lock",      's', RTGETOPT_REQ_UINT32 }, // percentage of VM sessions closed without Unlok
     428        { "--time",      't', RTGETOPT_REQ_UINT64 }, // required time of load test execution, in seconds
     429        { "--machines" , 'u', RTGETOPT_REQ_UINT32 }
    428430    };
    429431    int rc = RTGetOptInit(&GetState, argc, argv, s_aOptions, RT_ELEMENTS(s_aOptions), 1, 0 /*fFlags*/);
    430     AssertRC(rc);
    431     Assert(pArgs != NULL);
     432    AssertRCReturn(rc, rc);
     433    AssertPtr(pArgs);
    432434   
    433435    while ((rc = RTGetOpt(&GetState, &ValueUnion)) != 0)
     
    435437        switch (rc)
    436438        {
    437         case 'p':
    438         {
    439             if (ValueUnion.u32 == 0)
    440             {
    441                 RTPrintf("--packsize should be more then zero\n");
    442                 return VERR_INVALID_PARAMETER;
    443             }
    444                         if(ValueUnion.u32 > 16000)
    445                         {
    446                                 RTPrintf("maximum --packsize value is 16000.\n"
    447                     "That means can use no more then 16000 machines for the test.\n");
    448                                 return VERR_INVALID_PARAMETER;
    449                         }
    450             pArgs->machinesPackSize = ValueUnion.u32;
    451             break;
    452         }
    453         case 's':
    454         {
    455             if (ValueUnion.u32 > 100)
    456             {
    457                 RTPrintf("maximum --lock value is 100.\n"
    458                     "That means 100 percent of sessions should be closed without unlock.\n");
    459                 return VERR_INVALID_PARAMETER;
    460             }
    461             pArgs->percentsUnlok = ValueUnion.u32;
    462             break;
    463         }
    464         case 't':
    465         {
    466             pArgs->executionTime = ValueUnion.u64 * 1000;
    467             break;
    468         }
    469                 case 'u':
    470                 {
    471                         if (ValueUnion.u32 > 16000)
    472             {
    473                 RTPrintf("maximum --machines value is 16000.\n"
    474                     "That means can make no more then 16000 machines for the test.\n");
    475                 return VERR_INVALID_PARAMETER;
    476             }
    477                         if (ValueUnion.u32 < pArgs->machinesPackSize)
    478                         {
    479                                 RTPrintf("--machines value should be larger then --packsize value.\n");
    480                                 return VERR_INVALID_PARAMETER;
    481                         }
    482                         pArgs->numberMachines = ValueUnion.u32;
    483                         break;
    484                 }
    485         default:
    486         {
    487             RTPrintf("Invalid arguments.\n");
    488             return rc;
    489         }
    490                 }
     439            case 'p':
     440                if (ValueUnion.u32 == 0)
     441                {
     442                    RTPrintf("--packsize should be more then zero\n");
     443                    return VERR_INVALID_PARAMETER;
     444                }
     445                if (ValueUnion.u32 > 16000)
     446                {
     447                        RTPrintf("maximum --packsize value is 16000.\n"
     448                                 "That means can use no more then 16000 machines for the test.\n");
     449                        return VERR_INVALID_PARAMETER;
     450                }
     451                pArgs->machinesPackSize = ValueUnion.u32;
     452                break;
     453
     454            case 's':
     455                if (ValueUnion.u32 > 100)
     456                {
     457                    RTPrintf("maximum --lock value is 100.\n"
     458                             "That means 100 percent of sessions should be closed without unlock.\n");
     459                    return VERR_INVALID_PARAMETER;
     460                }
     461                pArgs->percentsUnlok = ValueUnion.u32;
     462                break;
     463
     464            case 't':
     465                pArgs->cMsExecutionTime = ValueUnion.u64 * 1000;
     466                break;
     467
     468            case 'u':
     469                if (ValueUnion.u32 > 16000)
     470                {
     471                    RTPrintf("maximum --machines value is 16000.\n"
     472                             "That means can make no more then 16000 machines for the test.\n");
     473                    return VERR_INVALID_PARAMETER;
     474                }
     475                if (ValueUnion.u32 < pArgs->machinesPackSize)
     476                {
     477                    RTPrintf("--machines value should be larger then --packsize value.\n");
     478                    return VERR_INVALID_PARAMETER;
     479                }
     480                pArgs->numberMachines = ValueUnion.u32;
     481                break;
     482
     483            default:
     484                RTGetOptPrintError(rc, &ValueUnion);
     485                return rc;
     486        }
    491487    }
    492488    return rc;
     
    495491
    496492/**
    497 *   Examples:
    498 *   - tstVBoxClientWatcherLoad --packsize 500 --lock 10 --time 14400 --machines 4000
    499 *               It will create 4000 VMs with names "utmvm0"..."utmvm3999"
    500 *       It will start 500 random VMs together, stop them,
    501 *       without closing their session with probability 10%,
    502 *       will repeat this during 4 hours.
    503 *               After test it will delete all "utmvm..." machines.
    504 *
    505 *   - tstVBoxClientWatcherLoad --packsize 1 --lock 30 --time 3600 --machines 1000
    506 *               It will create 1000 VMs with names "utmvm0"..."utmvm999"
    507 *       It will start random VM - stop them,
    508 *       without closing their session with probability 30%,
    509 *       will repeat this during 30 minutes.
    510 *               After test it will delete all "utmvm..." machines.
    511 */
     493 *
     494 * Examples:
     495 *   - tstVBoxClientWatcherLoad --packsize 500 --lock 10 --time 14400 --machines 4000
     496 *              It will create 4000 VMs with names "utmvm0"..."utmvm3999"
     497 *       It will start 500 random VMs together, stop them,
     498 *       without closing their session with probability 10%,
     499 *       will repeat this during 4 hours.
     500 *              After test it will delete all "utmvm..." machines.
     501 *
     502 *   - tstVBoxClientWatcherLoad --packsize 1 --lock 30 --time 3600 --machines 1000
     503 *              It will create 1000 VMs with names "utmvm0"..."utmvm999"
     504 *       It will start random VM - stop them,
     505 *       without closing their session with probability 30%,
     506 *       will repeat this during 30 minutes.
     507 *              After test it will delete all "utmvm..." machines.
     508 */
    512509int main(int argc, char **argv)
    513510{
     
    516513        return rcExit;
    517514    SUPR3Init(NULL);
    518         com::Initialize();
     515    com::Initialize();
    519516    RTTestBanner(g_hTest);
     517
    520518    RTPrintf("Initializing ...\n");
    521519    int rc = RTSemEventCreate(&g_PingEevent);
     
    524522    g_Args.machinesPackSize = 100;
    525523    g_Args.percentsUnlok = 10;
    526     g_Args.executionTime = 3 * 60 * 1000; // 3 minutes of test execution by default
    527         g_Args.numberMachines = 200;
     524    g_Args.cMsExecutionTime = 3*RT_MS_1MIN;
     525    g_Args.numberMachines = 200;
    528526    rc = ParseArguments(argc, argv, &g_Args);
    529527    if (RT_FAILURE(rc))
    530     {
    531528        return RTTestSkipAndDestroy(g_hTest, "Invalid arguments.\n");
    532     }
    533     RTPrintf("Arguments packSize = %d, percentUnlok = %d, time = %d.\n",
    534         g_Args.machinesPackSize,
    535         g_Args.percentsUnlok,
    536         g_Args.executionTime);
     529
     530    RTPrintf("Arguments packSize = %d, percentUnlok = %d, time = %lld.\n",
     531             g_Args.machinesPackSize, g_Args.percentsUnlok, g_Args.cMsExecutionTime);
    537532               
    538     RTTHREAD Thread;
    539     rc = RTThreadCreate(&Thread, tstThreadRun, (void *)&g_Args,
    540         0, RTTHREADTYPE_DEFAULT, RTTHREADFLAGS_WAITABLE, "tstThreadRun");
    541     AssertRC(rc);
    542    
    543     uint64_t start = RTTimeMilliTS();
    544     while (RTTimeMilliTS() - start < g_Args.executionTime && g_RunTest)
    545     {
    546         // check that test thread didn't hang and call us periodically
    547         // allowed 30 seconds for operation - start or stop VM
    548         rc = RTSemEventWait(g_PingEevent, 3 * 60 * 1000);
    549         if (RT_FAILURE(rc))
    550         {
    551             if (rc == VERR_TIMEOUT)
    552             {
    553                 // seems that test thread hungs - alert
    554                 RTTestFailed(g_hTest, "Test failed - one of operations hunged. VBoxSvc deadlock detected.\n");
    555                                 com::Shutdown();
    556                 return RTTestSummaryAndDestroy(g_hTest);
    557             }
    558             AssertRC(rc);
    559         }
    560     }
    561 
    562     RTPrintf("Finishing...\n");
    563        
    564     // finish test thread
    565     g_RunTest = FALSE;
    566     // wait it for finish
    567     RTThreadWait(Thread, RT_INDEFINITE_WAIT, &rc);
     533    RTTHREAD hThread;
     534    rc = RTThreadCreate(&hThread, tstThreadRun, (void *)&g_Args,
     535                        0, RTTHREADTYPE_DEFAULT, RTTHREADFLAGS_WAITABLE, "tstThreadRun");
     536    if (RT_SUCCESS(rc))
     537    {
     538        AssertRC(rc);
     539
     540        uint64_t msStart = RTTimeMilliTS();
     541        while (RTTimeMilliTS() - msStart < g_Args.cMsExecutionTime && g_RunTest)
     542        {
     543            // check that test thread didn't hang and call us periodically
     544            // allowed 30 seconds for operation - msStart or stop VM
     545            rc = RTSemEventWait(g_PingEevent, 3 * 60 * 1000);
     546            if (RT_FAILURE(rc))
     547            {
     548                if (rc == VERR_TIMEOUT)
     549                {
     550                    // seems that test thread hungs - alert
     551                    RTTestFailed(g_hTest, "Test failed - one of operations hunged. VBoxSvc deadlock detected.\n");
     552                    com::Shutdown();
     553                    return RTTestSummaryAndDestroy(g_hTest);
     554                }
     555                AssertRC(rc);
     556            }
     557        }
     558
     559        RTPrintf("Finishing...\n");
     560
     561        // finish test thread
     562        g_RunTest = false;
     563        // wait it for finish
     564        RTThreadWait(hThread, RT_INDEFINITE_WAIT, &rc);
     565    }
    568566    RTSemEventDestroy(g_PingEevent);
    569567               
    570         com::Shutdown();
     568    com::Shutdown();
    571569    if (RT_FAILURE(rc))
    572     {
    573570        RTTestFailed(g_hTest, "Test failed.\n");
    574         return RTTestSummaryAndDestroy(g_hTest);
    575     }
    576571    else
    577     {
    578572        RTTestPassed(g_hTest, "Test finished.\n");
    579     }
    580573    return RTTestSummaryAndDestroy(g_hTest);
    581574}
     575
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette