This repository has been archived by the owner on Nov 4, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 254
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1021 from edx/bderusha/mgmt-cmd-update-referrals
Add management command for adding site to referrals without sites
- Loading branch information
Showing
4 changed files
with
120 additions
and
0 deletions.
There are no files selected for viewing
Empty file.
Empty file.
44 changes: 44 additions & 0 deletions
44
ecommerce/referrals/management/commands/add_site_to_referrals.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
""" Adds a Site to Referrals where site is set to null. """ | ||
from __future__ import unicode_literals | ||
|
||
from django.contrib.sites.models import Site | ||
from django.core.management import BaseCommand, CommandError | ||
|
||
from ecommerce.referrals.models import Referral | ||
|
||
|
||
class Command(BaseCommand): | ||
help = 'Add a site to referrals without one.' | ||
|
||
def add_arguments(self, parser): | ||
parser.add_argument('-s', '--site-id', | ||
action='store', | ||
dest='site_id', | ||
type=int, | ||
help='ID of the Site to associate the referrals with.') | ||
parser.add_argument('--commit', | ||
action='store_true', | ||
dest='commit', | ||
default=False, | ||
help='Actually update the referrals.') | ||
|
||
def handle(self, *args, **options): | ||
queryset = Referral.objects.filter(site__isnull=True) | ||
count = queryset.count() | ||
|
||
try: | ||
site = Site.objects.get(id=options['site_id']) | ||
except Site.DoesNotExist: | ||
msg = 'A valid Site ID must be specified!' | ||
self.stderr.write(msg) | ||
raise CommandError(msg) | ||
|
||
if options['commit']: | ||
self.stdout.write('Associating [{}] referrals with site [{}]...'.format(count, site)) | ||
|
||
queryset.update(site=site) | ||
self.stdout.write('Done.') | ||
else: | ||
msg = 'This has been an example operation. If the --commit flag had been included, the command ' \ | ||
'would have associated [{}] referrals with site [{}].'.format(count, site) | ||
self.stdout.write(msg) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
from __future__ import unicode_literals | ||
from StringIO import StringIO | ||
|
||
from django.contrib.sites.models import Site | ||
from django.core.management import call_command, CommandError | ||
|
||
from ecommerce.referrals.models import Referral | ||
from ecommerce.tests.testcases import TestCase | ||
|
||
|
||
class AddSiteToReferralsCommandTests(TestCase): | ||
command = 'add_site_to_referrals' | ||
|
||
def setUp(self): | ||
super(AddSiteToReferralsCommandTests, self).setUp() | ||
self.site = Site.objects.create(domain='acme.fake') | ||
site = Site.objects.create(domain='test.fake') | ||
self.associated_referrals = [Referral.objects.create(basket_id=i, site=site) for i in range(0, 2)] | ||
self.unassociated_referrals = [Referral.objects.create(basket_id=i) for i in range(3, 6)] | ||
|
||
def test_without_commit(self): | ||
""" Verify the command does not modify any referrals, if the commit flag is not specified. """ | ||
queryset = Referral.objects.filter(site__isnull=True) | ||
expected = queryset.count() | ||
|
||
# Call the command with dry-run flag | ||
out = StringIO() | ||
call_command(self.command, site_id=self.site.id, commit=False, stdout=out) | ||
|
||
# Verify no referrals affected | ||
self.assertEqual(queryset.count(), expected) | ||
|
||
# Verify the number of referrals expected to be deleted was printed to stdout | ||
expected = ''.join( | ||
[ | ||
'This has been an example operation. If the --commit flag had been included, the command ', | ||
'would have associated [{}] referrals with site [{}].'.format( | ||
len(self.unassociated_referrals), self.site | ||
) | ||
] | ||
) | ||
self.assertEqual(out.getvalue().strip(), expected) | ||
|
||
def test_with_commit(self): | ||
""" Verify the command adds a site to referrals without one. """ | ||
queryset = Referral.objects.filter(site=self.site) | ||
|
||
# There should be no referrals associated with the site | ||
self.assertEqual(queryset.count(), 0) | ||
|
||
# Call the command | ||
out = StringIO() | ||
call_command(self.command, site_id=self.site.id, commit=True, stdout=out) | ||
|
||
# The referrals should be associated with the site | ||
self.assertEqual(queryset.count(), 3) | ||
|
||
# There should be no unassociated referrals | ||
self.assertEqual(Referral.objects.filter(site__isnull=True).count(), 0) | ||
|
||
# Verify info was output to stdout | ||
actual = out.getvalue().strip() | ||
self.assertTrue( | ||
actual.startswith( | ||
'Associating [{count}] referrals with site [{site}]..'.format( | ||
count=len(self.unassociated_referrals), | ||
site=self.site | ||
) | ||
) | ||
) | ||
self.assertTrue(actual.endswith('Done.')) | ||
|
||
def test_without_site_id(self): | ||
""" Verify an error is raised if no site ID is specified. """ | ||
with self.assertRaisesMessage(CommandError, 'A valid Site ID must be specified!'): | ||
call_command(self.command, commit=False) |