Skip to content

Commit

Permalink
feat: adding an activated_at value to group membership records
Browse files Browse the repository at this point in the history
  • Loading branch information
alex-sheehan-edx committed Mar 12, 2024
1 parent 769115c commit 3193d0b
Show file tree
Hide file tree
Showing 5 changed files with 62 additions and 3 deletions.
2 changes: 2 additions & 0 deletions enterprise/api/v1/views/enterprise_group.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
from enterprise.api.v1 import serializers
from enterprise.api.v1.views.base_views import EnterpriseReadWriteModelViewSet
from enterprise.logging import getEnterpriseLogger
from enterprise.utils import localized_utcnow

LOGGER = getEnterpriseLogger(__name__)

Expand Down Expand Up @@ -195,6 +196,7 @@ def assign_learners(self, request, group_uuid):
# Extend the list of memberships that need to be created associated with existing Users
ent_customer_users = [
models.EnterpriseGroupMembership(
activated_at=localized_utcnow(),
enterprise_customer_user=ecu,
group=group
)
Expand Down
23 changes: 23 additions & 0 deletions enterprise/migrations/0203_auto_20240312_1527.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Generated by Django 3.2.23 on 2024-03-12 15:27

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('enterprise', '0202_enterprisegroup_applies_to_all_contexts_and_more'),
]

operations = [
migrations.AddField(
model_name='enterprisegroupmembership',
name='activated_at',
field=models.DateTimeField(blank=True, default=None, help_text='The moment at which the membership record is written with an Enterprise Customer User record.', null=True),
),
migrations.AddField(
model_name='historicalenterprisegroupmembership',
name='activated_at',
field=models.DateTimeField(blank=True, default=None, help_text='The moment at which the membership record is written with an Enterprise Customer User record.', null=True),
),
]
9 changes: 9 additions & 0 deletions enterprise/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -1484,6 +1484,7 @@ def fulfill_pending_group_memberships(self, enterprise_customer_user):
enterprise_customer_user: a EnterpriseCustomerUser instance
"""
self.memberships.update(
activated_at=localized_utcnow(),
pending_enterprise_customer_user=None,
enterprise_customer_user=enterprise_customer_user
)
Expand Down Expand Up @@ -4308,6 +4309,14 @@ class EnterpriseGroupMembership(TimeStampedModel, SoftDeletableModel):
related_name='memberships',
on_delete=models.deletion.CASCADE,
)
activated_at = models.DateTimeField(
default=None,
blank=True,
null=True,
help_text=_(
"The moment at which the membership record is written with an Enterprise Customer User record."
),
)
history = HistoricalRecords()

class Meta:
Expand Down
22 changes: 22 additions & 0 deletions tests/test_enterprise/api/test_views.py
Original file line number Diff line number Diff line change
Expand Up @@ -7690,6 +7690,28 @@ def test_group_applies_to_all_contexts_learner_list(self):
for result in results:
assert (result.get('pending_learner_id') == pending_user.id) or (result.get('learner_id') == new_user.id)

def test_group_assign_realized_learner_adds_activated_at(self):
"""
Test that newly created membership records associated with an existing user have an activated at value written
but records associated with pending memberships do not.
"""
url = settings.TEST_SERVER + reverse(
'enterprise-group-assign-learners',
kwargs={'group_uuid': self.group_2.uuid},
)
request_data = {'learner_emails': f"{UserFactory().email},email@example.com"}
self.client.post(url, data=request_data)
membership = EnterpriseGroupMembership.objects.filter(
group=self.group_2,
pending_enterprise_customer_user__isnull=True
).first()
assert membership.activated_at
pending_membership = EnterpriseGroupMembership.objects.filter(
group=self.group_2,
enterprise_customer_user__isnull=True
).first()
assert not pending_membership.activated_at


@mark.django_db
class TestEnterpriseCustomerSsoConfigurationViewSet(APITest):
Expand Down
9 changes: 6 additions & 3 deletions tests/test_enterprise/test_signals.py
Original file line number Diff line number Diff line change
Expand Up @@ -256,19 +256,22 @@ def test_handle_user_post_save_fulfills_pending_group_memberships(self):
email = "jackie.chan@hollywood.com"
user = UserFactory(id=1, email=email)
pending_user = PendingEnterpriseCustomerUserFactory(user_email=email)
EnterpriseGroupMembershipFactory(
new_membership = EnterpriseGroupMembershipFactory(
pending_enterprise_customer_user=pending_user,
enterprise_customer_user=None
)
assert not new_membership.activated_at
parameters = {"instance": user, "created": False}
handle_user_post_save(mock.Mock(), **parameters)
# Should delete pending link
assert PendingEnterpriseCustomerUser.objects.count() == 0
assert len(EnterpriseGroupMembership.objects.all()) == 1

new_enterprise_user = EnterpriseCustomerUser.objects.get(user_id=user.id)
assert EnterpriseGroupMembership.objects.first().pending_enterprise_customer_user is None
assert EnterpriseGroupMembership.objects.first().enterprise_customer_user == new_enterprise_user
membership = EnterpriseGroupMembership.objects.first()
assert membership.pending_enterprise_customer_user is None
assert membership.enterprise_customer_user == new_enterprise_user
assert membership.activated_at


@mark.django_db
Expand Down

0 comments on commit 3193d0b

Please sign in to comment.