Conditions | 4 |
Total Lines | 20 |
Lines | 0 |
Ratio | 0 % |
Tests | 1 |
CRAP Score | 16.0213 |
Changes | 0 |
1 | 1 | from plugin.models import SyncResult |
|
17 | 1 | 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 |