Travis: stifle progress on git clone
[beanstalkd.git] / testjobs.c
blobc3de9359ed2f1bb9f12cefed56fd5196ef805070
1 #include <stdint.h>
2 #include <stdlib.h>
3 #include <stdio.h>
4 #include <string.h>
5 #include <sys/time.h>
6 #include "ct/ct.h"
7 #include "dat.h"
9 static tube default_tube;
11 void
12 cttestjob_creation()
14 job j;
16 TUBE_ASSIGN(default_tube, make_tube("default"));
17 j = make_job(1, 0, 1, 0, default_tube);
18 assertf(j->r.pri == 1, "priority should match");
21 void
22 cttestjob_cmp_pris()
24 job a, b;
26 TUBE_ASSIGN(default_tube, make_tube("default"));
27 a = make_job(1, 0, 1, 0, default_tube);
28 b = make_job(1 << 27, 0, 1, 0, default_tube);
30 assertf(job_pri_less(a, b), "should be less");
33 void
34 cttestjob_cmp_ids()
36 job a, b;
38 TUBE_ASSIGN(default_tube, make_tube("default"));
39 a = make_job(1, 0, 1, 0, default_tube);
40 b = make_job(1, 0, 1, 0, default_tube);
42 b->r.id <<= 49;
43 assertf(job_pri_less(a, b), "should be less");
47 void
48 cttestjob_large_pris()
50 job a, b;
52 TUBE_ASSIGN(default_tube, make_tube("default"));
53 a = make_job(1, 0, 1, 0, default_tube);
54 b = make_job(-5, 0, 1, 0, default_tube);
56 assertf(job_pri_less(a, b), "should be less");
58 a = make_job(-5, 0, 1, 0, default_tube);
59 b = make_job(1, 0, 1, 0, default_tube);
61 assertf(!job_pri_less(a, b), "should not be less");
64 void
65 cttestjob_hash_free()
67 job j;
68 uint64 jid = 83;
70 TUBE_ASSIGN(default_tube, make_tube("default"));
71 j = make_job_with_id(0, 0, 1, 0, default_tube, jid);
72 job_free(j);
74 assertf(!job_find(jid), "job should be missing");
77 void
78 cttestjob_hash_free_next()
80 job a, b;
81 uint64 aid = 97, bid = 12386;
83 TUBE_ASSIGN(default_tube, make_tube("default"));
84 b = make_job_with_id(0, 0, 1, 0, default_tube, bid);
85 a = make_job_with_id(0, 0, 1, 0, default_tube, aid);
87 assertf(a->ht_next == b, "b should be chained to a");
89 job_free(b);
91 assertf(a->ht_next == NULL, "job should be missing");
94 void
95 cttestjob_all_jobs_used()
97 job j, x;
99 TUBE_ASSIGN(default_tube, make_tube("default"));
100 j = make_job(0, 0, 1, 0, default_tube);
101 assertf(get_all_jobs_used() == 1, "should match");
103 x = allocate_job(10);
104 assertf(get_all_jobs_used() == 1, "should match");
106 job_free(x);
107 assertf(get_all_jobs_used() == 1, "should match");
109 job_free(j);
110 assertf(get_all_jobs_used() == 0, "should match");
113 void
114 cttestjob_100_000_jobs()
116 int i;
118 TUBE_ASSIGN(default_tube, make_tube("default"));
119 for (i = 0; i < 100000; i++) {
120 make_job(0, 0, 1, 0, default_tube);
122 assertf(get_all_jobs_used() == 100000, "should match");
124 for (i = 1; i <= 100000; i++) {
125 job_free(job_find(i));
127 fprintf(stderr, "get_all_jobs_used() => %zu\n", get_all_jobs_used());
128 assertf(get_all_jobs_used() == 0, "should match");
131 void
132 ctbenchmakejob(int n)
134 int i;
135 TUBE_ASSIGN(default_tube, make_tube("default"));
136 for (i = 0; i < n; i++) {
137 make_job(0, 0, 1, 0, default_tube);