view potd/tests/test_receivers.py @ 1037:7e0c3cbd3cda

Fix bad select_related call. In Django 1.8, select_related now throws an error if you give it an invalid field. This was happening. Fix that query. Also noticed an extra query generated in the display_post template. Fixed.
author Brian Neal <bgneal@gmail.com>
date Tue, 29 Dec 2015 22:21:42 -0600
parents 0aa9aeaa98a6
children
line wrap: on
line source
"""Tests for potd signal handlers."""
from django.contrib.auth.models import User
from django.test import TestCase

from mock import Mock

from potd.models import Photo, Sequence, Current


class PotdSignalRcvrTestCase(TestCase):

    fixtures = ['potd_test.json']

    def test_on_photo_save(self):
        user = User.objects.get(pk=1)
        photo = Photo(photo='/tmp/1.jpg',
                      caption='caption',
                      description='desc',
                      user=user)
        photo.generate_thumb = Mock()
        photo.save()

        current = Current.objects.get_current_id()
        self.assertTrue(current != photo.pk)

        seq = Sequence.objects.get(pk=1)
        expected = '1,{},2,3'.format(photo.pk)
        self.assertEqual(seq.seq, expected)

    def test_on_photo_delete(self):
        photo = Photo.objects.get(pk=2)
        photo.delete()
        seq = Sequence.objects.get(pk=1)
        self.assertEqual(seq.seq, '1,3')