Changeset b6fc3f


Ignore:
Timestamp:
02/09/09 21:44:08 (3 years ago)
Author:
Erik Ekman <yarrick@…>
Branches:
master
Children:
955135
Parents:
3ee493
git-author:
Erik Ekman <yarrick@…> (02/09/09 21:44:08)
git-committer:
Erik Ekman <erik@…> (02/04/12 20:34:00)
Message:

Made dns_get_id return unsigned short, added test cases

Files:
6 edited

Legend:

Unmodified
Added
Removed
  • src/dns.c

    r155f0c rb6fc3f  
    184184} 
    185185 
    186 short 
     186unsigned short 
    187187dns_get_id(char *packet, size_t packetlen) 
    188188{ 
  • src/dns.h

    ra5031e rb6fc3f  
    2727int dns_encode(char *, size_t, struct query *, qr_t, char *, size_t); 
    2828int dns_encode_ns_response(char *buf, size_t buflen, struct query *q, char *topdomain); 
    29 short dns_get_id(char *packet, size_t packetlen); 
     29unsigned short dns_get_id(char *packet, size_t packetlen); 
    3030int dns_decode(char *, size_t, struct query *, qr_t, char *, size_t); 
    3131 
  • src/fw_query.c

    r02d40c rb6fc3f  
    3636} 
    3737 
    38 void fw_query_get(short query_id, struct fw_query **fw_query) 
     38void fw_query_get(unsigned short query_id, struct fw_query **fw_query) 
    3939{ 
    4040        int i; 
  • src/fw_query.h

    r155f0c rb6fc3f  
    3131        struct sockaddr addr; 
    3232        int addrlen; 
    33         short id; 
     33        unsigned short id; 
    3434}; 
    3535 
    3636void fw_query_init(); 
    3737void fw_query_put(struct fw_query *fw_query); 
    38 void fw_query_get(short query_id, struct fw_query **fw_query); 
     38void fw_query_get(unsigned short query_id, struct fw_query **fw_query); 
    3939 
    4040#endif /*__FW_QUERY_H__*/ 
  • src/iodined.c

    r10fd38 rb6fc3f  
    626626        socklen_t fromlen; 
    627627        struct fw_query *query; 
    628         short id; 
     628        unsigned short id; 
    629629        int r; 
    630630 
  • tests/dns.c

    r0836ad rb6fc3f  
    3434static void dump_packet(char *, size_t); 
    3535 
    36 static char queryPacket[] = 
     36static char query_packet[] = 
    3737        "\x05\x39\x01\x00\x00\x01\x00\x00\x00\x00\x00\x01\x2D\x41\x6A\x62\x63" 
    3838        "\x75\x79\x74\x63\x70\x65\x62\x30\x67\x71\x30\x6C\x74\x65\x62\x75\x78" 
     
    4141        "\x0A\x00\x01\x00\x00\x29\x10\x00\x00\x00\x80\x00\x00\x00"; 
    4242 
    43 static char answerPacket[] = 
     43static char answer_packet[] = 
    4444        "\x05\x39\x84\x00\x00\x01\x00\x01\x00\x00\x00\x00\x05\x73\x69\x6C\x6C" 
    4545        "\x79\x04\x68\x6F\x73\x74\x02\x6F\x66\x06\x69\x6F\x64\x69\x6E\x65\x04" 
     
    4949        "\x20\x62\x65\x20\x64\x65\x6C\x69\x76\x65\x72\x65\x64"; 
    5050 
    51 static char answerPacketHighTransId[] = 
     51static char answer_packet_high_trans_id[] = 
    5252        "\x85\x39\x84\x00\x00\x01\x00\x01\x00\x00\x00\x00\x05\x73\x69\x6C\x6C" 
    5353        "\x79\x04\x68\x6F\x73\x74\x02\x6F\x66\x06\x69\x6F\x64\x69\x6E\x65\x04" 
     
    8888        strcpy(d, topdomain); 
    8989        ret = dns_encode(buf, len, &q, QR_QUERY, resolv, strlen(resolv)); 
    90         len = sizeof(queryPacket) - 1; /* Skip extra null character */ 
    91  
    92         if (strncmp(queryPacket, buf, sizeof(queryPacket)) || ret != len) { 
     90        len = sizeof(query_packet) - 1; /* Skip extra null character */ 
     91 
     92        if (strncmp(query_packet, buf, sizeof(query_packet)) || ret != len) { 
    9393                printf("\n"); 
    94                 dump_packet(queryPacket, len); 
     94                dump_packet(query_packet, len); 
    9595                dump_packet(buf, ret); 
    9696        } 
    97         fail_unless(strncmp(queryPacket, buf, sizeof(queryPacket)) == 0, "Did not compile expected packet"); 
     97        fail_unless(strncmp(query_packet, buf, sizeof(query_packet)) == 0, "Did not compile expected packet"); 
    9898        fail_unless(ret == len, "Bad packet length: %d, expected %d", ret, len); 
    9999} 
     
    111111        memset(&buf, 0, sizeof(buf)); 
    112112        q.id = 0; 
    113         len = sizeof(queryPacket) - 1; 
     113        len = sizeof(query_packet) - 1; 
    114114        enc = get_base32_encoder(); 
    115115 
    116         dns_decode(buf, sizeof(buf), &q, QR_QUERY, queryPacket, len); 
     116        dns_decode(buf, sizeof(buf), &q, QR_QUERY, query_packet, len); 
    117117        domain = strstr(q.name, topdomain); 
    118118        len = sizeof(buf); 
     
    140140 
    141141        ret = dns_encode(buf, len, &q, QR_ANSWER, msgData, strlen(msgData)); 
    142         len = sizeof(answerPacket) - 1; /* Skip extra null character */ 
    143  
    144         fail_unless(strncmp(answerPacket, buf, sizeof(answerPacket)) == 0, "Did not compile expected packet"); 
     142        len = sizeof(answer_packet) - 1; /* Skip extra null character */ 
     143 
     144        fail_unless(strncmp(answer_packet, buf, sizeof(answer_packet)) == 0, "Did not compile expected packet"); 
    145145        fail_unless(ret == len, "Bad packet length: %d, expected %d", ret, len); 
    146146} 
     
    157157        memset(&buf, 0, sizeof(buf)); 
    158158 
    159         ret = dns_decode(buf, len, &q, QR_ANSWER, answerPacket, sizeof(answerPacket)-1); 
     159        ret = dns_decode(buf, len, &q, QR_ANSWER, answer_packet, sizeof(answer_packet)-1); 
    160160        fail_unless(strncmp(msgData, buf, sizeof(msgData)) == 0, "Did not extract expected data"); 
    161161        fail_unless(ret == strlen(msgData), "Bad data length: %d, expected %d", ret, strlen(msgData)); 
     
    174174        memset(&buf, 0, sizeof(buf)); 
    175175 
    176         ret = dns_decode(buf, len, &q, QR_ANSWER, answerPacketHighTransId, sizeof(answerPacketHighTransId)-1); 
     176        ret = dns_decode(buf, len, &q, QR_ANSWER, answer_packet_high_trans_id, sizeof(answer_packet_high_trans_id)-1); 
    177177        fail_unless(strncmp(msgData, buf, sizeof(msgData)) == 0, "Did not extract expected data"); 
    178178        fail_unless(ret == strlen(msgData), "Bad data length: %d, expected %d", ret, strlen(msgData)); 
     
    180180} 
    181181END_TEST 
     182 
     183START_TEST(test_get_id_short_packet) 
     184{ 
     185        char buf[5]; 
     186        int len; 
     187        unsigned short id; 
     188 
     189        len = sizeof(buf); 
     190        memset(&buf, 5, sizeof(buf)); 
     191 
     192        id = dns_get_id(buf, len); 
     193        fail_unless(id == 0); 
     194} 
     195END_TEST 
     196 
     197START_TEST(test_get_id_low) 
     198{ 
     199        unsigned short id; 
     200 
     201        id = dns_get_id(answer_packet, sizeof(answer_packet)); 
     202        fail_unless(id == 1337); 
     203} 
     204END_TEST 
     205 
     206START_TEST(test_get_id_high) 
     207{ 
     208        unsigned short id; 
     209 
     210        id = dns_get_id(answer_packet_high_trans_id, sizeof(answer_packet_high_trans_id)); 
     211        fail_unless(id == 0x8539); 
     212} 
     213END_TEST 
     214 
    182215static void 
    183216dump_packet(char *buf, size_t len) 
     
    210243        tcase_add_test(tc, test_decode_response); 
    211244        tcase_add_test(tc, test_decode_response_with_high_trans_id); 
     245        tcase_add_test(tc, test_get_id_short_packet); 
     246        tcase_add_test(tc, test_get_id_low); 
     247        tcase_add_test(tc, test_get_id_high); 
    212248 
    213249        return tc; 
Note: See TracChangeset for help on using the changeset viewer.