blob: 9ef0cfc6cadc1d342290f4912a0e82e71d4cb0e5 [file] [log] [blame]
/************************************************************************
*
* rw_process.h - declarations of testsuite process helpers
*
* $Id$
*
************************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
* implied. See the License for the specific language governing
* permissions and limitations under the License.
*
**************************************************************************/
#ifndef RW_PROCESS_H_INCLUDED
#define RW_PROCESS_H_INCLUDED
#include <testdefs.h>
typedef _RWSTD_SSIZE_T rw_pid_t;
_TEST_EXPORT int
rw_system (const char*, ...);
// returns pid of the created process or -1 on error
// (in which case errno is set to an appropriate value)
_TEST_EXPORT rw_pid_t
rw_process_create (const char*, ...);
// note: argv[0] should be equal to path
// returns pid of the created process or -1 on error
// (in which case errno is set to an appropriate value)
_TEST_EXPORT rw_pid_t
rw_process_create (const char* /*path*/, char* const /*argv*/[]);
// result is a pointer to a buffer where the result code
// of the specified process will be stored, or NULL
//
// the function suspends execution of the current process
// until a child has exited or specified timeout is reached
//
// returns:
// pid of the specified process if it has exited
// 0 when process still active
// -1 on error (in which case errno is set to an appropriate value)
//
// timeout is timeout interval in seconds.
// if timeout > 0 the function returns if the interval elapses
// if timeout == 0 the function returns immediately
// if timeout < 0 the function's time-out interval never elapses
//
// errors:
// ECHILD: no specified process exists
_TEST_EXPORT rw_pid_t
rw_waitpid (rw_pid_t /*pid*/, int* /*result*/, int /*timeout*/ = -1);
// returns:
// 0 when process terminated successfully
// 1 when signal was sent to the child process, but child process
// not terminated within 1 second interval
// -1 on error (in which case errno is set to an appropriate value)
// errors:
// ESRCH: the pid does not exist
// EPERM: the calling process does not have permission
// to terminate the specified process
_TEST_EXPORT int
rw_process_kill (rw_pid_t, int = -1);
#endif // RW_PROCESS_H_INCLUDED