Skip to content
This repository has been archived by the owner on Nov 4, 2024. It is now read-only.

Commit

Permalink
feat: changes to upgrad django-oscar to version 3.2
Browse files Browse the repository at this point in the history
  • Loading branch information
zubair-ce07 committed Aug 31, 2023
1 parent b5a96f1 commit c1436fa
Show file tree
Hide file tree
Showing 68 changed files with 564 additions and 130 deletions.
4 changes: 2 additions & 2 deletions ecommerce/core/tests/test_create_demo_data.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,12 +23,12 @@ def assert_seats_created(self, course_id, course_title, price):
audit_seat = seats[1]
self.assertFalse(hasattr(audit_seat.attr, 'certificate_type'))
self.assertFalse(audit_seat.attr.id_verification_required)
self.assertEqual(audit_seat.stockrecords.get(partner=self.partner).price_excl_tax, 0)
self.assertEqual(audit_seat.stockrecords.get(partner=self.partner).price, 0)

verified_seat = seats[0]
self.assertEqual(verified_seat.attr.certificate_type, 'verified')
self.assertTrue(verified_seat.attr.id_verification_required)
self.assertEqual(verified_seat.stockrecords.get(partner=self.partner).price_excl_tax, price)
self.assertEqual(verified_seat.stockrecords.get(partner=self.partner).price, price)

@responses.activate
def test_handle(self):
Expand Down
2 changes: 1 addition & 1 deletion ecommerce/core/tests/test_generate_courses.py
Original file line number Diff line number Diff line change
Expand Up @@ -192,5 +192,5 @@ def test_create_seat(self, seat_type, mock_logger):
course = Course.objects.get(id='course-v1:test-course-generator+1+1')
seats = course.seat_products
seat = seats[0]
self.assertEqual(seat.stockrecords.get(partner=self.partner).price_excl_tax, price)
self.assertEqual(seat.stockrecords.get(partner=self.partner).price, price)
mock_logger.info.assert_any_call("%s has been set to %s", seat_type, True)
2 changes: 1 addition & 1 deletion ecommerce/coupons/tests/test_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ def test_is_voucher_applied(self):
"""
Verify is_voucher_applied return correct value.
"""
product = ProductFactory(stockrecords__price_excl_tax=100)
product = ProductFactory(stockrecords__price=100)
voucher, product = prepare_voucher(
_range=RangeFactory(products=[product]),
benefit_value=10
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,7 @@ def get_course_info(course):
if len(seats) == 1:
seat = seats[0]
seat_type = getattr(seat.attr, 'certificate_type', '').lower()
price = seat.stockrecords.all()[0].price_excl_tax
price = seat.stockrecords.all()[0].price
id_verification_required = getattr(seat.attr, 'id_verification_required', False)

return seat_type, price, id_verification_required
Expand Down
4 changes: 2 additions & 2 deletions ecommerce/courses/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -248,7 +248,7 @@ def create_or_update_seat(
course_id
)

stock_record.price_excl_tax = price
stock_record.price = price
stock_record.price_currency = settings.OSCAR_DEFAULT_CURRENCY
stock_record.save()

Expand Down Expand Up @@ -325,7 +325,7 @@ def _create_or_update_enrollment_code(self, seat_type, id_verification_required,
partner_sku=enrollment_code_sku
)

stock_record.price_excl_tax = price
stock_record.price = price
stock_record.price_currency = settings.OSCAR_DEFAULT_CURRENCY
stock_record.save()

Expand Down
2 changes: 1 addition & 1 deletion ecommerce/courses/publishers.py
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ def serialize_seat_for_commerce_api(self, seat):
return {
'name': mode_for_product(seat),
'currency': stock_record.price_currency,
'price': int(stock_record.price_excl_tax),
'price': int(stock_record.price),
'sku': stock_record.partner_sku,
'bulk_sku': bulk_sku,
'expires': self.get_seat_expiration(seat),
Expand Down
4 changes: 2 additions & 2 deletions ecommerce/courses/tests/test_models.py
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@ def assert_course_seat_valid(self, seat, course, certificate_type, id_verificati
self.assertEqual(getattr(seat.attr, 'certificate_type', ''), certificate_type)
self.assertEqual(seat.attr.course_key, course.id)
self.assertEqual(seat.attr.id_verification_required, id_verification_required)
self.assertEqual(seat.stockrecords.first().price_excl_tax, price)
self.assertEqual(seat.stockrecords.first().price, price)

if credit_provider:
self.assertEqual(seat.attr.credit_provider, credit_provider)
Expand Down Expand Up @@ -157,7 +157,7 @@ def test_create_seat_with_enrollment_code(self):
self.assertIsNone(enrollment_code.expires)

stock_record = StockRecord.objects.get(product=enrollment_code)
self.assertEqual(stock_record.price_excl_tax, price)
self.assertEqual(stock_record.price, price)
self.assertEqual(stock_record.price_currency, settings.OSCAR_DEFAULT_CURRENCY)
self.assertEqual(stock_record.partner, self.partner)

Expand Down
6 changes: 3 additions & 3 deletions ecommerce/courses/tests/test_publishers.py
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,7 @@ def test_serialize_seat_for_commerce_api(self):
expected = {
'name': 'verified',
'currency': 'USD',
'price': int(stock_record.price_excl_tax),
'price': int(stock_record.price),
'sku': stock_record.partner_sku,
'bulk_sku': None,
'expires': None,
Expand Down Expand Up @@ -161,7 +161,7 @@ def test_serialize_seat_for_commerce_api_with_professional(self, is_verified, ex
expected = {
'name': expected_mode,
'currency': 'USD',
'price': int(stock_record.price_excl_tax),
'price': int(stock_record.price),
'sku': stock_record.partner_sku,
'bulk_sku': None,
'expires': None,
Expand All @@ -177,7 +177,7 @@ def test_serialize_seat_with_enrollment_code(self):
expected = {
'name': 'verified',
'currency': 'USD',
'price': int(stock_record.price_excl_tax),
'price': int(stock_record.price),
'sku': stock_record.partner_sku,
'bulk_sku': ec_stock_record.partner_sku,
'expires': None,
Expand Down
6 changes: 3 additions & 3 deletions ecommerce/credit/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -154,12 +154,12 @@ def _get_providers_detail(self, credit_seats):
if code:
discount = format_benefit_value(voucher.benefit)
if discount_type == 'Percentage':
new_price = stockrecord.price_excl_tax - (stockrecord.price_excl_tax * (discount_value / 100))
new_price = stockrecord.price - (stockrecord.price * (discount_value / 100))
else:
new_price = stockrecord.price_excl_tax - discount_value
new_price = stockrecord.price - discount_value
new_price = '{0:.2f}'.format(new_price)
providers_dict[seat.attr.credit_provider].update({
'price': stockrecord.price_excl_tax,
'price': stockrecord.price,
'sku': stockrecord.partner_sku,
'credit_hours': seat.attr.credit_hours,
'discount': discount,
Expand Down
2 changes: 1 addition & 1 deletion ecommerce/enterprise/conditions.py
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ def is_offer_max_discount_available(basket, offer):

def _get_basket_discount_value(basket, offer):
"""Calculate the discount value based on benefit type and value"""
sum_basket_lines = basket.all_lines().aggregate(total=Sum('stockrecord__price_excl_tax'))['total'] or Decimal(0.0)
sum_basket_lines = basket.all_lines().aggregate(total=Sum('stockrecord__price'))['total'] or Decimal(0.0)
# calculate discount value that will be covered by the offer
benefit_type = get_benefit_type(offer.benefit)
benefit_value = offer.benefit.value
Expand Down
4 changes: 2 additions & 2 deletions ecommerce/enterprise/tests/test_conditions.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ def setUp(self):
self.user = UserFactory()
self.condition = factories.EnterpriseCustomerConditionFactory()

self.test_product = ProductFactory(stockrecords__price_excl_tax=10, categories=[])
self.test_product = ProductFactory(stockrecords__price=10, categories=[])
self.course_run_1 = CourseFactory(partner=self.partner)
self.course_run_1.create_or_update_seat('verified', True, Decimal(100))

Expand Down Expand Up @@ -227,7 +227,7 @@ def test_is_satisfied_free_basket(self):
offer = factories.EnterpriseOfferFactory(partner=self.partner, condition=self.condition)
basket = BasketFactory(site=self.site, owner=self.user)
test_product = factories.ProductFactory(
stockrecords__price_excl_tax=0,
stockrecords__price=0,
stockrecords__partner__short_code='test'
)
basket.add_product(test_product)
Expand Down
8 changes: 4 additions & 4 deletions ecommerce/entitlements/tests/test_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ def test_course_entitlement_creation(self):
self.assertEqual(product.attr.UUID, 'foo-bar')

stock_record = StockRecord.objects.get(product=product, partner=self.partner)
self.assertEqual(stock_record.price_excl_tax, 100)
self.assertEqual(stock_record.price, 100)

def test_course_entitlement_update(self):
""" Test course entitlement product update """
Expand All @@ -29,16 +29,16 @@ def test_course_entitlement_update(self):
assert product.attr.variant_id == original_variant_id
stock_record = StockRecord.objects.get(product=product, partner=self.partner)

self.assertEqual(stock_record.price_excl_tax, 100)
self.assertEqual(stock_record.price, 100)
self.assertEqual(product.title, 'Course Foo Bar Entitlement')

new_variant_id = '11111111-1111-1111-1111-11111111'
product = create_or_update_course_entitlement(
'verified', 200, self.partner, 'foo-bar', 'Foo Bar Entitlement', variant_id=new_variant_id)

stock_record = StockRecord.objects.get(product=product, partner=self.partner)
self.assertEqual(stock_record.price_excl_tax, 200)
self.assertEqual(stock_record.price_excl_tax, 200)
self.assertEqual(stock_record.price, 200)
self.assertEqual(stock_record.price, 200)

product.refresh_from_db()
assert product.attr.variant_id == new_variant_id
2 changes: 1 addition & 1 deletion ecommerce/entitlements/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ def create_or_update_course_entitlement(
'product': course_entitlement,
'partner': partner,
'partner_sku': generate_sku(course_entitlement, partner),
'price_excl_tax': price,
'price': price,
'price_currency': settings.OSCAR_DEFAULT_CURRENCY,
}
)
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# Generated by Django 3.2.20 on 2023-08-24 10:28

from django.db import migrations


class Migration(migrations.Migration):

dependencies = [
('analytics', '0002_auto_20140827_1705'),
]

operations = [
migrations.AlterModelOptions(
name='userproductview',
options={'ordering': ['-pk'], 'verbose_name': 'User product view', 'verbose_name_plural': 'User product views'},
),
migrations.AlterModelOptions(
name='usersearch',
options={'ordering': ['-pk'], 'verbose_name': 'User search query', 'verbose_name_plural': 'User search queries'},
),
]
6 changes: 3 additions & 3 deletions ecommerce/extensions/api/serializers.py
Original file line number Diff line number Diff line change
Expand Up @@ -327,18 +327,18 @@ class StockRecordSerializer(serializers.ModelSerializer):

class Meta:
model = StockRecord
fields = ('id', 'product', 'partner', 'partner_sku', 'price_currency', 'price_excl_tax',)
fields = ('id', 'product', 'partner', 'partner_sku', 'price_currency', 'price',)


class PartialStockRecordSerializerForUpdate(StockRecordSerializer):
""" Stock record objects serializer for PUT requests.
Allowed fields to update are 'price_currency' and 'price_excl_tax'.
Allowed fields to update are 'price_currency' and 'price'.
"""

class Meta:
model = StockRecord
fields = ('price_currency', 'price_excl_tax',)
fields = ('price_currency', 'price',)


class ProductSerializer(ProductPaymentInfoMixin, serializers.HyperlinkedModelSerializer):
Expand Down
2 changes: 1 addition & 1 deletion ecommerce/extensions/api/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ def format_seat(seat):
result = seat_template.format(
course.name,
stock_record.partner_sku,
stock_record.price_excl_tax,
stock_record.price,
)
return result

Expand Down
2 changes: 1 addition & 1 deletion ecommerce/extensions/api/v2/tests/views/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -87,5 +87,5 @@ def serialize_stockrecord(self, stockrecord):
'product': stockrecord.product.id,
'partner_sku': stockrecord.partner_sku,
'price_currency': stockrecord.price_currency,
'price_excl_tax': str(stockrecord.price_excl_tax),
'price': str(stockrecord.price),
}
18 changes: 9 additions & 9 deletions ecommerce/extensions/api/v2/tests/views/test_baskets.py
Original file line number Diff line number Diff line change
Expand Up @@ -79,23 +79,23 @@ def setUp(self):
parent=self.base_product,
title='LP 560-4',
stockrecords__partner_sku=self.PAID_SKU,
stockrecords__price_excl_tax=Decimal('180000.00'),
stockrecords__price=Decimal('180000.00'),
stockrecords__partner__short_code='oscr',
)
factories.ProductFactory(
structure='child',
parent=self.base_product,
title=u'Papier-mâché',
stockrecords__partner_sku=self.ALTERNATE_FREE_SKU,
stockrecords__price_excl_tax=Decimal('0.00'),
stockrecords__price=Decimal('0.00'),
stockrecords__partner__short_code='otto',
)
factories.ProductFactory(
structure='child',
parent=self.base_product,
title='LP 570-4 Superleggera',
stockrecords__partner_sku=self.ALTERNATE_PAID_SKU,
stockrecords__price_excl_tax=Decimal('240000.00'),
stockrecords__price=Decimal('240000.00'),
stockrecords__partner__short_code='dummy',
)
# Ensure that the basket attribute type exists for these tests
Expand Down Expand Up @@ -403,7 +403,7 @@ def setUp(self):
self.products = ProductFactory.create_batch(3, stockrecords__partner=self.partner, categories=[])
self.path = reverse('api:v2:baskets:calculate')
self.range = factories.RangeFactory(includes_all_products=True)
self.product_total = sum(product.stockrecords.first().price_excl_tax for product in self.products)
self.product_total = sum(product.stockrecords.first().price for product in self.products)
self.user = self._login_as_user(is_staff=True)
self.url = self._generate_sku_url(self.products, username=self.user.username)

Expand Down Expand Up @@ -597,7 +597,7 @@ def test_basket_calculate_by_staff_user_other_username(self, mock_get_lms_resour
products, url = self.setup_other_user_basket_calculate()

expected = {
'total_incl_tax_excl_discounts': sum(product.stockrecords.first().price_excl_tax
'total_incl_tax_excl_discounts': sum(product.stockrecords.first().price
for product in products),
'total_incl_tax': Decimal('0.00'),
'currency': 'USD'
Expand All @@ -623,7 +623,7 @@ def test_basket_calculate_by_staff_user_other_username_non_atomic(
products, url = self.setup_other_user_basket_calculate()

expected = {
'total_incl_tax_excl_discounts': sum(product.stockrecords.first().price_excl_tax
'total_incl_tax_excl_discounts': sum(product.stockrecords.first().price
for product in products),
'total_incl_tax': Decimal('0.00'),
'currency': 'USD'
Expand Down Expand Up @@ -691,7 +691,7 @@ def test_basket_calculate_anonymous_skip_lms(self, mock_get_lms_resource_for_use
products, url = self._setup_anonymous_basket_calculate()

expected = {
'total_incl_tax_excl_discounts': sum(product.stockrecords.first().price_excl_tax
'total_incl_tax_excl_discounts': sum(product.stockrecords.first().price
for product in products),
'total_incl_tax': Decimal('0.00'),
'currency': 'USD'
Expand Down Expand Up @@ -867,7 +867,7 @@ def test_basket_calculate_by_staff_user_invalid_username(self, mock_get_lms_reso
url = self._generate_sku_url(products, username='invalidusername')

expected = {
'total_incl_tax_excl_discounts': sum(product.stockrecords.first().price_excl_tax
'total_incl_tax_excl_discounts': sum(product.stockrecords.first().price
for product in products[1:]),
'total_incl_tax': Decimal('300.00'),
'currency': 'USD'
Expand Down Expand Up @@ -932,7 +932,7 @@ def _create_program_with_courses_and_offer(self):
products.append(
factories.ProductFactory(
stockrecords__partner=self.partner,
stockrecords__price_excl_tax=Decimal('10.00'),
stockrecords__price=Decimal('10.00'),
stockrecords__partner_sku=sku,
))
return products, program_uuid
Expand Down
2 changes: 1 addition & 1 deletion ecommerce/extensions/api/v2/tests/views/test_coupons.py
Original file line number Diff line number Diff line change
Expand Up @@ -682,7 +682,7 @@ def test_update_coupon_price(self):
new_coupon = Product.objects.get(id=self.coupon.id)
stock_records = StockRecord.objects.filter(product=new_coupon).all()
for stock_record in stock_records:
self.assertEqual(stock_record.price_excl_tax, 77)
self.assertEqual(stock_record.price, 77)

def test_update_note(self):
path = reverse('api:v2:coupons-detail', kwargs={'pk': self.coupon.id})
Expand Down
8 changes: 4 additions & 4 deletions ecommerce/extensions/api/v2/tests/views/test_orders.py
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,7 @@ def test_orders_api_attributes_for_receipt_mfe(
course = CourseFactory(id=course_id, name='Test Course', partner=self.partner)
product = factories.ProductFactory(
categories=[],
stockrecords__price_excl_tax=price,
stockrecords__price=price,
stockrecords__price_currency=currency
)
basket = factories.BasketFactory(owner=self.user, site=self.site)
Expand Down Expand Up @@ -797,14 +797,14 @@ def test_create_manual_order_with_date_placed(self):

time_at_initial_price = datetime.now(pytz.utc).isoformat()

stock_record.price_excl_tax = price_1
stock_record.price = price_1
stock_record.save()
stock_record.price_excl_tax = price_2
stock_record.price = price_2
stock_record.save()

time_at_price_2 = datetime.now(pytz.utc).isoformat()

stock_record.price_excl_tax = final_price
stock_record.price = final_price
stock_record.save()

time_at_final_price = datetime.now(pytz.utc).isoformat()
Expand Down
4 changes: 2 additions & 2 deletions ecommerce/extensions/api/v2/tests/views/test_publication.py
Original file line number Diff line number Diff line change
Expand Up @@ -230,7 +230,7 @@ def assert_entitlement_saved(self, course, expected):
self.assertEqual(entitlement.parent.product_class.name, COURSE_ENTITLEMENT_PRODUCT_CLASS_NAME)
self.assertEqual(entitlement.attr.certificate_type, certificate_type)
self.assertEqual(entitlement.attr.UUID, self.course_uuid)
self.assertEqual(entitlement.stockrecords.get(partner=self.partner).price_excl_tax, expected['price'])
self.assertEqual(entitlement.stockrecords.get(partner=self.partner).price, expected['price'])

def assert_seat_saved(self, course, expected):
certificate_type = ''
Expand All @@ -251,7 +251,7 @@ def assert_seat_saved(self, course, expected):
# Verify product price and expiration time.
expires = EXPIRES if expected['expires'] else None
self.assertEqual(seat.expires, expires)
self.assertEqual(seat.stockrecords.get(partner=self.partner).price_excl_tax, expected['price'])
self.assertEqual(seat.stockrecords.get(partner=self.partner).price, expected['price'])

return seat

Expand Down
Loading

0 comments on commit c1436fa

Please sign in to comment.