2008-11-18 08:06:02 -05:00
|
|
|
#include "config.h"
|
|
|
|
|
2008-11-07 14:32:28 -05:00
|
|
|
#include <clutter/clutter.h>
|
|
|
|
|
|
|
|
#include <glib.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "test-conform-common.h"
|
|
|
|
|
2009-02-14 06:41:55 -05:00
|
|
|
static void
|
|
|
|
test_conform_skip_test (TestConformSimpleFixture *fixture,
|
|
|
|
gconstpointer data)
|
|
|
|
{
|
|
|
|
/* void */
|
|
|
|
}
|
2008-11-07 14:32:28 -05:00
|
|
|
|
|
|
|
/* This is a bit of sugar for adding new conformance tests:
|
|
|
|
*
|
|
|
|
* - It adds an extern function definition just to save maintaining a header
|
|
|
|
* that lists test entry points.
|
|
|
|
* - It sets up callbacks for a fixture, which lets us share initialization
|
|
|
|
* *code* between tests. (see test-conform-common.c)
|
|
|
|
* - It passes in a shared *data* pointer that is initialised once in main(),
|
|
|
|
* that gets passed to the fixture setup and test functions. (See the
|
|
|
|
* definition in test-conform-common.h)
|
|
|
|
*/
|
2009-02-14 06:41:55 -05:00
|
|
|
#define TEST_CONFORM_SIMPLE(NAMESPACE, FUNC) G_STMT_START { \
|
2008-11-07 14:32:28 -05:00
|
|
|
extern void FUNC (TestConformSimpleFixture *fixture, gconstpointer data); \
|
|
|
|
g_test_add ("/conform" NAMESPACE "/" #FUNC, \
|
|
|
|
TestConformSimpleFixture, \
|
|
|
|
shared_state, /* data argument for test */ \
|
|
|
|
test_conform_simple_fixture_setup, \
|
|
|
|
FUNC, \
|
2009-02-14 06:41:55 -05:00
|
|
|
test_conform_simple_fixture_teardown); } G_STMT_END
|
2008-11-07 14:32:28 -05:00
|
|
|
|
2009-02-14 06:41:55 -05:00
|
|
|
/* this is a macro that conditionally executes a test if CONDITION
|
|
|
|
* evaluates to TRUE; otherwise, it will put the test under the
|
|
|
|
* "/skip" namespace and execute a dummy function that will always
|
|
|
|
* pass.
|
|
|
|
*/
|
|
|
|
#define TEST_CONFORM_SKIP(CONDITION, NAMESPACE, FUNC) G_STMT_START { \
|
|
|
|
if (CONDITION) { \
|
|
|
|
g_test_add ("/skipped" NAMESPACE "/" #FUNC, \
|
|
|
|
TestConformSimpleFixture, \
|
|
|
|
shared_state, /* data argument for test */ \
|
|
|
|
test_conform_simple_fixture_setup, \
|
|
|
|
test_conform_skip_test, \
|
|
|
|
test_conform_simple_fixture_teardown); \
|
|
|
|
} else { TEST_CONFORM_SIMPLE (NAMESPACE, FUNC); } } G_STMT_END
|
2008-11-07 14:32:28 -05:00
|
|
|
|
2009-02-19 11:51:37 -05:00
|
|
|
#define TEST_CONFORM_TODO(NAMESPACE, FUNC) G_STMT_START { \
|
|
|
|
g_test_add ("/todo" NAMESPACE "/" #FUNC, \
|
|
|
|
TestConformSimpleFixture, \
|
|
|
|
shared_state, \
|
|
|
|
test_conform_simple_fixture_setup, \
|
|
|
|
test_conform_skip_test, \
|
|
|
|
test_conform_simple_fixture_teardown); } G_STMT_END
|
|
|
|
|
2008-11-07 14:32:28 -05:00
|
|
|
int
|
|
|
|
main (int argc, char **argv)
|
|
|
|
{
|
|
|
|
TestConformSharedState *shared_state = g_new0 (TestConformSharedState, 1);
|
2008-11-18 08:06:02 -05:00
|
|
|
|
|
|
|
#ifdef HAVE_CLUTTER_GLX
|
|
|
|
/* on X11 we need a display connection to run the test suite */
|
2009-05-27 18:39:18 -04:00
|
|
|
const gchar *display = g_getenv ("DISPLAY");
|
2008-11-18 08:06:02 -05:00
|
|
|
if (!display || *display == '\0')
|
|
|
|
{
|
|
|
|
g_print ("No DISPLAY found. Unable to run the conformance "
|
|
|
|
"test suite without a display.");
|
|
|
|
return EXIT_SUCCESS;
|
|
|
|
}
|
|
|
|
#endif
|
2008-11-07 14:32:28 -05:00
|
|
|
|
2009-06-08 13:13:18 -04:00
|
|
|
/* Turning of sync-to-vblank removes a dependency on the specifics of the
|
|
|
|
* test environment. It also means that the timeline-only tests are
|
|
|
|
* throttled to a reasonable frame rate rather than running in tight
|
|
|
|
* infinite loop.
|
|
|
|
*/
|
|
|
|
g_setenv ("CLUTTER_VBLANK", "none", FALSE);
|
|
|
|
|
2008-11-07 14:32:28 -05:00
|
|
|
g_test_init (&argc, &argv, NULL);
|
2009-01-20 16:12:44 -05:00
|
|
|
|
2008-11-07 14:32:28 -05:00
|
|
|
g_test_bug_base ("http://bugzilla.openedhand.com/show_bug.cgi?id=%s");
|
|
|
|
|
|
|
|
/* Initialise the state you need to share with everything.
|
|
|
|
*/
|
|
|
|
shared_state->argc_addr = &argc;
|
|
|
|
shared_state->argv_addr = &argv;
|
2009-01-20 16:12:44 -05:00
|
|
|
|
2009-05-22 11:59:14 -04:00
|
|
|
g_assert (clutter_init (shared_state->argc_addr, shared_state->argv_addr)
|
|
|
|
== CLUTTER_INIT_SUCCESS);
|
|
|
|
|
2008-11-10 06:48:00 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/timeline", test_timeline);
|
2009-02-14 06:41:55 -05:00
|
|
|
TEST_CONFORM_SKIP (!g_test_slow (), "/timeline", test_timeline_interpolate);
|
|
|
|
TEST_CONFORM_SKIP (!g_test_slow (), "/timeline", test_timeline_rewind);
|
2009-01-20 16:12:44 -05:00
|
|
|
|
2008-11-07 14:32:28 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/picking", test_pick);
|
|
|
|
|
2008-12-11 06:45:37 -05:00
|
|
|
/* ClutterText */
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_utf8_validation);
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_empty);
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_set_empty);
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_set_text);
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_append_some);
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_prepend_some);
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_insert);
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_delete_chars);
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_delete_text);
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_cursor);
|
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_event);
|
2008-12-11 06:59:50 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_get_chars);
|
2008-12-11 07:13:26 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_cache);
|
2009-01-06 10:30:31 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/text", test_text_password_char);
|
2008-12-11 06:45:37 -05:00
|
|
|
|
2008-11-07 14:32:28 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/rectangle", test_rect_set_size);
|
|
|
|
TEST_CONFORM_SIMPLE ("/rectangle", test_rect_set_color);
|
|
|
|
|
|
|
|
TEST_CONFORM_SIMPLE ("/fixed", test_fixed_constants);
|
2009-01-20 16:12:44 -05:00
|
|
|
|
2008-11-08 10:56:22 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/invariants", test_initial_state);
|
Enforce invariants on mapped, realized, visibility states
Bug 1138 - No trackable "mapped" state
* Add a VISIBLE flag tracking application programmer's
expected showing-state for the actor, allowing us to
always ensure we keep what the app wants while tracking
internal implementation state separately.
* Make MAPPED reflect whether the actor will be painted;
add notification on a ClutterActor::mapped property.
Keep MAPPED state updated as the actor is shown,
ancestors are shown, actor is reparented, etc.
* Require a stage and realized parents to realize; this means
at realization time the correct window system and GL resources
are known. But unparented actors can no longer be realized.
* Allow children to be unrealized even if parent is realized.
Otherwise in effect either all actors or no actors are realized,
i.e. it becomes a stage-global flag.
* Allow clutter_actor_realize() to "fail" if not inside a toplevel
* Rework clutter_actor_unrealize() so internally we have
a flavor that does not mess with visibility flag
* Add _clutter_actor_rerealize() to encapsulate a somewhat
tricky operation we were doing in a couple of places
* Do not realize/unrealize children in ClutterGroup,
ClutterActor already does it
* Do not realize impl by hand in clutter_stage_show(),
since showing impl already does that
* Do not unrealize in various dispose() methods, since
ClutterActor dispose implementation already does it
and chaining up is mandatory
* ClutterTexture uses COGL while unrealizable (before it's
added to a stage). Previously this breakage was affecting
ClutterActor because we had to allow realize outside
a stage. Move the breakage to ClutterTexture, by making
ClutterTexture just use COGL while not realized.
* Unrealize before we set parent to NULL in clutter_actor_unparent().
This means unrealize() implementations can get to the stage.
Because actors need the stage in order to detach from stage.
* Update clutter-actor-invariants.txt to reflect latest changes
* Remove explicit hide/unrealize from ClutterActor::dispose since
unparent already forces those
Instead just assert that unparent() occurred and did the right thing.
* Check whether parent implements unrealize before chaining up
Needed because ClutterGroup no longer has to implement unrealize.
* Perform unrealize in the default handler for the signal.
This allows non-containers that have children to work properly,
and allows containers to override how it's done.
* Add map/unmap virtual methods and set MAPPED flag on self and
children in there. This allows subclasses to hook map/unmap.
These are not signals, because notify::mapped is better for
anything it's legitimate for a non-subclass to do.
Signed-off-by: Emmanuele Bassi <ebassi@linux.intel.com>
2009-04-02 09:16:43 -04:00
|
|
|
TEST_CONFORM_SIMPLE ("/invariants", test_shown_not_parented);
|
2008-11-18 07:16:00 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/invariants", test_realized);
|
Enforce invariants on mapped, realized, visibility states
Bug 1138 - No trackable "mapped" state
* Add a VISIBLE flag tracking application programmer's
expected showing-state for the actor, allowing us to
always ensure we keep what the app wants while tracking
internal implementation state separately.
* Make MAPPED reflect whether the actor will be painted;
add notification on a ClutterActor::mapped property.
Keep MAPPED state updated as the actor is shown,
ancestors are shown, actor is reparented, etc.
* Require a stage and realized parents to realize; this means
at realization time the correct window system and GL resources
are known. But unparented actors can no longer be realized.
* Allow children to be unrealized even if parent is realized.
Otherwise in effect either all actors or no actors are realized,
i.e. it becomes a stage-global flag.
* Allow clutter_actor_realize() to "fail" if not inside a toplevel
* Rework clutter_actor_unrealize() so internally we have
a flavor that does not mess with visibility flag
* Add _clutter_actor_rerealize() to encapsulate a somewhat
tricky operation we were doing in a couple of places
* Do not realize/unrealize children in ClutterGroup,
ClutterActor already does it
* Do not realize impl by hand in clutter_stage_show(),
since showing impl already does that
* Do not unrealize in various dispose() methods, since
ClutterActor dispose implementation already does it
and chaining up is mandatory
* ClutterTexture uses COGL while unrealizable (before it's
added to a stage). Previously this breakage was affecting
ClutterActor because we had to allow realize outside
a stage. Move the breakage to ClutterTexture, by making
ClutterTexture just use COGL while not realized.
* Unrealize before we set parent to NULL in clutter_actor_unparent().
This means unrealize() implementations can get to the stage.
Because actors need the stage in order to detach from stage.
* Update clutter-actor-invariants.txt to reflect latest changes
* Remove explicit hide/unrealize from ClutterActor::dispose since
unparent already forces those
Instead just assert that unparent() occurred and did the right thing.
* Check whether parent implements unrealize before chaining up
Needed because ClutterGroup no longer has to implement unrealize.
* Perform unrealize in the default handler for the signal.
This allows non-containers that have children to work properly,
and allows containers to override how it's done.
* Add map/unmap virtual methods and set MAPPED flag on self and
children in there. This allows subclasses to hook map/unmap.
These are not signals, because notify::mapped is better for
anything it's legitimate for a non-subclass to do.
Signed-off-by: Emmanuele Bassi <ebassi@linux.intel.com>
2009-04-02 09:16:43 -04:00
|
|
|
TEST_CONFORM_SIMPLE ("/invariants", test_realize_not_recursive);
|
|
|
|
TEST_CONFORM_SIMPLE ("/invariants", test_map_recursive);
|
2008-11-08 10:56:22 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/invariants", test_mapped);
|
|
|
|
TEST_CONFORM_SIMPLE ("/invariants", test_show_on_set_parent);
|
2009-06-11 22:46:38 -04:00
|
|
|
TEST_CONFORM_SIMPLE ("/invariants", test_clone_no_map);
|
2008-11-08 10:56:22 -05:00
|
|
|
|
2009-01-20 16:12:44 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/vertex-buffer", test_vertex_buffer_contiguous);
|
|
|
|
TEST_CONFORM_SIMPLE ("/vertex-buffer", test_vertex_buffer_interleved);
|
|
|
|
TEST_CONFORM_SIMPLE ("/vertex-buffer", test_vertex_buffer_mutability);
|
2008-11-10 13:53:14 -05:00
|
|
|
|
2008-11-12 09:41:01 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/opacity", test_label_opacity);
|
|
|
|
TEST_CONFORM_SIMPLE ("/opacity", test_rectangle_opacity);
|
|
|
|
TEST_CONFORM_SIMPLE ("/opacity", test_paint_opacity);
|
2008-11-07 14:32:28 -05:00
|
|
|
|
2008-11-28 12:36:37 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/texture", test_backface_culling);
|
2009-02-09 07:47:41 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/texture", test_npot_texture);
|
2009-06-07 11:31:12 -04:00
|
|
|
TEST_CONFORM_SIMPLE ("/texture", test_premult);
|
2008-11-28 12:36:37 -05:00
|
|
|
|
2008-12-05 08:13:37 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/path", test_path);
|
|
|
|
|
2008-12-08 08:57:10 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/binding-pool", test_binding_pool);
|
|
|
|
|
2009-01-22 08:14:02 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/actor", test_anchors);
|
|
|
|
|
2009-02-14 06:45:27 -05:00
|
|
|
TEST_CONFORM_SIMPLE ("/model", test_list_model_populate);
|
|
|
|
TEST_CONFORM_SIMPLE ("/model", test_list_model_iterate);
|
2009-04-29 10:39:23 -04:00
|
|
|
TEST_CONFORM_SIMPLE ("/model", test_list_model_filter);
|
2009-02-14 06:45:27 -05:00
|
|
|
|
2009-06-19 07:15:12 -04:00
|
|
|
TEST_CONFORM_SIMPLE ("/material", test_materials);
|
2009-05-10 19:40:41 -04:00
|
|
|
TEST_CONFORM_SIMPLE ("/material", test_blend_strings);
|
|
|
|
|
2009-06-01 13:43:47 -04:00
|
|
|
TEST_CONFORM_SIMPLE ("/color", test_color_from_string);
|
|
|
|
TEST_CONFORM_SIMPLE ("/color", test_color_to_string);
|
|
|
|
|
2009-06-03 06:12:09 -04:00
|
|
|
TEST_CONFORM_SIMPLE ("/units", test_units_constructors);
|
|
|
|
TEST_CONFORM_SIMPLE ("/units", test_units_string);
|
|
|
|
|
2008-11-12 09:41:01 -05:00
|
|
|
return g_test_run ();
|
|
|
|
}
|