xserver-multidpi/test
Erkki Seppälä ccb3e78124 Xext: add a generic hashtable implementation
The generic hashtable implementation adds a key-value container, that
keeps the key and value inside the hashtable structure and manages
their memory by itself. This data structure is best suited for
fixed-length keys and values.

One creates a new hash table with ht_create and disposes it with
ht_destroy. ht_create accepts the key and value sizes (in bytes) in
addition to the hashing and comparison functions to use. When adding
keys with ht_add, they will be copied into the hash and a pointer to
the value will be returned: data may be put into this structure (or if
the hash table is to be used as a set, one can just not put anything
in).

The hash table comes also with one generic hashing function plus a
comparison function to facilitate ease of use. It also has a custom
hashing and comparison functions for hashing resource IDs with
HashXID.

Reviewed-by: Rami Ylimäki <rami.ylimaki@vincit.fi>
Signed-off-by: Erkki Seppälä <erkki.seppala@vincit.fi>
2012-04-18 12:49:06 +03:00
..
xi2 test: reset the client before checking the swapped version 2012-03-29 08:14:54 +10:00
.gitignore test: add new test cases to .gitignore 2012-03-04 20:01:29 -08:00
ddxstubs.c os: Pass the FatalError message to OsVendorFatalError 2012-03-24 01:07:05 -07:00
fixes.c Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
hashtabletest.c Xext: add a generic hashtable implementation 2012-04-18 12:49:06 +03:00
input.c Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
list.c Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
Makefile.am Xext: add a generic hashtable implementation 2012-04-18 12:49:06 +03:00
misc.c Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
README Add a test-suite for in-server unit-testing. 2009-04-28 16:03:56 +10:00
string.c Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
touch.c Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
xfree86.c Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
xkb.c Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
xtest.c test: init the sync extensions for tests to pass again 2012-03-29 08:14:31 +10:00

                        X server test suite

This suite contains a set of tests to verify the behaviour of functions used
internally to the server. This test suite is based on glib's testing
framework [1].

= How it works =
Through some automake abuse, we link the test programs with the same static
libraries as the Xorg binary. The test suites can then call various functions
and verify their behaviour - without the need to start the server or connect
clients.

This testing only works for functions that do not rely on a particular state
of the X server. Unless the test suite replicates the expected state, which
may be difficult.

= How to run the tests =
Run "make check" the test directory. This will compile the tests and execute
them in the order specified in the TESTS variable in test/Makefile.am.

Each set of tests related to a subsystem are available as a binary that can be
executed directly. For example, run "xkb" to perform some xkb-related tests.

== Adding a new test ==
When adding a new test, ensure that you add a short description of what the
test does and what the expected outcome is. If the test reproduces a
particular bug, using g_test_bug().

== Misc ==

The programs "gtester" and "gtester-report" may be used to generate XML/HTML
log files of tests succeeded and failed.

---------

[1] http://library.gnome.org/devel/glib/stable/glib-Testing.html