summaryrefslogtreecommitdiffstats
path: root/runtime/tests/maps/is2.c
diff options
context:
space:
mode:
authorhunt <hunt>2005-10-26 08:08:53 +0000
committerhunt <hunt>2005-10-26 08:08:53 +0000
commitd06fc47a2be5a31f770595211a719fe0e6c0cc13 (patch)
tree980f15972175169238b8f4942b261d9e72943a60 /runtime/tests/maps/is2.c
parent1dcb36dc4ad16c1b842d0961cd6a5d8e57c97b87 (diff)
downloadsystemtap-steved-d06fc47a2be5a31f770595211a719fe0e6c0cc13.tar.gz
systemtap-steved-d06fc47a2be5a31f770595211a719fe0e6c0cc13.tar.xz
systemtap-steved-d06fc47a2be5a31f770595211a719fe0e6c0cc13.zip
2005-10-26 Martin Hunt <hunt@redhat.com>
* maps/map.test: Update with results for new tests. * maps/*2.c: Tests for the new API. * maps/ist.c: Renamed isx.c. * maps/setadd.c: New test of adding and setting.
Diffstat (limited to 'runtime/tests/maps/is2.c')
-rw-r--r--runtime/tests/maps/is2.c119
1 files changed, 119 insertions, 0 deletions
diff --git a/runtime/tests/maps/is2.c b/runtime/tests/maps/is2.c
new file mode 100644
index 00000000..b6537f06
--- /dev/null
+++ b/runtime/tests/maps/is2.c
@@ -0,0 +1,119 @@
+#include "runtime.h"
+
+/* test of maps with keys of int64 and value of string */
+#define KEY1_TYPE INT64
+#define VALUE_TYPE STRING
+#include "map-gen.c"
+
+#include "map.c"
+
+int main ()
+{
+ MAP map = _stp_map_new_is(4);
+ map->wrap = 1;
+
+ /* map[1] = one */
+ _stp_map_set_is (map, 1, "one");
+
+ printf ("map[1]=%s\n", _stp_map_get_is(map,1));
+ _stp_map_print(map,"map[%1d] = %s");
+
+ /* map[3] = "three" */
+ _stp_map_set_is (map, 3, "three");
+ _stp_map_print(map,"map[%1d] = %s");
+
+ /* now try to confuse things */
+ /* These won't do anything useful, but shouldn't crash */
+ _stp_map_set_is(0,1,"foobar");
+ _stp_map_set_is(map,0,0);
+ _stp_map_set_is(map,100,0);
+ _stp_map_print(map,"map[%1d] = %s");
+
+ /* create and delete a key */
+ _stp_map_set_is (map, 1024, "2048");
+ _stp_map_set_is (map, 1024, 0);
+ _stp_map_print(map,"map[%1d] = %s");
+
+ /* create and delete a key again*/
+ _stp_map_set_is (map, 1024, "2048");
+ _stp_map_print(map,"map[%1d] = %s");
+ _stp_map_set_is (map, 1024, 0);
+ _stp_map_print(map,"map[%1d] = %s");
+
+
+ /* check that unset values are 0 */
+ if (_stp_map_get_is(map, 5))
+ printf("ERROR: unset key has nonzero value\n");
+
+ /* map[5] = "five" */
+ _stp_map_set_is (map, 5, "five");
+ _stp_map_print(map,"map[%1d] = %s");
+
+ /* test empty string */
+ _stp_map_set_is (map, 5, "");
+ _stp_map_print(map,"map[%1d] = %s");
+
+
+ /* add 4 new entries, pushing the others out */
+ int i;
+ for (i = 6; i < 10; i++)
+ {
+ char buf[32];
+ sprintf(buf, "value of %d", i);
+ _stp_map_set_is (map, i, buf);
+ }
+ _stp_map_print(map,"map[%1d] = %s");
+
+ /* 5, 382, 526, and 903 all hash to the same value (23) */
+ /* use them to test the hash chain */
+ _stp_map_set_is (map, 5, "1005");
+ _stp_map_set_is (map, 382, "1382");
+ _stp_map_set_is (map, 526, "1526");
+ _stp_map_set_is (map, 903, "1903");
+
+ _stp_map_print(map,"map[%1d] = %s");
+
+ /* now delete all 4 nodes, one by one */
+ _stp_map_set_is (map, 382, 0);
+ _stp_map_print(map,"map[%1d] = %s");
+
+ _stp_map_set_is (map, 5, 0);
+ _stp_map_print(map,"map[%1d] = %s");
+
+ _stp_map_set_is (map, 903, 0);
+ _stp_map_print(map,"map[%1d] = %s");
+
+ _stp_map_set_is (map, 526, 0);
+ _stp_map_print(map,"map[%1d] = %s");
+
+ /* test overflow errors */
+ map->wrap = 0;
+ for (i = 6; i < 10; i++)
+ {
+ char buf[32];
+ sprintf(buf, "value of %d", i);
+ _stp_map_set_is (map, i, buf);
+ }
+
+ for (i = 6; i < 10; i++)
+ {
+ char buf[32];
+ int res;
+ sprintf(buf, "new value of %d", i);
+ res = _stp_map_set_is (map, i, buf);
+ if (res)
+ printf("WARNING: During wrap test, got result of %d when expected 0\n", res);
+ }
+ for (i = 16; i < 20; i++)
+ {
+ char buf[32];
+ int res;
+ sprintf(buf, "BAD value of %d", i);
+ res = _stp_map_set_is (map, i, buf);
+ if (res != -1)
+ printf("WARNING: During wrap test, got result of %d when expected -1\n", res);
+ }
+ _stp_map_print(map,"map[%1d] = %s");
+ _stp_map_del (map);
+ return 0;
+}