|
| 1 | +const getQueueMetrics = async (queue) => { |
| 2 | + const _sqlCnt = `SELECT * FROM fetchq.metric_get('${queue}')`; |
| 3 | + const res = await global.query(_sqlCnt); |
| 4 | + return res.rows.reduce( |
| 5 | + (acc, curr) => ({ |
| 6 | + ...acc, |
| 7 | + [curr.metric]: Number(curr.current_value), |
| 8 | + }), |
| 9 | + {}, |
| 10 | + ); |
| 11 | +}; |
| 12 | + |
1 | 13 | describe('v1QueueDocumentDrop', () => {
|
2 | 14 | beforeEach(global.resetSchema);
|
3 | 15 |
|
@@ -55,4 +67,111 @@ describe('v1QueueDocumentDrop', () => {
|
55 | 67 | expect(calls[0][0].response.status).toBe(404);
|
56 | 68 | expect(calls[0][0].response.data.success).toBe(false);
|
57 | 69 | });
|
| 70 | + |
| 71 | + it('should update counters from ACTIVE status', async () => { |
| 72 | + await global.query(`SELECT FROM fetchq.queue_create('q1')`); |
| 73 | + await global.query(`SELECT FROM fetchq.queue_set_max_attempts('q1', 1)`); |
| 74 | + await global.query(`SELECT FROM fetchq.doc_push('q1', 's1')`); |
| 75 | + await global.query(`SELECT FROM fetchq.doc_pick('q1', 0, 1, '1y')`); |
| 76 | + await global.query(`SELECT FROM fetchq.mnt()`); |
| 77 | + |
| 78 | + const m1 = await getQueueMetrics('q1'); |
| 79 | + expect(m1).toEqual({ act: 1, cnt: 1, ent: 1, pkd: 1, pnd: 0, v0: 1 }); |
| 80 | + |
| 81 | + await global.post('/api/v1/queues/q1/drop/s1'); |
| 82 | + await global.query(`SELECT FROM fetchq.mnt()`); |
| 83 | + |
| 84 | + const m2 = await getQueueMetrics('q1'); |
| 85 | + expect(m2).toEqual({ act: 0, cnt: 0, ent: 1, pkd: 1, pnd: 0, v0: 0 }); |
| 86 | + }); |
| 87 | + |
| 88 | + it('should update counters from PLANNED status', async () => { |
| 89 | + await global.query(`SELECT FROM fetchq.queue_create('q1')`); |
| 90 | + await global.query(`SELECT FROM fetchq.queue_set_max_attempts('q1', 1)`); |
| 91 | + await global.query( |
| 92 | + `SELECT FROM fetchq.doc_push('q1', 's1', 0, 0, NOW() + INTERVAL '1m', '{}')`, |
| 93 | + ); |
| 94 | + await global.query(`SELECT FROM fetchq.mnt()`); |
| 95 | + |
| 96 | + const m1 = await getQueueMetrics('q1'); |
| 97 | + expect(m1).toEqual({ cnt: 1, ent: 1, pln: 1, v0: 1 }); |
| 98 | + |
| 99 | + await global.post('/api/v1/queues/q1/drop/s1'); |
| 100 | + await global.query(`SELECT FROM fetchq.mnt()`); |
| 101 | + |
| 102 | + const m2 = await getQueueMetrics('q1'); |
| 103 | + expect(m2).toEqual({ cnt: 0, ent: 1, pln: 0, v0: 0 }); |
| 104 | + }); |
| 105 | + |
| 106 | + it('should update counters from COMPLETED status', async () => { |
| 107 | + await global.query(`SELECT FROM fetchq.queue_create('q1')`); |
| 108 | + await global.query(`SELECT FROM fetchq.queue_set_max_attempts('q1', 1)`); |
| 109 | + await global.query(`SELECT FROM fetchq.doc_push('q1', 's1')`); |
| 110 | + await global.query(`SELECT FROM fetchq.doc_pick('q1', 0, 1, '1y')`); |
| 111 | + await global.query(`SELECT FROM fetchq.doc_complete('q1', 's1')`); |
| 112 | + await global.query(`SELECT FROM fetchq.mnt()`); |
| 113 | + |
| 114 | + const m1 = await getQueueMetrics('q1'); |
| 115 | + expect(m1).toEqual({ |
| 116 | + act: 0, |
| 117 | + cnt: 1, |
| 118 | + cpl: 1, |
| 119 | + ent: 1, |
| 120 | + pkd: 1, |
| 121 | + pnd: 0, |
| 122 | + prc: 1, |
| 123 | + v0: 1, |
| 124 | + }); |
| 125 | + |
| 126 | + await global.post('/api/v1/queues/q1/drop/s1'); |
| 127 | + await global.query(`SELECT FROM fetchq.mnt()`); |
| 128 | + |
| 129 | + const m2 = await getQueueMetrics('q1'); |
| 130 | + expect(m2).toEqual({ |
| 131 | + act: 0, |
| 132 | + cnt: 0, |
| 133 | + cpl: 0, |
| 134 | + ent: 1, |
| 135 | + pkd: 1, |
| 136 | + pnd: 0, |
| 137 | + prc: 1, |
| 138 | + v0: 0, |
| 139 | + }); |
| 140 | + }); |
| 141 | + |
| 142 | + it('should update counters from KILLED status', async () => { |
| 143 | + await global.query(`SELECT FROM fetchq.queue_create('q1')`); |
| 144 | + await global.query(`SELECT FROM fetchq.queue_set_max_attempts('q1', 1)`); |
| 145 | + await global.query(`SELECT FROM fetchq.doc_push('q1', 's1')`); |
| 146 | + await global.query(`SELECT FROM fetchq.doc_pick('q1', 0, 1, '1y')`); |
| 147 | + await global.query(`SELECT FROM fetchq.doc_kill('q1', 's1')`); |
| 148 | + await global.query(`SELECT FROM fetchq.mnt()`); |
| 149 | + |
| 150 | + const m1 = await getQueueMetrics('q1'); |
| 151 | + expect(m1).toEqual({ |
| 152 | + act: 0, |
| 153 | + cnt: 1, |
| 154 | + kll: 1, |
| 155 | + ent: 1, |
| 156 | + pkd: 1, |
| 157 | + pnd: 0, |
| 158 | + prc: 1, |
| 159 | + v0: 1, |
| 160 | + }); |
| 161 | + |
| 162 | + await global.post('/api/v1/queues/q1/drop/s1'); |
| 163 | + await global.query(`SELECT FROM fetchq.mnt()`); |
| 164 | + |
| 165 | + const m2 = await getQueueMetrics('q1'); |
| 166 | + expect(m2).toEqual({ |
| 167 | + act: 0, |
| 168 | + cnt: 0, |
| 169 | + kll: 0, |
| 170 | + ent: 1, |
| 171 | + pkd: 1, |
| 172 | + pnd: 0, |
| 173 | + prc: 1, |
| 174 | + v0: 0, |
| 175 | + }); |
| 176 | + }); |
58 | 177 | });
|
0 commit comments