Mercurial > public > sg101
view potd/tests/test_receivers.py @ 943:cf9918328c64
Haystack tweaks for Django 1.7.7.
I had to upgrade to Haystack 2.3.1 to get it to work with Django
1.7.7. I also had to update the Xapian backend. But I ran into
problems.
On my laptop anyway (Ubuntu 14.0.4), xapian gets mad when search terms
are greater than 245 chars (or something) when indexing. So I created
a custom field that would simply omit terms greater than 64 chars and
used this field everywhere I previously used a CharField.
Secondly, the custom search form was broken now. Something changed in
the Xapian backend and exact searches stopped working. Fortunately the
auto_query (which I was using originally and broke during an upgrade)
started working again. So I cut the search form back over to doing an
auto_query. I kept the form the same (3 fields) because I didn't want
to change the form and I think it's better that way.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Wed, 13 May 2015 20:25:07 -0500 |
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')