Skip to content

Commit

Permalink
Update date in dao_get_jobs_by_service_id (#2300)
Browse files Browse the repository at this point in the history
* fix(dao_get_jobs_by_service_id): use util function to calculate query time frame

* chore: add tests for `dao_get_jobs_by_service_id`

* chore: formatting

* fix: update tests

* fix(tests): add some 00:00 and 23:59 timestamps to the test to ensure no rogue jobs are slipping in

---------

Co-authored-by: Jumana B <[email protected]>
  • Loading branch information
andrewleith and jzbahrai authored Sep 26, 2024
1 parent 53a413e commit 0574bcc
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 10 deletions.
5 changes: 3 additions & 2 deletions app/dao/jobs_dao.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@

from app import db
from app.dao.dao_utils import transactional
from app.dao.date_util import get_query_date_based_on_retention_period
from app.dao.templates_dao import dao_get_template_by_id
from app.models import (
JOB_STATUS_CANCELLED,
Expand All @@ -28,7 +29,6 @@
ServiceDataRetention,
Template,
)
from app.utils import midnight_n_days_ago


@statsd(namespace="dao")
Expand Down Expand Up @@ -58,7 +58,8 @@ def dao_get_jobs_by_service_id(service_id, limit_days=None, page=1, page_size=50
Job.original_file_name != current_app.config["ONE_OFF_MESSAGE_FILENAME"],
]
if limit_days is not None:
query_filter.append(Job.created_at >= midnight_n_days_ago(limit_days))
query_filter.append(Job.created_at > get_query_date_based_on_retention_period(limit_days))

if statuses is not None and statuses != [""]:
query_filter.append(Job.job_status.in_(statuses))
return (
Expand Down
19 changes: 12 additions & 7 deletions tests/app/dao/test_jobs_dao.py
Original file line number Diff line number Diff line change
Expand Up @@ -160,18 +160,23 @@ def test_get_jobs_for_service_with_limit_days_param(sample_template):
assert old_job not in jobs_limit_days


@freeze_time("2017-06-10")
# This test assumes the local timezone is EST
@freeze_time("2024-09-25 12:25:00")
def test_get_jobs_for_service_with_limit_days_edge_case(sample_template):
one_job = create_job(sample_template)
just_after_midnight_job = create_job(sample_template, created_at=datetime(2017, 6, 3, 4, 0, 1))
just_before_midnight_job = create_job(sample_template, created_at=datetime(2017, 6, 3, 3, 59, 0))
# create 2 jobs for each day of the last 10 days
for i in range(1, 11):
create_job(sample_template, created_at=datetime(2024, 9, 25 - i, 0, 0, 0))
create_job(sample_template, created_at=datetime(2024, 9, 25 - i, 23, 59, 59))

too_old_job = create_job(sample_template, created_at=datetime(2024, 9, 18, 0, 1, 0))
just_right_job = create_job(sample_template, created_at=datetime(2024, 9, 19, 0, 0, 0))

jobs_limit_days = dao_get_jobs_by_service_id(one_job.service_id, limit_days=7).items
assert len(jobs_limit_days) == 2

assert len(jobs_limit_days) == 14 # 2 for one for each day: today (1) + 12 the last 6 days (12) + one for just_right_job (1)
assert one_job in jobs_limit_days
assert just_after_midnight_job in jobs_limit_days
assert just_before_midnight_job not in jobs_limit_days
assert just_right_job in jobs_limit_days
assert too_old_job not in jobs_limit_days


def test_get_jobs_for_service_in_processed_at_then_created_at_order(notify_db, notify_db_session, sample_template):
Expand Down
4 changes: 3 additions & 1 deletion tests/app/job/test_rest.py
Original file line number Diff line number Diff line change
Expand Up @@ -751,7 +751,9 @@ def test_get_jobs_with_limit_days(admin_request, sample_template):
limit_days=7,
)

assert len(resp_json["data"]) == 2
# get_jobs_by_service should return data from the current day (Monday 9th) and the previous 6 days (Tuesday 3rd)
# so only 1 job should be returned
assert len(resp_json["data"]) == 1


def test_get_jobs_should_return_statistics(admin_request, sample_template):
Expand Down

0 comments on commit 0574bcc

Please sign in to comment.