view gpp/potd/tests/tools_tests.py @ 552:9e42e6618168

For bitbucket issue #2, tweak the admin settings for the Post model to reduce slow queries. Define our own queryset() method so we can control the select_related(), and not have it cascade from post to topics to forums to categories. Removed 'topic' from list_display because MySQL still sucked with 2 inner joins. Now it seems to be tolerable with only one join to User.
author Brian Neal <bgneal@gmail.com>
date Wed, 25 Jan 2012 20:07:03 -0600
parents ae89ba801e8b
children
line wrap: on
line source
"""
Tests for the pick_potd() function.

"""
from django.test import TestCase
from django.contrib.auth.models import User

from potd.models import Current, Photo, Sequence
from potd.tools import pick_potd


class PickPotdTest(TestCase):

    fixtures = ['potd_test.json']

    def test_pick(self):

        pick_potd()

        curr = Current.objects.get(pk=1)
        self.assertEqual(curr.potd.pk, 2)

    def test_shuffle(self):

        photo = Photo.objects.get(pk=3)
        curr = Current.objects.get(pk=1)
        curr.potd = photo
        curr.save()

        pick_potd()

        ids = Sequence.objects.get(pk=1).seq.split(',')
        curr = Current.objects.get(pk=1)
        self.assertEqual(len(ids), 3)
        self.assertEqual(curr.potd.pk, int(ids[0]))