On Saturday, August 20, 2022 at 11:39:55 AM UTC-7 Tom Clerckx wrote:
> Our tasks are added using scheduler.queue_task(...) function. > > By default, we set the period to 0 > Why? If you don't know the period, why are you queuing it? Or are you using the "cron" type of task scheduling? > Later on we added to the defaults : prevent_drift = True > > It's this last change that triggered the observed error. > > Eveything I know about the scheduler has been shown to me by Stefan (Niphlod), who wrote the subsystem and the tests. I suspect I would have to spend quite a bit of time to come up with an analysis of what is really wrong, but I'm really suspicious of queuing a period of 0. /dps > > > > > On Friday, August 19, 2022 at 12:49:05 PM UTC+2 snide...@gmail.com wrote: > >> On Monday, August 8, 2022 at 3:50:26 AM UTC-7 Tom Clerckx wrote: >> >>> Version: >>> Version 2.22.5-stable+timestamp.2022.06.04.18.13.51 >>> >>> There is a problem with the calculation of next_run_time in >>> gluon/scheduler.py at line 1024 >>> >>> It calculates: >>> steps = secondspassed // task.period + 1 >>> >>> However, there is no check done for task.period being 0 >>> >>> This can cause the following scheduler error: >>> ZeroDivisionError: float divmod() >>> >>> I think it would be better to initialize next_run_time and change the >>> last else condition to "elif task.period". >>> >> >> How did you get task.period == 0? >> >> I'm wondering if this is a valid use-case; the scheduler has quite a test >> suite. >> >> /dps >> >> > -- Resources: - http://web2py.com - http://web2py.com/book (Documentation) - http://github.com/web2py/web2py (Source code) - https://code.google.com/p/web2py/issues/list (Report Issues) --- You received this message because you are subscribed to the Google Groups "web2py-users" group. To unsubscribe from this group and stop receiving emails from it, send an email to web2py+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/web2py/38a740d4-1fb5-4454-a825-da76b7220da2n%40googlegroups.com.