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 ad79ae9 commit 961e6fd
Showing 1 changed file with 98 additions and 3 deletions.
101 changes: 98 additions & 3 deletions tests/test_bynderassetcopymixin.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,13 @@

import responses

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

from wagtail_bynder.views.mixins import BynderAssetCopyMixin
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 = CustomImage

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,74 @@ 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")

fake_obj = mock.MagicMock()
fake_obj.save = create_dupe_and_throw_integrity_error

with (
# Patch update_from_asset_data() to prevent download attempts
# and other unnecessary work
mock.patch.object(
self.view.model,
"update_from_asset_data",
),
# Patch build_object_from_data to return a mock with a patched save() method
mock.patch.object(
self.view,
"build_object_from_data",
return_value=fake_obj,
),
):
# 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)

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")

fake_obj = mock.MagicMock()
fake_obj.save = throw_integrity_error

with (
# Patch update_from_asset_data() to prevent download attempts
# and other unnecessary work
mock.patch.object(
self.view.model,
"update_from_asset_data",
),
# Patch build_object_from_data to return a mock with a patched save() method
mock.patch.object(
self.view,
"build_object_from_data",
return_value=fake_obj,
),
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)

0 comments on commit 961e6fd

Please sign in to comment.