Refactored a bit. Extracted the code which checks for
test suite selection to a function.
This commit is contained in:
parent
16254c328a
commit
5379420c8a
1 changed files with 43 additions and 28 deletions
|
@ -315,8 +315,6 @@ ParseOptions(int argc, char *argv[])
|
|||
|
||||
memset(selected_suite_name, 0, NAME_BUFFER_SIZE);
|
||||
strcpy(selected_suite_name, suiteName);
|
||||
|
||||
printf("%s\n", selected_suite_name);
|
||||
}
|
||||
else {
|
||||
printf("runner: unknown command '%s'\n", arg);
|
||||
|
@ -327,6 +325,44 @@ ParseOptions(int argc, char *argv[])
|
|||
}
|
||||
|
||||
|
||||
/*!
|
||||
* Tests if the given test suite is selected for execution.
|
||||
* If only_selected_suite flag is zero, then all the suites are
|
||||
* automatically selected. If the flags is non-zero, only the suite
|
||||
* which matches the selected suite is selected.
|
||||
*
|
||||
* \param testSuiteName Name of the test suite
|
||||
*
|
||||
* \return 1 if given suite is selected, otherwise 0
|
||||
*/
|
||||
int
|
||||
SuiteIsSelected(char *testSuiteName) {
|
||||
int retVal = 1;
|
||||
|
||||
if(only_selected_suite) {
|
||||
// extract the suite name. Rips the tests/ and file suffix from the suite name
|
||||
char buffer[NAME_BUFFER_SIZE];
|
||||
int len = strlen(testSuiteName);
|
||||
|
||||
//! \todo Fix this, it's rather horrible way to do it
|
||||
#define DIR_NAME_LENGTH 6
|
||||
#if defined(linux) || defined( __linux)
|
||||
#define FILE_EXT_LENGTH 3
|
||||
#else
|
||||
#define FILE_EXT_LENGTH 6
|
||||
#endif
|
||||
int length = len - DIR_NAME_LENGTH - FILE_EXT_LENGTH;
|
||||
|
||||
memset(buffer, 0, NAME_BUFFER_SIZE);
|
||||
memcpy(buffer, testSuiteName + 6, length);
|
||||
|
||||
retVal = SDL_strncmp(selected_suite_name, buffer, NAME_BUFFER_SIZE) == 0;
|
||||
}
|
||||
|
||||
return retVal;
|
||||
}
|
||||
|
||||
|
||||
/*!
|
||||
* Entry point for test runner
|
||||
*
|
||||
|
@ -349,28 +385,10 @@ main(int argc, char *argv[])
|
|||
char *testSuiteName = NULL;
|
||||
int suiteCounter = 0;
|
||||
for(testSuiteName = testSuiteNames[suiteCounter]; testSuiteName; testSuiteName = testSuiteNames[++suiteCounter]) {
|
||||
|
||||
if(only_selected_suite) {
|
||||
// extract the suite name. Rips the tests/ and file suffix from the suite name
|
||||
char buffer[NAME_BUFFER_SIZE];
|
||||
int len = strlen(testSuiteName);
|
||||
|
||||
//! \todo Fix this, it's rather horrible way to do it
|
||||
#define DIR_NAME_LENGTH 6
|
||||
#if defined(linux) || defined( __linux)
|
||||
#define FILE_EXT_LENGTH 3
|
||||
#else
|
||||
#define FILE_EXT_LENGTH 6
|
||||
#endif
|
||||
int length = len - DIR_NAME_LENGTH - FILE_EXT_LENGTH;
|
||||
|
||||
memset(buffer, 0, NAME_BUFFER_SIZE);
|
||||
memcpy(buffer, testSuiteName + 6, length);
|
||||
|
||||
if(SDL_strncmp(selected_suite_name, buffer, NAME_BUFFER_SIZE) != 0) {
|
||||
// if the current suite isn't selected, go to next suite
|
||||
if(SuiteIsSelected(testSuiteName) == 0) {
|
||||
continue;
|
||||
}
|
||||
}
|
||||
|
||||
void *suite = LoadTestSuite(testSuiteName);
|
||||
TestCaseReference **tests = QueryTestCases(suite);
|
||||
|
@ -378,12 +396,9 @@ main(int argc, char *argv[])
|
|||
TestCaseReference *reference = NULL;
|
||||
int counter = 0;
|
||||
for(reference = tests[counter]; reference; reference = tests[++counter]) {
|
||||
|
||||
if(only_selected_test) {
|
||||
if(SDL_strncmp(selected_test_name, reference->name, NAME_BUFFER_SIZE) != 0) {
|
||||
if(only_selected_test && SDL_strncmp(selected_test_name, reference->name, NAME_BUFFER_SIZE) != 0) {
|
||||
continue;
|
||||
}
|
||||
}
|
||||
|
||||
if(reference->enabled == TEST_DISABLED) {
|
||||
printf("Test %s (in %s) disabled. Omitting...\n", reference->name, testSuiteName);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue