Skip to content
Snippets Groups Projects
Unverified Commit b1d5ad8d authored by Calen Pennington's avatar Calen Pennington Committed by GitHub
Browse files

Merge pull request #23024 from cpennington/fix-edx-when-date-ingest

Correctly wire in signal the new course_date_signals app so that it a…
parents e38a1004 4901dde7
No related merge requests found
Showing with 22 additions and 24 deletions
......@@ -444,7 +444,7 @@ class CourseEntitlement(TimeStampedModel):
refund_successful = refund_entitlement(course_entitlement=self)
if not refund_successful:
# This state is achieved in most cases by a failure in the ecommerce service to process the refund.
log.warn(
log.warning(
u'Entitlement Refund failed for Course Entitlement [%s], alert User',
self.uuid
)
......
......@@ -166,7 +166,7 @@ class ConditionalModule(ConditionalFields, XModule, StudioEditableModule):
if module is not None:
# We do not want to log when module is None, and it is when requester
# does not have access to the requested required module.
log.warn('Error in conditional module: \
log.warning('Error in conditional module: \
required module {module} has no {module_attr}'.format(module=module, module_attr=attr_name))
return False
......
......@@ -170,7 +170,7 @@ class SplitMigrator(object):
draft_location, revision=ModuleStoreEnum.RevisionOption.draft_preferred, **kwargs
)
if parent_loc is None:
log.warn(u'No parent found in source course for %s', draft_location)
log.warning(u'No parent found in source course for %s', draft_location)
continue
old_parent = self.source_modulestore.get_item(parent_loc, **kwargs)
split_parent_loc = new_draft_course_loc.make_usage_key(
......
......@@ -69,7 +69,7 @@ def rewrite_video_url(cdn_base_url, original_video_url):
validator(rewritten_url)
return rewritten_url
except ValidationError:
log.warn("Invalid CDN rewrite URL encountered, %s", rewritten_url)
log.warning("Invalid CDN rewrite URL encountered, %s", rewritten_url)
# Mimic the behavior of removed get_video_from_cdn in this regard and
# return None causing the caller to use the original URL.
......
......@@ -208,7 +208,7 @@ def refund_entitlement(course_entitlement):
always_notify=True,
)
else:
log.warn(u'No refund opened for user [%s], course entitlement [%s]', enrollee.id, entitlement_uuid)
log.warning(u'No refund opened for user [%s], course entitlement [%s]', enrollee.id, entitlement_uuid)
return False
......
"""
Django app to manage course content dates, and ingesting them into edx-when for later use by the LMS.
"""
default_app_config = 'openedx.core.djangoapps.course_date_signals.apps.CourseDatesSignalsConfig' # pylint: disable=invalid-name
"""
Django app configuration for openedx.core.djangoapps.course_dates_signals
Django App Configuration for the course_date_signals app
"""
from django.apps import AppConfig
class CourseDatesSignalsConfig(AppConfig):
name = 'openedx.core.djangoapps.course_dates_signals'
name = 'openedx.core.djangoapps.course_date_signals'
def ready(self):
"""
......
......@@ -7,18 +7,17 @@ from django.dispatch import receiver
from six import text_type
from xblock.fields import Scope
from xmodule.modulestore.django import SignalHandler, modulestore
from edx_when.api import FIELDS_TO_EXTRACT, set_dates_for_course
log = logging.getLogger(__name__)
def date_field_values(date_fields, xblock):
def _field_values(fields, xblock):
"""
Read field values for the specified date fields from the supplied xblock.
Read field values for the specified fields from the supplied xblock.
"""
result = {}
for field_name in date_fields:
for field_name in fields:
if field_name not in xblock.fields:
continue
field = xblock.fields[field_name]
......@@ -39,18 +38,18 @@ def extract_dates_from_course(course):
"""
Extract all dates from the supplied course.
"""
log.info('Publishing course dates for %s', course.id)
log.info('Extracting course dates for %s', course.id)
if course.self_paced:
metadata = date_field_values(FIELDS_TO_EXTRACT, course)
metadata = _field_values(FIELDS_TO_EXTRACT, course)
# self-paced courses may accidentally have a course due date
metadata.pop('due', None)
date_items = [(course.location, metadata)]
else:
date_items = []
items = modulestore().get_items(course.id)
log.info('extracting dates from %d items in %s', len(items), course.id)
log.info('Extracting dates from %d items in %s', len(items), course.id)
for item in items:
date_items.append((item.location, date_field_values(FIELDS_TO_EXTRACT, item)))
date_items.append((item.location, _field_values(FIELDS_TO_EXTRACT, item)))
return date_items
......@@ -59,12 +58,10 @@ def extract_dates(sender, course_key, **kwargs): # pylint: disable=unused-argum
"""
Extract dates from blocks when publishing a course.
"""
log.info("Extracting dates from %s", course_key)
course = modulestore().get_course(course_key)
if not course:
log.info("No course found for key %s", course_key)
log.info("No course found for key %s to extract dates from", course_key)
return
date_items = extract_dates_from_course(course)
......@@ -72,4 +69,4 @@ def extract_dates(sender, course_key, **kwargs): # pylint: disable=unused-argum
try:
set_dates_for_course(course_key, date_items)
except Exception: # pylint: disable=broad-except
log.exception('setting dates for %s', course_key)
log.exception('Unable to set dates for %s on course publish', course_key)
# pylint: disable=missing-docstring,unused-argument,model-missing-unicode
# pylint: disable=missing-docstring,unused-argument
import json
......
......@@ -41,7 +41,6 @@ class CountryMiddleware(MiddlewareMixin):
reader = geoip2.database.Reader(settings.GEOIP_PATH)
try:
response = reader.country(new_ip_address)
# pylint: disable=no-member
country_code = response.country.iso_code
except geoip2.errors.AddressNotFoundError:
country_code = ""
......
......@@ -4,9 +4,6 @@ Test site_configuration middleware.
"""
from mock import patch
from django.conf import settings
from django.test import TestCase
from django.test.client import Client
from django.test.utils import override_settings
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment