Merge pull request #20758 from edx/andytr1/grades_simple_history

Adding simple history to track grade changes. Educator-4347
This commit is contained in:
Andytr1
2019-06-10 12:39:54 -04:00
committed by GitHub
3 changed files with 54 additions and 1 deletions

View File

@@ -1178,6 +1178,7 @@ INSTALLED_APPS = [
'openedx.features.course_duration_limits',
'openedx.features.content_type_gating',
'experiments',
]

View File

@@ -0,0 +1,43 @@
# -*- coding: utf-8 -*-
# Generated by Django 1.11.20 on 2019-06-05 13:59
from __future__ import unicode_literals
from django.conf import settings
from django.db import migrations, models
import django.db.models.deletion
import simple_history.models
class Migration(migrations.Migration):
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
('grades', '0014_persistentsubsectiongradeoverridehistory'),
]
operations = [
migrations.CreateModel(
name='HistoricalPersistentSubsectionGradeOverride',
fields=[
('id', models.IntegerField(auto_created=True, blank=True, db_index=True, verbose_name='ID')),
('created', models.DateTimeField(blank=True, db_index=True, editable=False)),
('modified', models.DateTimeField(blank=True, db_index=True, editable=False)),
('earned_all_override', models.FloatField(blank=True, null=True)),
('possible_all_override', models.FloatField(blank=True, null=True)),
('earned_graded_override', models.FloatField(blank=True, null=True)),
('possible_graded_override', models.FloatField(blank=True, null=True)),
('history_id', models.AutoField(primary_key=True, serialize=False)),
('history_date', models.DateTimeField()),
('history_change_reason', models.CharField(max_length=100, null=True)),
('history_type', models.CharField(choices=[('+', 'Created'), ('~', 'Changed'), ('-', 'Deleted')], max_length=1)),
('grade', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to='grades.PersistentSubsectionGrade')),
('history_user', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='+', to=settings.AUTH_USER_MODEL)),
],
options={
'ordering': ('-history_date', '-history_id'),
'get_latest_by': 'history_date',
'verbose_name': 'historical persistent subsection grade override',
},
bases=(simple_history.models.HistoricalChanges, models.Model),
),
]

View File

@@ -14,6 +14,7 @@ from base64 import b64encode
from collections import defaultdict, namedtuple
from hashlib import sha1
from django.apps import apps
from django.contrib.auth.models import User
from django.db import models
from django.utils.timezone import now
@@ -25,7 +26,8 @@ from opaque_keys.edx.keys import CourseKey, UsageKey
from coursewarehistoryextended.fields import UnsignedBigIntAutoField, UnsignedBigIntOneToOneField
from lms.djangoapps.grades import events, constants
from openedx.core.lib.cache_utils import get_cache
from simple_history.models import HistoricalRecords
from simple_history.utils import update_change_reason
log = logging.getLogger(__name__)
@@ -653,6 +655,12 @@ class PersistentSubsectionGradeOverride(models.Model):
_CACHE_NAMESPACE = u"grades.models.PersistentSubsectionGradeOverride"
# This is necessary because CMS does not install the grades app, but it
# imports this models code. Simple History will attempt to connect to the installed
# model in the grades app, which will fail.
if 'grades' in apps.app_configs:
history = HistoricalRecords()
def __unicode__(self):
return u', '.join([
u"{}".format(type(self).__name__),
@@ -703,6 +711,7 @@ class PersistentSubsectionGradeOverride(models.Model):
grade=subsection_grade_model,
defaults=cls._prepare_override_params(subsection_grade_model, override_data),
)
update_change_reason(override, feature)
action = action or PersistentSubsectionGradeOverrideHistory.CREATE_OR_UPDATE