Skip to content

Commit

Permalink
Update tests
Browse files Browse the repository at this point in the history
  • Loading branch information
ababic committed Jul 6, 2024
1 parent 33c27cb commit b76bd56
Showing 1 changed file with 96 additions and 2 deletions.
98 changes: 96 additions & 2 deletions tests/test_bynderassetcopymixin.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,12 @@

import responses

from django.db import IntegrityError
from django.http import HttpRequest
from django.test import TestCase
from django.utils.functional import cached_property
from django.views.generic.base import View
from testapp.factories import CustomImageFactory
from wagtail.images import get_image_model
from wagtail_factories import ImageFactory

Expand All @@ -17,8 +22,13 @@
class BynderAssetCopyMixinTests(TestCase):
def setUp(self):
super().setUp()
self.view = BynderAssetCopyMixin()
self.view.model = get_image_model()
request = HttpRequest()
request.method = ""
request.path = "/"

self.view = self.view_class()
self.view.setup(request)

# Mock out Bynder API calls
responses.add(
responses.GET,
Expand All @@ -27,6 +37,20 @@ def setUp(self):
status=200,
)

@cached_property
def view_class(self) -> type[BynderAssetCopyMixin]:
"""
Use the mixin to create a functioning view class
that can be used in tests for this class.
"""

class TestViewClass(BynderAssetCopyMixin, View):
"""A basic view class utilising BynderAssetCopyMixin"""

model = get_image_model()

return TestViewClass

@responses.activate
def test_create_object(self):
# After fetching the data from bynder, the method should create a
Expand Down Expand Up @@ -94,3 +118,73 @@ def test_update_object_when_object_is_outdated(self):
is_up_to_date_mock.assert_called_once_with(TEST_ASSET_DATA)
update_from_asset_data_mock.assert_called_once_with(TEST_ASSET_DATA)
save_mock.assert_called_once()

@responses.activate
def test_create_object_clash_handling_after_update(self):
# Create an image with a matching bynder_id
existing = CustomImageFactory.create(bynder_id=TEST_ASSET_ID)

# Trigger the test target directly
with mock.patch.object(
self.view.model, "update_from_asset_data"
) as update_from_asset_data_mock:
result = self.view.create_object(TEST_ASSET_ID)

# Check behavior and result
update_from_asset_data_mock.assert_called_once_with(TEST_ASSET_DATA)
self.assertEqual(result, existing)

@responses.activate
def test_create_object_clash_handling_on_save(self):
def create_dupe_and_throw_integrity_error():
CustomImageFactory.create(bynder_id=TEST_ASSET_ID)
raise IntegrityError("bynder_id must be unique")

with (
# Patch update_from_asset_data() to prevent download attempts
# and other unnecessary work
mock.patch.object(
self.view.model,
"update_from_asset_data",
) as update_from_asset_data_mock,
# Patch save() to trigger our custom code
mock.patch.object(
self.view.model,
"save",
side_effect=create_dupe_and_throw_integrity_error,
) as save_mock,
):
# The IntegrityError should be captured, and the object
# that was saved previously should be found and returned
result = self.view.create_object(TEST_ASSET_ID)

update_from_asset_data_mock.assert_called_once_with(TEST_ASSET_DATA)
save_mock.assert_called_once()
self.assertEqual(result.bynder_id, TEST_ASSET_ID)

@responses.activate
def test_create_object_clash_handling_on_save_when_bynder_id_match_not_found(self):
def throw_integrity_error():
raise IntegrityError("Some other field must be unique")

with (
# Patch update_from_asset_data() to prevent download attempts
# and other unnecessary work
mock.patch.object(
self.view.model,
"update_from_asset_data",
) as update_from_asset_data_mock,
# Patch save() to trigger our custom code
mock.patch.object(
self.view.model,
"save",
side_effect=throw_integrity_error,
) as save_mock,
self.assertRaises(IntegrityError),
):
# With no 'bynder_id' match to be found, the error is allowed
# to bubble up
self.view.create_object(TEST_ASSET_ID)

update_from_asset_data_mock.assert_called_once_with(TEST_ASSET_DATA)
save_mock.assert_called_once()

0 comments on commit b76bd56

Please sign in to comment.