|
|
import unittest
from unittest.mock import patch
import pytest
from django.db import IntegrityError
from django.test import TestCase
from pyblackbird_cc.resources.factories import PDFPageSnapshotModelFactory
from pyblackbird_cc.resources.factories import ResourceModelFactory
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
# 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"])
|