summaryrefslogtreecommitdiffstats
path: root/Source/cmaketest.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmaketest.cxx')
-rw-r--r--Source/cmaketest.cxx33
1 files changed, 27 insertions, 6 deletions
diff --git a/Source/cmaketest.cxx b/Source/cmaketest.cxx
index aca0f93..152d601 100644
--- a/Source/cmaketest.cxx
+++ b/Source/cmaketest.cxx
@@ -170,6 +170,11 @@ int do_cmaketest (int argc, char **argv)
{
std::cerr << "Error: cmaketest does not have a valid MAKEPROGRAM\n";
}
+
+ // Return value for run command;
+ int retVal = 0;
+ int ret = 0;
+
makeCommand = cmSystemTools::ConvertToOutputPath(makeCommand.c_str());
std::string lowerCaseCommand = cmSystemTools::LowerCase(makeCommand);
// if msdev is the make program then do the following
@@ -212,12 +217,14 @@ int do_cmaketest (int argc, char **argv)
std::string cleanCommand = makeCommand;
cleanCommand += " clean";
std::cout << "Running make clean command: " << cleanCommand.c_str() << " ...\n";
- if (!cmSystemTools::RunCommand(cleanCommand.c_str(), output))
+ retVal = 0;
+ if (!cmSystemTools::RunCommand(cleanCommand.c_str(), output, retVal) || retVal)
{
std::cerr << "Error: " << cleanCommand.c_str() << " execution failed\n";
std::cerr << output.c_str() << "\n";
// return to the original directory
cmSystemTools::ChangeDirectory(cwd.c_str());
+ std::cerr << "Return value: " << retVal << std::endl;
return 1;
}
@@ -225,7 +232,8 @@ int do_cmaketest (int argc, char **argv)
}
std::cout << "Running make command: " << makeCommand.c_str() << " ...\n";
- if (!cmSystemTools::RunCommand(makeCommand.c_str(), output))
+ retVal = 0;
+ if (!cmSystemTools::RunCommand(makeCommand.c_str(), output, retVal))
{
std::cerr << "Error: " << makeCommand.c_str() << " execution failed\n";
std::cerr << output.c_str() << "\n";
@@ -233,6 +241,14 @@ int do_cmaketest (int argc, char **argv)
cmSystemTools::ChangeDirectory(cwd.c_str());
return 1;
}
+ if ( retVal )
+ {
+ cmSystemTools::Error("Building of project failed\n");
+ std::cerr << output.c_str() << "\n";
+ // return to the original directory
+ cmSystemTools::ChangeDirectory(cwd.c_str());
+ ret = 1;
+ }
// now run the compiled test if we can find it
// See if the executable exists as written.
@@ -293,21 +309,26 @@ int do_cmaketest (int argc, char **argv)
fullPath += *p;
}
std::cout << "Running test executable: " << fullPath.c_str() << "\n";
- int ret = 0;
- if (!cmSystemTools::RunCommand(fullPath.c_str(), output, ret, 0, true))
+ retVal = 0;
+ if (!cmSystemTools::RunCommand(fullPath.c_str(), output, retVal, 0, true))
{
std::cerr << "Error: " << fullPath.c_str() << " execution failed\n";
// return to the original directory
cmSystemTools::ChangeDirectory(cwd.c_str());
return 1;
- }
+ }
std::cout << output << "\n";
// return to the original directory
cmSystemTools::ChangeDirectory(cwd.c_str());
- if(ret)
+ if(retVal)
{
cmSystemTools::Error("test executable ", fullPath.c_str(),
"returned a non-zero value");
+ ret = 1;
+ }
+ if ( ret )
+ {
+ cmSystemTools::Error("Test failed");
}
return ret;
}