Skip to content

Commit

Permalink
Store course start and end when aviaible
Browse files Browse the repository at this point in the history
Use the value from the custom variables in canvas this indicates the
course deviates from the term of the course.

We have been requesting these variables as part of the default custom variables
in the config json for a while so we'll get a data for a few schools.

We'll look into applying the same patter in other LMSes.
  • Loading branch information
marcospri committed Jan 8, 2025
1 parent ceaa512 commit 697f2fa
Show file tree
Hide file tree
Showing 3 changed files with 62 additions and 5 deletions.
2 changes: 1 addition & 1 deletion lms/models/lms_course.py
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ class LMSCourse(CreatedUpdatedMixin, Base):
"""The start date of the course. Only for when we get this information directly from the LMS"""

ends_at: Mapped[datetime | None] = mapped_column()
"""The end date of the course. Only for when we get this information direclty from the LMS"""
"""The end date of the course. Only for when we get this information directly from the LMS"""


class LMSCourseApplicationInstance(CreatedUpdatedMixin, Base):
Expand Down
31 changes: 30 additions & 1 deletion lms/services/course.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
import json
from copy import deepcopy
from datetime import datetime
from typing import Mapping

from dateutil import parser
from sqlalchemy import Select, select, union

from lms.db import full_text_match
Expand Down Expand Up @@ -311,6 +314,8 @@ def _upsert_lms_course(self, course: Course, lti_params: LTIParams) -> LMSCourse
"https://purl.imsglobal.org/spec/lti-nrps/claim/namesroleservice", {}
).get("context_memberships_url")

course_starts_at, course_ends_at = self._get_course_dates(lti_params)

lms_course = bulk_upsert(
self._db,
LMSCourse,
Expand All @@ -321,10 +326,18 @@ def _upsert_lms_course(self, course: Course, lti_params: LTIParams) -> LMSCourse
"h_authority_provided_id": course.authority_provided_id,
"name": course.lms_name,
"lti_context_memberships_url": lti_context_membership_url,
"starts_at": course_starts_at,
"ends_at": course_ends_at,
}
],
index_elements=["h_authority_provided_id"],
update_columns=["updated", "name", "lti_context_memberships_url"],
update_columns=[
"updated",
"name",
"lti_context_memberships_url",
"starts_at",
"ends_at",
],
).one()
bulk_upsert(
self._db,
Expand Down Expand Up @@ -415,6 +428,22 @@ def _get_copied_from_course(self, lti_params) -> Course | None:

return None

def _get_course_dates(
self, lti_params: Mapping
) -> tuple[datetime | None, datetime | None]:
"""Get the dates for the current curse, None if not available."""
try:
course_starts_at = parser.isoparse(lti_params.get("custom_course_starts"))
except (TypeError, ValueError):
course_starts_at = None

try:
course_ends_at = parser.isoparse(lti_params.get("custom_course_ends"))
except (TypeError, ValueError):
course_ends_at = None

return course_starts_at, course_ends_at


def course_service_factory(_context, request):
return CourseService(
Expand Down
34 changes: 31 additions & 3 deletions tests/unit/lms/services/course_test.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
from datetime import date, datetime
from datetime import UTC, date, datetime
from unittest.mock import call, patch, sentinel

import pytest
Expand Down Expand Up @@ -161,9 +161,29 @@ def test_get_from_launch_when_new_and_historical_course_exists(
)
assert course == upsert_course.return_value

@pytest.mark.parametrize(
"custom_course_starts, course_starts_at",
[(None, None), ("2022-01-01T00:00:00Z", datetime(2022, 1, 1, tzinfo=UTC))],
)
@pytest.mark.parametrize(
"custom_course_ends, course_ends_at",
[(None, None), ("2022-01-01T00:00:00Z", datetime(2022, 1, 1, tzinfo=UTC))],
)
def test_upsert_course(
self, svc, grouping_service, bulk_upsert, db_session, lti_params
self,
svc,
grouping_service,
bulk_upsert,
db_session,
lti_params,
custom_course_starts,
course_starts_at,
custom_course_ends,
course_ends_at,
):
lti_params["custom_course_starts"] = custom_course_starts
lti_params["custom_course_ends"] = custom_course_ends

course = svc.upsert_course(
lti_params=lti_params,
extra=sentinel.extra,
Expand Down Expand Up @@ -196,10 +216,18 @@ def test_upsert_course(
"h_authority_provided_id": course.authority_provided_id,
"name": course.lms_name,
"lti_context_memberships_url": None,
"starts_at": course_starts_at,
"ends_at": course_ends_at,
}
],
index_elements=["h_authority_provided_id"],
update_columns=["updated", "name", "lti_context_memberships_url"],
update_columns=[
"updated",
"name",
"lti_context_memberships_url",
"starts_at",
"ends_at",
],
),
call().one(),
call(
Expand Down

0 comments on commit 697f2fa

Please sign in to comment.