update changelog
[debian/iodine.git] / tests / user.c
index 7c3f87a25f861a998ff034a34c9d5524a8afb1af..afd61cac3a5c7dda1eaafe9f75dfc75a235214bf 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2006-2007 Bjorn Andersson <flex@kryo.se>, Erik Ekman <yarrick@kryo.se>
+ * Copyright (c) 2006-2009 Bjorn Andersson <flex@kryo.se>, Erik Ekman <yarrick@kryo.se>
  *
  * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above
@@ -34,7 +34,7 @@ START_TEST(test_init_users)
        int i;
 
        ip = inet_addr("127.0.0.1");
-       init_users(ip);
+       init_users(ip, 27);
        for (i = 0; i < USERS; i++) {
                fail_unless(users[i].id == i);
                fail_unless(users[i].q.id == 0);
@@ -51,7 +51,7 @@ START_TEST(test_users_waiting)
        in_addr_t ip;
 
        ip = inet_addr("127.0.0.1");
-       init_users(ip);
+       init_users(ip, 27);
 
        fail_unless(users_waiting_on_reply() == 0);
 
@@ -63,6 +63,7 @@ START_TEST(test_users_waiting)
        
        fail_unless(users_waiting_on_reply() == 0);
        
+       users[3].conn = CONN_DNS_NULL;
        users[3].q.id = 1;
        
        fail_unless(users_waiting_on_reply() == 1);
@@ -75,7 +76,8 @@ START_TEST(test_find_user_by_ip)
        unsigned int testip;
 
        ip = inet_addr("127.0.0.1");
-       init_users(ip);
+       init_users(ip, 27);
+       users[0].conn = CONN_DNS_NULL;
 
        testip = (unsigned int) inet_addr("10.0.0.1");
        fail_unless(find_user_by_ip(testip) == -1);
@@ -100,19 +102,25 @@ START_TEST(test_all_users_waiting_to_send)
        in_addr_t ip;
 
        ip = inet_addr("127.0.0.1");
-       init_users(ip);
+       init_users(ip, 27);
 
        fail_unless(all_users_waiting_to_send() == 1);
        
+       users[0].conn = CONN_DNS_NULL;
        users[0].active = 1;
        
        fail_unless(all_users_waiting_to_send() == 1);
        
        users[0].last_pkt = time(NULL);
+       users[0].outpacket.len = 0;
        
        fail_unless(all_users_waiting_to_send() == 0);
 
+#ifdef OUTPACKETQ_LEN
+       users[0].outpacketq_filled = 1;
+#else
        users[0].outpacket.len = 44;
+#endif
        
        fail_unless(all_users_waiting_to_send() == 1);
 }
@@ -124,7 +132,7 @@ START_TEST(test_find_available_user)
        int i;
 
        ip = inet_addr("127.0.0.1");
-       init_users(ip);
+       init_users(ip, 27);
 
        for (i = 0; i < USERS; i++) {
                fail_unless(find_available_user() == i);
@@ -146,6 +154,34 @@ START_TEST(test_find_available_user)
 }
 END_TEST
 
+START_TEST(test_find_available_user_small_net)
+{
+       in_addr_t ip;
+       int i;
+
+       ip = inet_addr("127.0.0.1");
+       init_users(ip, 29); /* this should result in 5 enabled users */
+
+       for (i = 0; i < 5; i++) {
+               fail_unless(find_available_user() == i);
+       }
+
+       for (i = 0; i < USERS; i++) {
+               fail_unless(find_available_user() == -1);
+       }
+
+       users[3].active = 0;
+
+       fail_unless(find_available_user() == 3);
+       fail_unless(find_available_user() == -1);
+
+       users[3].last_pkt = 55;
+       
+       fail_unless(find_available_user() == 3);
+       fail_unless(find_available_user() == -1);
+}
+END_TEST
+
 TCase *
 test_user_create_tests()
 {
@@ -157,6 +193,7 @@ test_user_create_tests()
        tcase_add_test(tc, test_find_user_by_ip);
        tcase_add_test(tc, test_all_users_waiting_to_send);
        tcase_add_test(tc, test_find_available_user);
+       tcase_add_test(tc, test_find_available_user_small_net);
 
        return tc;
 }