app_queue: Fix initial hold time queue statistic

Fixed to use correct initial value and fixed to use the
correct queue info to check the first value.

ASTERISK-27204

Change-Id: Ia9e36c828e566e1cc25c66f73307566e4acb8e73
This commit is contained in:
Sungtae Kim 2017-08-17 23:46:49 +02:00 committed by Joshua Colp
parent e4e2e53c8a
commit 22af5e3784
1 changed files with 7 additions and 3 deletions

View File

@ -4072,8 +4072,12 @@ static void recalc_holdtime(struct queue_ent *qe, int newholdtime)
/* 2^2 (4) is the filter coefficient; a higher exponent would give old entries more weight */
ao2_lock(qe->parent);
oldvalue = qe->parent->holdtime;
qe->parent->holdtime = (((oldvalue << 2) - oldvalue) + newholdtime) >> 2;
if ((qe->parent->callscompleted + qe->parent->callsabandoned) == 0) {
qe->parent->holdtime = newholdtime;
} else {
oldvalue = qe->parent->holdtime;
qe->parent->holdtime = (((oldvalue << 2) - oldvalue) + newholdtime) >> 2;
}
ao2_unlock(qe->parent);
}
@ -5651,7 +5655,7 @@ static int update_queue(struct call_queue *q, struct member *member, int callcom
if (callcompletedinsl) {
q->callscompletedinsl++;
}
if (q->callscompletedinsl == 1) {
if (q->callscompleted == 1) {
q->talktime = newtalktime;
} else {
/* Calculate talktime using the same exponential average as holdtime code */