123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- # -*- coding: utf-8 -*-
- from __future__ import absolute_import
- import datetime
- import logging
- import pytest
- from tests.unit.utils.scheduler.base import SchedulerTestsBase
- try:
- import dateutil.parser
- HAS_DATEUTIL_PARSER = True
- except ImportError:
- HAS_DATEUTIL_PARSER = False
- log = logging.getLogger(__name__)
- @pytest.mark.skipif(
- HAS_DATEUTIL_PARSER is False,
- reason="The 'dateutil.parser' library is not available",
- )
- class SchedulerPostponeTest(SchedulerTestsBase):
- """
- Validate the pkg module
- """
- def setUp(self):
- super(SchedulerPostponeTest, self).setUp()
- self.schedule.opts["loop_interval"] = 1
- @pytest.mark.slow_test(seconds=5) # Test takes >1 and <=5 seconds
- def test_postpone(self):
- """
- verify that scheduled job is postponed until the specified time.
- """
- job = {
- "schedule": {"job1": {"function": "test.ping", "when": "11/29/2017 4pm"}}
- }
- # 11/29/2017 4pm
- run_time = dateutil.parser.parse("11/29/2017 4:00pm")
- # 5 minute delay
- delay = 300
- # Add job to schedule
- self.schedule.opts.update(job)
- # Postpone the job by 5 minutes
- self.schedule.postpone_job(
- "job1",
- {
- "time": run_time.strftime("%Y-%m-%dT%H:%M:%S"),
- "new_time": (run_time + datetime.timedelta(seconds=delay)).strftime(
- "%Y-%m-%dT%H:%M:%S"
- ),
- },
- )
- # Run at the original time
- self.schedule.eval(now=run_time)
- ret = self.schedule.job_status("job1")
- self.assertNotIn("_last_run", ret)
- # Run 5 minutes later
- self.schedule.eval(now=run_time + datetime.timedelta(seconds=delay))
- ret = self.schedule.job_status("job1")
- self.assertEqual(ret["_last_run"], run_time + datetime.timedelta(seconds=delay))
- # Run 6 minutes later
- self.schedule.eval(now=run_time + datetime.timedelta(seconds=delay + 1))
- ret = self.schedule.job_status("job1")
- self.assertEqual(ret["_last_run"], run_time + datetime.timedelta(seconds=delay))
|