Add WORKING_DIRECTORY argument to add_test
This commit is contained in:
parent
7679f9fab0
commit
42de5d02dd
|
@ -74,6 +74,7 @@ bool cmAddTestCommand::HandleNameMode(std::vector<std::string> const& args)
|
||||||
{
|
{
|
||||||
std::string name;
|
std::string name;
|
||||||
std::vector<std::string> configurations;
|
std::vector<std::string> configurations;
|
||||||
|
std::string working_directory;
|
||||||
std::vector<std::string> command;
|
std::vector<std::string> command;
|
||||||
|
|
||||||
// Read the arguments.
|
// Read the arguments.
|
||||||
|
@ -81,6 +82,7 @@ bool cmAddTestCommand::HandleNameMode(std::vector<std::string> const& args)
|
||||||
DoingName,
|
DoingName,
|
||||||
DoingCommand,
|
DoingCommand,
|
||||||
DoingConfigs,
|
DoingConfigs,
|
||||||
|
DoingWorkingDirectory,
|
||||||
DoingNone
|
DoingNone
|
||||||
};
|
};
|
||||||
Doing doing = DoingName;
|
Doing doing = DoingName;
|
||||||
|
@ -104,6 +106,15 @@ bool cmAddTestCommand::HandleNameMode(std::vector<std::string> const& args)
|
||||||
}
|
}
|
||||||
doing = DoingConfigs;
|
doing = DoingConfigs;
|
||||||
}
|
}
|
||||||
|
else if(args[i] == "WORKING_DIRECTORY")
|
||||||
|
{
|
||||||
|
if(!working_directory.empty())
|
||||||
|
{
|
||||||
|
this->SetError(" may be given at most one WORKING_DIRECTORY.");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
doing = DoingWorkingDirectory;
|
||||||
|
}
|
||||||
else if(doing == DoingName)
|
else if(doing == DoingName)
|
||||||
{
|
{
|
||||||
name = args[i];
|
name = args[i];
|
||||||
|
@ -117,6 +128,11 @@ bool cmAddTestCommand::HandleNameMode(std::vector<std::string> const& args)
|
||||||
{
|
{
|
||||||
configurations.push_back(args[i]);
|
configurations.push_back(args[i]);
|
||||||
}
|
}
|
||||||
|
else if(doing == DoingWorkingDirectory)
|
||||||
|
{
|
||||||
|
working_directory = args[i];
|
||||||
|
doing = DoingNone;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
cmOStringStream e;
|
cmOStringStream e;
|
||||||
|
@ -154,6 +170,7 @@ bool cmAddTestCommand::HandleNameMode(std::vector<std::string> const& args)
|
||||||
cmTest* test = this->Makefile->CreateTest(name.c_str());
|
cmTest* test = this->Makefile->CreateTest(name.c_str());
|
||||||
test->SetOldStyle(false);
|
test->SetOldStyle(false);
|
||||||
test->SetCommand(command);
|
test->SetCommand(command);
|
||||||
|
test->SetProperty("WORKING_DIRECTORY", working_directory.c_str());
|
||||||
this->Makefile->AddTestGenerator(new cmTestGenerator(test, configurations));
|
this->Makefile->AddTestGenerator(new cmTestGenerator(test, configurations));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -68,12 +68,15 @@ public:
|
||||||
"in the binary tree.\n"
|
"in the binary tree.\n"
|
||||||
"\n"
|
"\n"
|
||||||
" add_test(NAME <name> [CONFIGURATIONS [Debug|Release|...]]\n"
|
" add_test(NAME <name> [CONFIGURATIONS [Debug|Release|...]]\n"
|
||||||
|
" [WORKING_DIRECTORY dir]\n"
|
||||||
" COMMAND <command> [arg1 [arg2 ...]])\n"
|
" COMMAND <command> [arg1 [arg2 ...]])\n"
|
||||||
"If COMMAND specifies an executable target (created by "
|
"If COMMAND specifies an executable target (created by "
|
||||||
"add_executable) it will automatically be replaced by the location "
|
"add_executable) it will automatically be replaced by the location "
|
||||||
"of the executable created at build time. "
|
"of the executable created at build time. "
|
||||||
"If a CONFIGURATIONS option is given then the test will be executed "
|
"If a CONFIGURATIONS option is given then the test will be executed "
|
||||||
"only when testing under one of the named configurations."
|
"only when testing under one of the named configurations."
|
||||||
|
"If a WORKING_DIRECTORY option is given then the test will be executed "
|
||||||
|
"in the given directory."
|
||||||
"\n"
|
"\n"
|
||||||
"Arguments after COMMAND may use \"generator expressions\" with the "
|
"Arguments after COMMAND may use \"generator expressions\" with the "
|
||||||
"syntax \"$<...>\". "
|
"syntax \"$<...>\". "
|
||||||
|
|
Loading…
Reference in New Issue