| Conditions | 4 |
| Total Lines | 20 |
| Lines | 0 |
| Ratio | 0 % |
| Tests | 0 |
| CRAP Score | 20 |
| Changes | 0 | ||
| 1 | from plugin.models import SyncResult |
||
| 17 | def check(self, job): |
||
| 18 | last_result = SyncIntervalOption.get_last_result(job.account, SyncMode.Full) |
||
| 19 | |||
| 20 | if last_result is None or last_result.started_at <= job.due_at: |
||
| 21 | return True |
||
| 22 | |||
| 23 | # Re-schedule job |
||
| 24 | job.due_at = job.next_at(last_result.started_at) |
||
| 25 | |||
| 26 | log.debug('Job re-scheduled to %r', job.due_at) |
||
| 27 | |||
| 28 | # Check if a trigger is required |
||
| 29 | if job.due_at <= datetime.utcnow(): |
||
| 30 | return True |
||
| 31 | |||
| 32 | # Trigger ignored, update job |
||
| 33 | job.save() |
||
| 34 | |||
| 35 | log.debug('Ignoring scheduled sync interval (already triggered)') |
||
| 36 | return False |
||
| 37 | |||
| 58 |