test-mail-index-map.c revision 96ca70b91de9f2b07728812bbec222e18f121cbd
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen/* Copyright (c) 2016 Dovecot authors, see the included COPYING file */
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen#include "lib.h"
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen#include "array.h"
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen#include "test-common.h"
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen#include "mail-index-private.h"
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen#include "mail-index-modseq.h"
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen#include "mail-index-transaction-private.h"
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainenstatic void test_mail_index_map_lookup_seq_range_count(unsigned int messages_count)
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen{
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen struct mail_index_record_map rec_map;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen struct mail_index_map map;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen uint32_t seq, first_uid, last_uid, first_seq, last_seq, max_uid;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen memset(&map, 0, sizeof(map));
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen memset(&rec_map, 0, sizeof(rec_map));
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen map.rec_map = &rec_map;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen map.hdr.messages_count = messages_count;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen map.hdr.record_size = sizeof(struct mail_index_record);
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen rec_map.records_count = map.hdr.messages_count;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen rec_map.records = i_new(struct mail_index_record, map.hdr.messages_count);
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen for (seq = 1; seq <= map.hdr.messages_count; seq++)
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen MAIL_INDEX_REC_AT_SEQ(&map, seq)->uid = seq*2;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen max_uid = (seq-1)*2;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen map.hdr.next_uid = max_uid + 1;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen for (first_uid = 2; first_uid <= max_uid; first_uid++) {
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen for (last_uid = first_uid; last_uid <= max_uid; last_uid++) {
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen if (first_uid == last_uid && first_uid%2 != 0)
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen continue;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen mail_index_map_lookup_seq_range(&map, first_uid, last_uid, &first_seq, &last_seq);
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen test_assert((first_uid+1)/2 == first_seq && last_uid/2 == last_seq);
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen }
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen }
96ca70b91de9f2b07728812bbec222e18f121cbdTimo Sirainen i_free(rec_map.records);
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen}
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainenstatic void test_mail_index_map_lookup_seq_range(void)
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen{
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen unsigned int i;
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen test_begin("mail index map lookup seq range");
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen for (i = 1; i < 20; i++)
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen test_mail_index_map_lookup_seq_range_count(i);
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen test_end();
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen}
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainenint main(void)
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen{
baf3e87e186453fda13bd21f7cbcb2efc8492e8bTimo Sirainen static void (*test_functions[])(void) = {
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen test_mail_index_map_lookup_seq_range,
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen NULL
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen };
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen return test_run(test_functions);
0cc566d5e68a650d12fd73631d53a467fad72e1eTimo Sirainen}