summaryrefslogtreecommitdiffstats
path: root/tests/user_door.c
diff options
context:
space:
mode:
authorJérémy Zurcher <jeremy@asynk.ch>2012-05-31 16:39:14 +0200
committerJérémy Zurcher <jeremy@asynk.ch>2012-05-31 16:39:14 +0200
commit4bc1b68caf1165222b7ea4080144547d388d17eb (patch)
treef54132649202d1acfb11730d0dce9d648f5b1efa /tests/user_door.c
parente6a53fa2a651ec15b5a2b7c5ed70af421660ca7a (diff)
downloadedoors-4bc1b68caf1165222b7ea4080144547d388d17eb.zip
edoors-4bc1b68caf1165222b7ea4080144547d388d17eb.tar.gz
split and complete tests
Diffstat (limited to 'tests/user_door.c')
-rw-r--r--tests/user_door.c55
1 files changed, 55 insertions, 0 deletions
diff --git a/tests/user_door.c b/tests/user_door.c
new file mode 100644
index 0000000..7a7c705
--- /dev/null
+++ b/tests/user_door.c
@@ -0,0 +1,55 @@
+
+#include "helper.h"
+
+typedef struct {
+ char txt[32];
+ int idx;
+} Input;
+
+static int free_called = 0;
+
+static Input* input_create(char *txt)
+{
+ Input *input = (Input*)malloc(sizeof(Input));
+ strncpy(input->txt,txt,32);
+ input->txt[31] = '\0';
+ input->idx = 0;
+ return input;
+}
+
+static void input_free(Input *input)
+{
+ EINA_LOG_DOM_DBG(_eiotas_log_dom,"free Input\n");
+ free(input);
+ free_called = 1;
+}
+
+static void input_show(Input *input)
+{
+ EINA_LOG_DOM_DBG(_eiotas_log_dom,"Input [%d] %s\n",input->idx,input->txt);
+}
+
+static void input_receive(const Eiotas_Door *door, Eiotas_Particle *particle, Eiotas_User_Data *data)
+{
+ EINA_LOG_DOM_DBG(_eiotas_log_dom,"input_receive 0x%X\n",PRINTPTR(data));
+}
+
+void test_user_door()
+{
+ Eiotas_Spin *dom0 = eiotas_spin_add("dom0",10);
+
+ Input *input = input_create("hello world");
+ input_show(input);
+
+ Eiotas_User_Bits user_bits;
+
+ user_bits.data = input;
+ user_bits.free_fct = (Eiotas_User_Data_Free)&input_free;
+ user_bits.recv_fct = (Eiotas_Receive_Particle)&input_receive;
+ Eiotas_Door *din0 = eiotas_door_add("input0",&dom0->room,&user_bits);
+ eiotas_iota_show(&din0->iota); // eiotas_iota_show((Eiotas_Iota*)din0);
+
+ eiotas_spin_free(dom0);
+ check_cond((free_called==1),"input_free not called");
+}
+