import unittest from unittest.mock import patch import pytest from django.test import TestCase from django.db import IntegrityError from pyblackbird_cc.resources.factories import PDFPageSnapshotModelFactory from pyblackbird_cc.resources.models import PDFPageSnapshot from pyblackbird_cc.resources.models import PDFResource from pyblackbird_cc.resources.models import Resource from pyblackbird_cc.resources.models import ResourceCategory from pyblackbird_cc.resources.models import ResourceType from pyblackbird_cc.resources.views import ResourceInfo from pyblackbird_cc.resources.views import _extract_metadata_from_resource from pyblackbird_cc.resources.factories import ResourceModelFactory # TODO - convert this test into the test of a function # that takes a Resource object and returns all the PDF snapshots # file names @pytest.mark.django_db() def test_resource_model(resources): # Create a resource r1 = resources[0] # Get the first pdf resource on the resource pdf_on_rw = r1.pdf_resources.first() # Create a single pdf_page_shapshot and associate it with the pdf resource on the resource pdf_page_snapshot = PDFPageSnapshotModelFactory(pdf_file=pdf_on_rw) assert Resource.objects.filter(name="Default Resource 1").exists() assert "test_0.pdf" in r1.get_pdf_file_names() assert "test_1.pdf" in r1.get_pdf_file_names() assert "test_2.pdf" in r1.get_pdf_file_names() assert "test_3.pdf" not in r1.get_pdf_file_names() assert "pdf_page_snapshot_0.jpg" in r1.get_pdf_snapshot_file_names() @pytest.mark.django_db() def test_can_add_feature_slots_to_resource(): r = ResourceModelFactory() r.feature_slot = 1 r.save() assert r.feature_slot == 1 @pytest.mark.django_db() def test_resource_slot_int_must_be_unique(): """ Test that a resource feature slot must be unique. """ r1 = ResourceModelFactory() r2 = ResourceModelFactory() r1.feature_slot = 1 r1.save() r2.feature_slot = 1 with pytest.raises(IntegrityError): r2.save() class ResourceModelTest(TestCase): def test_string_representation(self): resource = Resource(name="Test Resource") assert str(resource) == "Test Resource" @unittest.skip("Skipping this test for now as it is broken") class TestExtractMetadata(TestCase): @patch("resources.views.get_presigned_obj_url") def test_extract_metadata_from_resource(self, mock_get_url): # Create mock instances of ResourceType and ResourceCategory mock_resource_type = ResourceType.objects.create(name="Test Type") mock_main_category = ResourceCategory.objects.create(name="Test Main Category") mock_resource = Resource( name="Test Resource", thumbnail_filenames=["thumb.jpg", "thumb2.jpg"], created_at="2022-01-01", updated_at="2022-01-02", resource_type=mock_resource_type, main_resource_category=mock_main_category, age_range="5-7", ) mock_get_url.return_value = "https://example.com/url" result = _extract_metadata_from_resource(mock_resource) self.assertIsInstance(result, ResourceInfo) assert result.name == "Test Resource" assert result.pdf_filenames == "test.pdf" assert result.thumbnail_filenames in ["thumb.jpg", "thumb2.jpg"] assert result.created == "2022-01-01" assert result.updated == "2022-01-02" @unittest.skip("These tests will not run because they rely upon the view to get file size, etc.") class TestPDFResourceModel(TestCase): def setUp(self): self.resource_type = ResourceType.objects.create(name="Test Resource Type") self.resource_category = ResourceCategory.objects.create(name="Test Resource Category") self.resource = Resource.objects.create( name="Test Resource", resource_type=self.resource_type, main_resource_category=self.resource_category, age_range="5-7", curriculum="English", description="Test Description", ) self.pdf_resource = PDFResource.objects.create( resource=self.resource, file_name="resources/tests/testdata/test_small_file.pdf", ) self.pdf_page_snapshot = PDFPageSnapshot.objects.create( name="Test Thumbnail Image", file_name="test_resource_1.jpg", pdf_file=self.pdf_resource, ) def test_pdf_resource_string_representation(self): self.assertEqual(str(self.resource), "Test Resource") def test_get_pdf_snapshot_filenames(self): self.assertEqual(self.pdf_resource.snapshot_file_names(), ["test_resource_1.jpg"])