tstRTProcCreateEx.cpp revision eb164f7d77f5b3bee0fe6fbdd46521550e3306c4
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * IPRT Testcase - RTProcCreateEx.
e64031e20c39650a7bc902a3e1aba613b9415deevboxsync * Copyright (C) 2010 Oracle Corporation
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * available from http://www.virtualbox.org. This file is free software;
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * you can redistribute it and/or modify it under the terms of the GNU
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * General Public License (GPL) as published by the Free Software
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * The contents of this file may alternatively be used under the terms
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * of the Common Development and Distribution License Version 1.0
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * VirtualBox OSE distribution, in which case the provisions of the
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * CDDL are applicable instead of those of the GPL.
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * You may elect to license modified versions of this file under the
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync * terms and conditions of either the GPL or the CDDL or both.
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync/*******************************************************************************
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync* Header Files *
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync*******************************************************************************/
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync/*******************************************************************************
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync* Global Variables *
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync*******************************************************************************/
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsyncstatic const char * const g_apszArgs4[] =
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsyncstatic int tstRTCreateProcEx5Child(int argc, char **argv)
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync /** @todo Does not yet handle ERROR_MORE_DATA for user names longer than 32767. */
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTPrintf("GetUserName failed with last error=%ld\n", GetLastError());
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync/* Does not work on NT4 (yet). */
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync /* First try to figure out how much space for SID + domain name we need. */
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync BOOL bRet = LookupAccountName(NULL /* current system*/,
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTPrintf("LookupAccountName(1) failed with last error=%ld\n", dwErr);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync /* Now try getting the real SID + domain name. */
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync char *pszDomain = (char *)RTMemAlloc(cbDomain); /* Size in TCHAR! */
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTPrintf("LookupAccountName(2) failed with last error=%ld\n", GetLastError());
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync /** @todo Lookup UID/effective UID, maybe GID? */
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsyncstatic void tstRTCreateProcEx5(const char *pszUser, const char *pszPassword)
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTestISubF("As user \"%s\" with password \"%s\"", pszUser, pszPassword);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync "--testcase-child-5",
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync /* Test for invalid logons. */
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC_RETV(RTProcCreateEx(g_szExecName, apszArgs, RTENV_DEFAULT, 0 /*fFlags*/, NULL,
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync NULL, NULL, "non-existing-user", "wrong-password", &hProc), VERR_AUTHENTICATION_FAILURE);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync /* Test for invalid application. */
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC_RETV(RTProcCreateEx("non-existing-app", apszArgs, RTENV_DEFAULT, 0 /*fFlags*/, NULL,
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync NULL, NULL, NULL, NULL, &hProc), VERR_FILE_NOT_FOUND);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync /* Test a (hopefully) valid user/password logon (given by parameters of this function). */
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC_RETV(RTProcCreateEx(g_szExecName, apszArgs, RTENV_DEFAULT, 0 /*fFlags*/, NULL,
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync NULL, NULL, pszUser, pszPassword, &hProc), VINF_SUCCESS);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTPROCSTATUS ProcStatus = { -1, RTPROCEXITREASON_ABEND };
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC(RTProcWait(hProc, RTPROCWAIT_FLAGS_BLOCK, &ProcStatus), VINF_SUCCESS);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync if (ProcStatus.enmReason != RTPROCEXITREASON_NORMAL || ProcStatus.iStatus != 0)
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTestIFailed("enmReason=%d iStatus=%d", ProcStatus.enmReason, ProcStatus.iStatus);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsyncstatic int tstRTCreateProcEx4Child(int argc, char **argv)
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync for (int i = 0; i < argc; i++)
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync "child4: argv[%2u]='%s'\n"
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync "child4: expected='%s'\n",
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsyncstatic void tstRTCreateProcEx4(void)
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC_RETV(RTProcCreateEx(g_szExecName, g_apszArgs4, RTENV_DEFAULT, 0 /*fFlags*/, NULL,
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTPROCSTATUS ProcStatus = { -1, RTPROCEXITREASON_ABEND };
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC(RTProcWait(hProc, RTPROCWAIT_FLAGS_BLOCK, &ProcStatus), VINF_SUCCESS);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync if (ProcStatus.enmReason != RTPROCEXITREASON_NORMAL || ProcStatus.iStatus != 0)
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTestIFailed("enmReason=%d iStatus=%d", ProcStatus.enmReason, ProcStatus.iStatus);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTStrmPrintf(g_pStdOut, "w"); RTStrmFlush(g_pStdOut);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTStrmPrintf(g_pStdErr, "o"); RTStrmFlush(g_pStdErr);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTStrmPrintf(g_pStdOut, "r"); RTStrmFlush(g_pStdOut);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTStrmPrintf(g_pStdErr, "k"); RTStrmFlush(g_pStdErr);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsyncstatic void tstRTCreateProcEx3(void)
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC_RETV(RTPipeCreate(&hPipeR, &hPipeW, RTPIPE_C_INHERIT_WRITE), VINF_SUCCESS);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync "non-existing-non-executable-file",
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync "--testcase-child-3",
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC_RETV(RTProcCreateEx(g_szExecName, apszArgs, RTENV_DEFAULT, 0 /*fFlags*/, NULL,
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync &Handle, &Handle, NULL, NULL, &hProc), VINF_SUCCESS);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC(RTPipeClose(hPipeW), VINF_SUCCESS);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync int rc = RTPipeReadBlocking(hPipeR, &szOutput[offOutput], cbLeft, &cbRead);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC(RTPipeClose(hPipeR), VINF_SUCCESS);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTPROCSTATUS ProcStatus = { -1, RTPROCEXITREASON_ABEND };
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC(RTProcWait(hProc, RTPROCWAIT_FLAGS_BLOCK, &ProcStatus), VINF_SUCCESS);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync if (ProcStatus.enmReason != RTPROCEXITREASON_NORMAL || ProcStatus.iStatus != 0)
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTestIFailed("enmReason=%d iStatus=%d", ProcStatus.enmReason, ProcStatus.iStatus);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTestIFailed("wrong output: \"%s\" (len=%u)", szOutput, offOutput);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsyncstatic void tstRTCreateProcEx2(void)
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC_RETV(RTPipeCreate(&hPipeR, &hPipeW, RTPIPE_C_INHERIT_WRITE), VINF_SUCCESS);
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync "non-existing-non-executable-file",
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync "--testcase-child-2",
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC_RETV(RTProcCreateEx(g_szExecName, apszArgs, RTENV_DEFAULT, 0 /*fFlags*/, NULL,
3183efc91c7b8252f1dc50dca3efd2d8ae627813vboxsync RTTESTI_CHECK_RC(RTPipeClose(hPipeW), VINF_SUCCESS);
static int tstRTCreateProcEx1Child(void)
if (rc)
static void tstRTCreateProcEx1(void)
if (cbLeft == 0)
return tstRTCreateProcEx1Child();
return tstRTCreateProcEx2Child();
return tstRTCreateProcEx3Child();
if (rc)
return rc;
if (pszAsUser)