2010-10-12 17:11:52 +01:00
|
|
|
How to add new units to the Clutter Conformance test suite
|
|
|
|
-------------------------------------------------------------------------------
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
If the new unit is not logically part of an existing file, you should create a
|
|
|
|
new source file and add it to the build. The built files are listed in the
|
|
|
|
Makefile.am template. Please, respect the sections already available there.
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
When creating a new file, you should include "test-conform-common.h", as well
|
|
|
|
as <clutter/clutter.h> and <glib.h>.
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
Each new test unit should be contained in a function named following this
|
|
|
|
pattern:
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
void
|
|
|
|
<section>_<unit> (void)
|
|
|
|
{
|
|
|
|
}
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
For instance:
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
void
|
|
|
|
actor_allocation_changes (void)
|
|
|
|
{
|
|
|
|
/* test allocation changes */
|
|
|
|
}
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
void
|
|
|
|
rectangle_border (void)
|
|
|
|
{
|
|
|
|
/* test ClutterRectangle's border property */
|
|
|
|
}
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
After adding the test unit, edit test-conform-main.c and add the unit to the
|
|
|
|
list of tests, by using one of these three macros:
|
|
|
|
|
|
|
|
• TEST_CONFORM_SIMPLE (path, function_name);
|
|
|
|
|
|
|
|
@path is the unit path in the suite, and it's used to generate the
|
|
|
|
executable wrapper for running the unit as a stand-alone binary
|
|
|
|
and for the HTML report.
|
|
|
|
@function_name is the name of the function containing the newly added
|
|
|
|
test unit.
|
|
|
|
|
|
|
|
This is the simple form of test unit, and it will always be run.
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
• TEST_CONFORM_SKIP (condition, path, function_name);
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
@condition is used to decide whether to run the unit or not.
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
This macro will check @condition on start, and if it evaluates to TRUE
|
|
|
|
then the @function_name will be called and the unit executed; otherwise
|
|
|
|
the test will automatically succeed.
|
|
|
|
|
|
|
|
• TEST_CONFORM_TODO (path, function_name);
|
|
|
|
|
|
|
|
This macro will execute @function_name and will succeed if the unit
|
|
|
|
fails. This macro should be used for tests that are known to fail.
|
|
|
|
|
|
|
|
Notes:
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
• Do not call clutter_init() in your units; initialization is handled
|
|
|
|
by the conformance test suite itself.
|
2008-11-07 19:32:28 +00:00
|
|
|
|
2010-10-12 17:11:52 +01:00
|
|
|
• All units are invoked in a new process, to prevent clobbering the
|
|
|
|
state.
|