Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
libSDL
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PocketInsanity
libSDL
Commits
d4b779a1
Commit
d4b779a1
authored
Jun 05, 2011
by
Markus Kauppila
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Possible to execute only selected tests or suites.
parent
8e99f21e
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
59 additions
and
5 deletions
+59
-5
runner.c
test/test-automation/runner.c
+59
-5
No files found.
test/test-automation/runner.c
View file @
d4b779a1
...
@@ -23,6 +23,8 @@
...
@@ -23,6 +23,8 @@
#include <stdio.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdlib.h>
#include <unistd.h>
#include <unistd.h>
#include <string.h>
#include <sys/types.h>
#include <sys/types.h>
#include "SDL_test.h"
#include "SDL_test.h"
...
@@ -37,6 +39,17 @@ typedef int (*TestCaseQuit)(void);
...
@@ -37,6 +39,17 @@ typedef int (*TestCaseQuit)(void);
//!< Flag for executing tests in-process
//!< Flag for executing tests in-process
static
int
execute_inproc
=
0
;
static
int
execute_inproc
=
0
;
//!< Flag for executing only test with selected name
static
int
only_selected_test
=
0
;
//!< Flag for executing only the selected test suite
static
int
only_selected_suite
=
0
;
//<! Size of the test and suite name buffers
#define NAME_BUFFER_SIZE 256
//!< Name of the selected test
char
selected_test_name
[
NAME_BUFFER_SIZE
];
//!< Name of the selected suite
char
selected_suite_name
[
NAME_BUFFER_SIZE
];
//!< Temporary array to hold test suite names
//!< Temporary array to hold test suite names
#if defined(linux) || defined( __linux)
#if defined(linux) || defined( __linux)
...
@@ -81,6 +94,7 @@ LoadTestSuite(char *testSuiteName)
...
@@ -81,6 +94,7 @@ LoadTestSuite(char *testSuiteName)
return
library
;
return
library
;
}
}
/*!
/*!
* Loads the test case references from the given test suite.
* Loads the test case references from the given test suite.
...
@@ -128,6 +142,7 @@ LoadTestCase(void *suite, char *testName)
...
@@ -128,6 +142,7 @@ LoadTestCase(void *suite, char *testName)
return
test
;
return
test
;
}
}
/*!
/*!
* Loads function that initialises the test case from the
* Loads function that initialises the test case from the
* given test suite.
* given test suite.
...
@@ -147,6 +162,7 @@ LoadTestCaseInit(void *suite) {
...
@@ -147,6 +162,7 @@ LoadTestCaseInit(void *suite) {
return
testCaseInit
;
return
testCaseInit
;
}
}
/*!
/*!
* Loads function that deinitialises the executed test case from the
* Loads function that deinitialises the executed test case from the
* given test suite.
* given test suite.
...
@@ -166,6 +182,7 @@ LoadTestCaseQuit(void *suite) {
...
@@ -166,6 +182,7 @@ LoadTestCaseQuit(void *suite) {
return
testCaseQuit
;
return
testCaseQuit
;
}
}
/*!
/*!
* If using out-of-proc execution of tests. This function
* If using out-of-proc execution of tests. This function
* will handle the return value of the child process
* will handle the return value of the child process
...
@@ -193,6 +210,7 @@ HandleTestReturnValue(int stat_lock)
...
@@ -193,6 +210,7 @@ HandleTestReturnValue(int stat_lock)
return
returnValue
;
return
returnValue
;
}
}
/*!
/*!
* Executes a test case. Loads the test, executes it and
* Executes a test case. Loads the test, executes it and
* returns the tests return value to the caller.
* returns the tests return value to the caller.
...
@@ -203,11 +221,9 @@ HandleTestReturnValue(int stat_lock)
...
@@ -203,11 +221,9 @@ HandleTestReturnValue(int stat_lock)
*/
*/
int
int
ExecuteTest
(
void
*
suite
,
TestCaseReference
*
testReference
)
{
ExecuteTest
(
void
*
suite
,
TestCaseReference
*
testReference
)
{
char
*
testname
=
testReference
->
name
;
TestCaseInit
testCaseInit
=
LoadTestCaseInit
(
suite
);
TestCaseInit
testCaseInit
=
LoadTestCaseInit
(
suite
);
TestCaseQuit
testCaseQuit
=
LoadTestCaseQuit
(
suite
);
TestCaseQuit
testCaseQuit
=
LoadTestCaseQuit
(
suite
);
TestCase
test
=
(
TestCase
)
LoadTestCase
(
suite
,
testname
);
TestCase
test
=
(
TestCase
)
LoadTestCase
(
suite
,
test
Reference
->
name
);
int
retVal
=
1
;
int
retVal
=
1
;
if
(
execute_inproc
)
{
if
(
execute_inproc
)
{
...
@@ -246,6 +262,7 @@ void printUsage() {
...
@@ -246,6 +262,7 @@ void printUsage() {
printf
(
" --help Print this help
\n
"
);
printf
(
" --help Print this help
\n
"
);
}
}
/*!
/*!
* Parse command line arguments
* Parse command line arguments
*
*
...
@@ -265,7 +282,22 @@ ParseOptions(int argc, char *argv[])
...
@@ -265,7 +282,22 @@ ParseOptions(int argc, char *argv[])
else
if
(
SDL_strcmp
(
arg
,
"--help"
)
==
0
||
SDL_strcmp
(
arg
,
"-h"
)
==
0
)
{
else
if
(
SDL_strcmp
(
arg
,
"--help"
)
==
0
||
SDL_strcmp
(
arg
,
"-h"
)
==
0
)
{
printUsage
();
printUsage
();
exit
(
0
);
exit
(
0
);
}
else
{
}
else
if
(
SDL_strcmp
(
arg
,
"--test"
)
==
0
||
SDL_strcmp
(
arg
,
"-t"
)
==
0
)
{
only_selected_test
=
1
;
char
*
testName
=
argv
[
++
i
];
//!< \todo fixme what if i == argc? segfault?
memset
(
selected_test_name
,
0
,
NAME_BUFFER_SIZE
);
// unnecessary?
strcpy
(
selected_test_name
,
testName
);
}
else
if
(
SDL_strcmp
(
arg
,
"--suite"
)
==
0
||
SDL_strcmp
(
arg
,
"-s"
)
==
0
)
{
only_selected_suite
=
1
;
char
*
suiteName
=
argv
[
++
i
];
//!< \todo fixme what if i == argc? segfault?
memset
(
selected_suite_name
,
0
,
NAME_BUFFER_SIZE
);
// unnecessary?
strcpy
(
selected_suite_name
,
suiteName
);
}
else
{
printf
(
"runner: unknown command '%s'
\n
"
,
arg
);
printf
(
"runner: unknown command '%s'
\n
"
,
arg
);
printUsage
();
printUsage
();
exit
(
0
);
exit
(
0
);
...
@@ -273,6 +305,7 @@ ParseOptions(int argc, char *argv[])
...
@@ -273,6 +305,7 @@ ParseOptions(int argc, char *argv[])
}
}
}
}
/*!
/*!
* Entry point for test runner
* Entry point for test runner
*
*
...
@@ -295,13 +328,34 @@ main(int argc, char *argv[])
...
@@ -295,13 +328,34 @@ main(int argc, char *argv[])
char
*
testSuiteName
=
NULL
;
char
*
testSuiteName
=
NULL
;
int
suiteCounter
=
0
;
int
suiteCounter
=
0
;
for
(
testSuiteName
=
testSuiteNames
[
suiteCounter
];
testSuiteName
;
testSuiteName
=
testSuiteNames
[
++
suiteCounter
])
{
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
[
32
];
int
len
=
strlen
(
testSuiteName
);
int
copy
=
len
-
6
-
6
;
memcpy
(
buffer
,
testSuiteName
+
6
,
copy
);
//printf("%s\n", buffer);
//char *name = strndup(testSuiteName[5], 32);
if
(
SDL_strncmp
(
selected_suite_name
,
buffer
,
NAME_BUFFER_SIZE
)
!=
0
)
{
continue
;
}
}
void
*
suite
=
LoadTestSuite
(
testSuiteName
);
void
*
suite
=
LoadTestSuite
(
testSuiteName
);
TestCaseReference
**
tests
=
QueryTestCases
(
suite
);
TestCaseReference
**
tests
=
QueryTestCases
(
suite
);
TestCaseReference
*
reference
=
NULL
;
TestCaseReference
*
reference
=
NULL
;
int
counter
=
0
;
int
counter
=
0
;
for
(
reference
=
tests
[
counter
];
reference
;
reference
=
tests
[
++
counter
])
{
for
(
reference
=
tests
[
counter
];
reference
;
reference
=
tests
[
++
counter
])
{
if
(
only_selected_test
)
{
if
(
SDL_strncmp
(
selected_test_name
,
reference
->
name
,
NAME_BUFFER_SIZE
)
!=
0
)
{
continue
;
}
}
if
(
reference
->
enabled
==
TEST_DISABLED
)
{
if
(
reference
->
enabled
==
TEST_DISABLED
)
{
printf
(
"Test %s (in %s) disabled. Omitting...
\n
"
,
reference
->
name
,
testSuiteName
);
printf
(
"Test %s (in %s) disabled. Omitting...
\n
"
,
reference
->
name
,
testSuiteName
);
}
else
{
}
else
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment