mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Require a remote command to exit with the exit status of the test program or with 255 if an error occurred.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@76323 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b1f61e24d1
commit
fc2271f3f5
@ -46,8 +46,8 @@ namespace {
|
||||
|
||||
ToolExecutionError::~ToolExecutionError() throw() { }
|
||||
|
||||
/// RunProgramWithTimeout - This function provides an alternate interface to the
|
||||
/// sys::Program::ExecuteAndWait interface.
|
||||
/// RunProgramWithTimeout - This function provides an alternate interface
|
||||
/// to the sys::Program::ExecuteAndWait interface.
|
||||
/// @see sys:Program::ExecuteAndWait
|
||||
static int RunProgramWithTimeout(const sys::Path &ProgramPath,
|
||||
const char **Args,
|
||||
@ -61,19 +61,73 @@ static int RunProgramWithTimeout(const sys::Path &ProgramPath,
|
||||
redirects[1] = &StdOutFile;
|
||||
redirects[2] = &StdErrFile;
|
||||
|
||||
if (0) {
|
||||
#if 0 // For debug purposes
|
||||
{
|
||||
errs() << "RUN:";
|
||||
for (unsigned i = 0; Args[i]; ++i)
|
||||
errs() << " " << Args[i];
|
||||
errs() << "\n";
|
||||
}
|
||||
#endif
|
||||
|
||||
return
|
||||
sys::Program::ExecuteAndWait(ProgramPath, Args, 0, redirects,
|
||||
NumSeconds, MemoryLimit);
|
||||
}
|
||||
|
||||
/// RunProgramRemotelyWithTimeout - This function runs the given program
|
||||
/// remotely using the given remote client and the sys::Program::ExecuteAndWait.
|
||||
/// Returns the remote program exit code or reports a remote client error if it
|
||||
/// fails. Remote client is required to return 255 if it failed or program exit
|
||||
/// code otherwise.
|
||||
/// @see sys:Program::ExecuteAndWait
|
||||
static int RunProgramRemotelyWithTimeout(const sys::Path &RemoteClientPath,
|
||||
const char **Args,
|
||||
const sys::Path &StdInFile,
|
||||
const sys::Path &StdOutFile,
|
||||
const sys::Path &StdErrFile,
|
||||
unsigned NumSeconds = 0,
|
||||
unsigned MemoryLimit = 0) {
|
||||
const sys::Path* redirects[3];
|
||||
redirects[0] = &StdInFile;
|
||||
redirects[1] = &StdOutFile;
|
||||
redirects[2] = &StdErrFile;
|
||||
|
||||
#if 0 // For debug purposes
|
||||
{
|
||||
errs() << "RUN:";
|
||||
for (unsigned i = 0; Args[i]; ++i)
|
||||
errs() << " " << Args[i];
|
||||
errs() << "\n";
|
||||
}
|
||||
#endif
|
||||
|
||||
// Run the program remotely with the remote client
|
||||
int ReturnCode = sys::Program::ExecuteAndWait(RemoteClientPath, Args,
|
||||
0, redirects, NumSeconds, MemoryLimit);
|
||||
|
||||
// Has the remote client fail?
|
||||
if (255 == ReturnCode) {
|
||||
std::ostringstream OS;
|
||||
OS << "\nError running remote client:\n ";
|
||||
for (const char **Arg = Args; *Arg; ++Arg)
|
||||
OS << " " << *Arg;
|
||||
OS << "\n";
|
||||
|
||||
// The error message is in the output file, let's print it out from there.
|
||||
std::ifstream ErrorFile(StdOutFile.c_str());
|
||||
if (ErrorFile) {
|
||||
std::copy(std::istreambuf_iterator<char>(ErrorFile),
|
||||
std::istreambuf_iterator<char>(),
|
||||
std::ostreambuf_iterator<char>(OS));
|
||||
ErrorFile.close();
|
||||
}
|
||||
|
||||
throw ToolExecutionError(OS.str());
|
||||
}
|
||||
|
||||
return ReturnCode;
|
||||
}
|
||||
|
||||
static void ProcessFailure(sys::Path ProgPath, const char** Args) {
|
||||
std::ostringstream OS;
|
||||
@ -680,18 +734,12 @@ int GCC::ExecuteProgram(const std::string &ProgramFile,
|
||||
Timeout, MemoryLimit);
|
||||
} else {
|
||||
outs() << "<run remotely>"; outs().flush();
|
||||
int RemoteClientStatus = RunProgramWithTimeout(sys::Path(RemoteClientPath),
|
||||
return RunProgramRemotelyWithTimeout(sys::Path(RemoteClientPath),
|
||||
&ProgramArgs[0], sys::Path(InputFile), sys::Path(OutputFile),
|
||||
sys::Path(OutputFile), Timeout, MemoryLimit);
|
||||
if (RemoteClientStatus != 0) {
|
||||
errs() << "Remote Client failed with an error: " <<
|
||||
RemoteClientStatus << ".\n";
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int GCC::MakeSharedObject(const std::string &InputFile, FileType fileType,
|
||||
std::string &OutputFile,
|
||||
const std::vector<std::string> &ArgsForGCC) {
|
||||
|
@ -2,11 +2,9 @@
|
||||
#
|
||||
# Program: RemoteRunSafely.sh
|
||||
#
|
||||
# Synopsis: This script simply runs another program remotely using rsh.
|
||||
# It always returns the another program exit code.
|
||||
#
|
||||
# (?) only exit statuses that indicates that the program could not be executed
|
||||
# normally is considered to indicate a test failure.
|
||||
# Synopsis: This script simply runs another program remotely using ssh.
|
||||
# It always returns the another program exit code or exit with
|
||||
# code 255 which indicates that the program could not be executed.
|
||||
#
|
||||
# Syntax:
|
||||
#
|
||||
@ -25,8 +23,8 @@ printUsageAndExit()
|
||||
{
|
||||
echo "Usage:"
|
||||
echo "./RemoteRunSafely.sh <hostname> [-l <login_name>] [-p <port>] " \
|
||||
"[cd <working_dir>] <program> <args...>"
|
||||
exit 1
|
||||
"<program> <args...>"
|
||||
exit 255
|
||||
}
|
||||
|
||||
moreArgsExpected()
|
||||
@ -88,7 +86,7 @@ fi
|
||||
local_program=$WORKING_DIR"/"$PROGRAM
|
||||
if [ ! -x "$local_program" ]; then
|
||||
echo "File "$local_program" does not exist or is not an executable.."
|
||||
exit 2
|
||||
exit 255
|
||||
fi
|
||||
|
||||
connection=$RUSER'@'$RHOST
|
||||
@ -98,11 +96,10 @@ remote="./"$PROGRAM
|
||||
$RCLIENT $connection $RPORT \
|
||||
'rm -f '$remote' ; ' \
|
||||
'cat > '$remote' ; chmod +x '$remote' ; '$remote' '$*' ; ' \
|
||||
'echo exit $? ; ' \
|
||||
'rm -f '$remote
|
||||
'err=$? ; rm -f '$remote' ; exit $err'
|
||||
)
|
||||
err=$?
|
||||
|
||||
#DEBUG: err=$?
|
||||
#DEBUG: echo script exit $err
|
||||
#DEBUG: exit $err
|
||||
exit $err
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user