2013-06-03 16:31:39 +00:00
|
|
|
"""
|
|
|
|
external library imports
|
|
|
|
"""
|
2011-10-09 18:48:03 +00:00
|
|
|
from datetime import datetime, timedelta
|
2013-06-03 16:31:39 +00:00
|
|
|
from decimal import Decimal as D
|
|
|
|
from math import factorial
|
|
|
|
from time import sleep, mktime
|
|
|
|
from urlparse import parse_qs, urlparse
|
2013-08-29 00:13:35 +00:00
|
|
|
from tempfile import NamedTemporaryFile
|
2013-06-03 16:31:39 +00:00
|
|
|
from celery.task import chord
|
|
|
|
from celery.task.sets import TaskSet
|
2013-08-29 00:13:35 +00:00
|
|
|
import requests
|
|
|
|
import os
|
2011-10-09 18:48:03 +00:00
|
|
|
|
2013-06-03 16:31:39 +00:00
|
|
|
"""
|
|
|
|
django imports
|
|
|
|
"""
|
2011-11-18 00:45:26 +00:00
|
|
|
from django.conf import settings
|
2013-06-03 16:31:39 +00:00
|
|
|
from django.contrib.auth.models import User
|
2012-02-10 01:51:10 +00:00
|
|
|
from django.contrib.comments.models import Comment
|
|
|
|
from django.contrib.contenttypes.models import ContentType
|
|
|
|
from django.contrib.sites.models import Site
|
2013-08-29 00:13:35 +00:00
|
|
|
from django.core.files import File as DjangoFile
|
2013-06-03 16:31:39 +00:00
|
|
|
from django.db import IntegrityError
|
2012-08-29 19:56:14 +00:00
|
|
|
from django.http import Http404
|
2013-06-03 16:31:39 +00:00
|
|
|
from django.test import TestCase
|
|
|
|
from django.test.client import Client
|
|
|
|
from django.test.utils import override_settings
|
|
|
|
from django.utils import unittest
|
2011-08-31 03:46:55 +00:00
|
|
|
|
2013-06-03 16:31:39 +00:00
|
|
|
"""
|
|
|
|
regluit imports
|
|
|
|
"""
|
|
|
|
from regluit.core import (
|
|
|
|
isbn,
|
|
|
|
bookloader,
|
|
|
|
models,
|
|
|
|
search,
|
|
|
|
goodreads,
|
|
|
|
librarything,
|
2013-09-18 21:36:42 +00:00
|
|
|
tasks,
|
|
|
|
parameters,
|
2013-06-03 16:31:39 +00:00
|
|
|
)
|
|
|
|
from regluit.core.models import (
|
|
|
|
Campaign,
|
|
|
|
Work,
|
|
|
|
UnglueitError,
|
|
|
|
Edition,
|
|
|
|
RightsHolder,
|
|
|
|
Claim,
|
|
|
|
Key,
|
|
|
|
Ebook,
|
|
|
|
Premium,
|
|
|
|
Subject,
|
2013-06-17 22:53:21 +00:00
|
|
|
Publisher,
|
add test to reproduce duplicate pubname
Unglue.it error on January 11, 2016 at 5:02 AM:
Traceback (most recent call last):
File
"/opt/regluit/ENV/local/lib/python2.7/site-packages/django/core/handlers
/base.py", line 109, in get_response
response = callback(request, *callback_args, **callback_kwargs)
File "/opt/regluit/frontend/views.py", line 795, in googlebooks
edition = bookloader.add_by_googlebooks_id(googlebooks_id)
File "/opt/regluit/core/bookloader.py", line 343, in
add_by_googlebooks_id
e.set_publisher(d.get('publisher'))
File "/opt/regluit/core/models.py", line 1827, in set_publisher
pub_name = PublisherName.objects.get(name=publisher_name)
File
"/opt/regluit/ENV/local/lib/python2.7/site-packages/django/db/models/man
ager.py", line 131, in get
return self.get_query_set().get(*args, **kwargs)
File
"/opt/regluit/ENV/local/lib/python2.7/site-packages/django/db/models/que
ry.py", line 368, in get
% (self.model._meta.object_name, num, kwargs))
MultipleObjectsReturned: get() returned more than one PublisherName --
it returned 2! Lookup parameters were {'name': u'North-Holland'}
2016-01-18 15:08:58 +00:00
|
|
|
PublisherName,
|
2013-08-22 18:23:47 +00:00
|
|
|
Offer,
|
2013-08-27 22:03:35 +00:00
|
|
|
EbookFile,
|
|
|
|
Acq,
|
2013-11-08 17:13:34 +00:00
|
|
|
Hold,
|
2013-06-03 16:31:39 +00:00
|
|
|
)
|
2013-10-17 02:48:29 +00:00
|
|
|
from regluit.libraryauth.models import Library
|
|
|
|
from regluit.core.parameters import TESTING, LIBRARY, RESERVE
|
2013-06-03 16:31:39 +00:00
|
|
|
from regluit.frontend.views import safe_get_work
|
2011-10-09 18:48:03 +00:00
|
|
|
from regluit.payment.models import Transaction
|
2011-10-08 03:11:57 +00:00
|
|
|
from regluit.payment.parameters import PAYMENT_TYPE_AUTHORIZATION
|
2013-06-03 16:31:39 +00:00
|
|
|
from regluit.utils.localdatetime import now, date_today
|
2013-09-16 01:43:58 +00:00
|
|
|
from regluit.pyepub import EPUB
|
2014-01-15 13:32:55 +00:00
|
|
|
from .epub import test_epub
|
2014-08-28 19:29:41 +00:00
|
|
|
from .pdf import ask_pdf, test_pdf
|
2011-10-14 02:16:28 +00:00
|
|
|
|
2015-08-18 10:57:14 +00:00
|
|
|
YAML_VERSIONFILE = os.path.join(os.path.dirname(__file__), '../test/versiontest.yaml')
|
2015-08-18 18:34:52 +00:00
|
|
|
YAML_HUCKFILE = os.path.join(os.path.dirname(__file__), '../test/raw/master/metadata.yaml')
|
2015-08-18 10:57:14 +00:00
|
|
|
|
2011-12-19 06:33:13 +00:00
|
|
|
class BookLoaderTests(TestCase):
|
2012-04-27 21:29:57 +00:00
|
|
|
def setUp(self):
|
|
|
|
self.user = User.objects.create_user('core_test', 'test@example.org', 'core_test')
|
|
|
|
self.client = Client()
|
|
|
|
self.client.login(username='core_test', password='core_test')
|
2015-07-30 03:01:43 +00:00
|
|
|
|
2015-08-18 10:57:14 +00:00
|
|
|
def test_add_by_local_yaml(self):
|
|
|
|
|
|
|
|
noebook_id = bookloader.load_from_yaml(YAML_VERSIONFILE)
|
|
|
|
noebook = models.Work.objects.get(id=noebook_id)
|
|
|
|
self.assertEqual( noebook.first_ebook(), None)
|
2015-08-18 18:34:52 +00:00
|
|
|
huck_id = bookloader.load_from_yaml(YAML_HUCKFILE)
|
|
|
|
huck = models.Work.objects.get(id=huck_id)
|
2015-09-24 21:58:34 +00:00
|
|
|
self.assertTrue( huck.ebooks().count()>1)
|
2015-08-18 10:57:14 +00:00
|
|
|
|
2015-07-30 03:01:43 +00:00
|
|
|
def test_add_by_yaml(self):
|
2015-08-07 05:21:15 +00:00
|
|
|
space_id = bookloader.load_from_yaml('https://github.com/gitenberg-dev/metadata/raw/master/samples/pandata.yaml')
|
|
|
|
huck_id = bookloader.load_from_yaml('https://github.com/GITenberg/Adventures-of-Huckleberry-Finn_76/raw/master/metadata.yaml')
|
|
|
|
space = models.Work.objects.get(id=space_id)
|
|
|
|
huck = models.Work.objects.get(id=huck_id)
|
2015-01-30 16:33:22 +00:00
|
|
|
|
|
|
|
def test_valid_subject(self):
|
|
|
|
self.assertTrue(bookloader.valid_subject('A, valid, suj\xc3t'))
|
|
|
|
self.assertFalse(bookloader.valid_subject('A, valid, suj\xc3t, '))
|
|
|
|
self.assertFalse(bookloader.valid_subject('A valid suj\xc3t \x01'))
|
2011-08-31 03:46:55 +00:00
|
|
|
|
2011-10-19 03:00:07 +00:00
|
|
|
def test_add_by_isbn(self):
|
2011-09-10 11:36:38 +00:00
|
|
|
# edition
|
2016-01-18 14:59:52 +00:00
|
|
|
edition = bookloader.add_by_isbn('9780444899743')
|
|
|
|
self.assertEqual(edition.title, 'Computers, Communication and Usability')
|
|
|
|
self.assertEqual(edition.publication_date, u'1993')
|
|
|
|
self.assertEqual(edition.publisher, u'North Holland')
|
|
|
|
self.assertEqual(edition.isbn_10, '044489974X')
|
|
|
|
self.assertEqual(edition.isbn_13, '9780444899743')
|
|
|
|
self.assertEqual(edition.googlebooks_id, '0bBQAAAAYAAJ')
|
2011-09-09 05:38:28 +00:00
|
|
|
|
2011-09-10 11:36:38 +00:00
|
|
|
# authors
|
2016-01-18 14:59:52 +00:00
|
|
|
self.assertEqual(edition.authors.all().count(), 3)
|
|
|
|
self.assertEqual(edition.authors.all()[0].name, 'Paul Byerley')
|
2011-10-10 16:57:10 +00:00
|
|
|
|
|
|
|
# work
|
|
|
|
self.assertTrue(edition.work)
|
2016-01-18 14:59:52 +00:00
|
|
|
self.assertEqual(edition.work.googlebooks_id, '0bBQAAAAYAAJ')
|
|
|
|
self.assertEqual(edition.work.first_isbn_13(), '9780444899743')
|
2012-01-17 04:28:34 +00:00
|
|
|
|
2016-01-25 19:08:37 +00:00
|
|
|
# test duplicate pubname
|
add test to reproduce duplicate pubname
Unglue.it error on January 11, 2016 at 5:02 AM:
Traceback (most recent call last):
File
"/opt/regluit/ENV/local/lib/python2.7/site-packages/django/core/handlers
/base.py", line 109, in get_response
response = callback(request, *callback_args, **callback_kwargs)
File "/opt/regluit/frontend/views.py", line 795, in googlebooks
edition = bookloader.add_by_googlebooks_id(googlebooks_id)
File "/opt/regluit/core/bookloader.py", line 343, in
add_by_googlebooks_id
e.set_publisher(d.get('publisher'))
File "/opt/regluit/core/models.py", line 1827, in set_publisher
pub_name = PublisherName.objects.get(name=publisher_name)
File
"/opt/regluit/ENV/local/lib/python2.7/site-packages/django/db/models/man
ager.py", line 131, in get
return self.get_query_set().get(*args, **kwargs)
File
"/opt/regluit/ENV/local/lib/python2.7/site-packages/django/db/models/que
ry.py", line 368, in get
% (self.model._meta.object_name, num, kwargs))
MultipleObjectsReturned: get() returned more than one PublisherName --
it returned 2! Lookup parameters were {'name': u'North-Holland'}
2016-01-18 15:08:58 +00:00
|
|
|
ed2 = Edition.objects.create(work=edition.work)
|
|
|
|
ed2.set_publisher('North Holland')
|
|
|
|
|
2013-03-27 16:51:10 +00:00
|
|
|
# publisher names
|
|
|
|
old_pub_name = edition.publisher_name
|
|
|
|
edition.set_publisher('test publisher name')
|
|
|
|
self.assertEqual(edition.publisher, u'test publisher name')
|
|
|
|
pub = Publisher(name=edition.publisher_name)
|
|
|
|
pub.save()
|
|
|
|
self.assertEqual(edition.work.publishers().count(), 1)
|
|
|
|
old_pub_name.publisher = pub
|
|
|
|
old_pub_name.save()
|
2016-01-18 14:59:52 +00:00
|
|
|
edition.set_publisher(u'North Holland')
|
|
|
|
self.assertEqual(edition.publisher, u'test publisher name') # North Holland has been aliased
|
2012-01-29 03:16:14 +00:00
|
|
|
# locale in language
|
2013-07-29 21:49:18 +00:00
|
|
|
# Obama Dreams from My Father, Chinese edition
|
|
|
|
# http://www.worldcat.org/title/oubama-de-meng-xiang-zhi-lu-yi-fu-zhi-ming/oclc/272997721&referer=brief_results
|
|
|
|
edition = bookloader.add_by_isbn('9789571349268')
|
2014-06-06 18:47:36 +00:00
|
|
|
self.assertEqual(edition.work.language, 'zh-TW')
|
2011-09-10 11:36:38 +00:00
|
|
|
|
2015-11-17 16:00:08 +00:00
|
|
|
@unittest.expectedFailure
|
2012-02-02 14:05:08 +00:00
|
|
|
def test_update_edition(self):
|
|
|
|
w = models.Work(title='silly title', language='xx')
|
|
|
|
w.save()
|
|
|
|
e = models.Edition(title=w.title,work=w)
|
|
|
|
e.save()
|
2015-05-27 19:37:47 +00:00
|
|
|
models.Identifier(type='isbn', value='9781449319793', work=w, edition=e).save()
|
2013-11-15 23:47:02 +00:00
|
|
|
bookloader.update_edition(e)
|
2012-02-02 14:05:08 +00:00
|
|
|
self.assertEqual(e.work.language, 'en')
|
2015-05-27 19:37:47 +00:00
|
|
|
self.assertEqual(e.title, 'Python for Data Analysis')
|
2012-02-02 14:05:08 +00:00
|
|
|
|
2011-09-10 11:36:38 +00:00
|
|
|
def test_double_add(self):
|
2012-07-20 15:40:11 +00:00
|
|
|
bookloader.add_by_isbn('0441007465')
|
|
|
|
bookloader.add_by_isbn('0441007465')
|
2011-10-10 16:57:10 +00:00
|
|
|
self.assertEqual(models.Edition.objects.all().count(), 1)
|
2011-09-10 11:36:38 +00:00
|
|
|
self.assertEqual(models.Author.objects.all().count(), 1)
|
|
|
|
self.assertEqual(models.Work.objects.all().count(), 1)
|
2011-10-10 21:26:38 +00:00
|
|
|
|
|
|
|
def test_missing_isbn(self):
|
2012-01-09 18:55:22 +00:00
|
|
|
e = bookloader.add_by_isbn_from_google('0139391401')
|
2011-10-10 21:26:38 +00:00
|
|
|
self.assertEqual(e, None)
|
2011-09-29 06:23:50 +00:00
|
|
|
|
2011-10-13 01:59:46 +00:00
|
|
|
def test_thingisbn(self):
|
2012-07-20 15:40:11 +00:00
|
|
|
isbns = bookloader.thingisbn('0441007465')
|
2011-10-13 01:59:46 +00:00
|
|
|
self.assertTrue(len(isbns) > 20)
|
2012-07-20 15:40:11 +00:00
|
|
|
self.assertTrue('0441007465' in isbns)
|
2011-10-13 01:59:46 +00:00
|
|
|
self.assertTrue('3453313895' in isbns)
|
|
|
|
|
2011-10-14 04:02:19 +00:00
|
|
|
def test_add_related(self):
|
|
|
|
# add one edition
|
2012-07-20 15:40:11 +00:00
|
|
|
edition = bookloader.add_by_isbn('0441007465')
|
2011-10-14 04:02:19 +00:00
|
|
|
self.assertEqual(models.Edition.objects.count(), 1)
|
|
|
|
self.assertEqual(models.Work.objects.count(), 1)
|
2012-01-10 20:20:02 +00:00
|
|
|
lang=edition.work.language
|
2011-10-14 04:02:19 +00:00
|
|
|
# ask for related editions to be added using the work we just created
|
2012-07-20 15:40:11 +00:00
|
|
|
bookloader.add_related('0441007465')
|
2011-12-13 14:55:26 +00:00
|
|
|
self.assertTrue(models.Edition.objects.count() > 15)
|
2012-01-10 20:20:02 +00:00
|
|
|
self.assertEqual(models.Work.objects.filter(language=lang).count(), 1)
|
2012-02-04 20:40:10 +00:00
|
|
|
self.assertTrue(edition.work.editions.count() > 9)
|
2011-12-13 14:55:26 +00:00
|
|
|
|
|
|
|
|
2011-12-19 06:33:13 +00:00
|
|
|
def test_populate_edition(self):
|
|
|
|
edition = bookloader.add_by_googlebooks_id('c_dBPgAACAAJ')
|
2012-02-16 18:19:36 +00:00
|
|
|
edition = tasks.populate_edition.run(edition.isbn_13)
|
2012-07-30 15:23:38 +00:00
|
|
|
self.assertTrue(edition.work.editions.all().count() > 10)
|
|
|
|
self.assertTrue(edition.work.subjects.all().count() > 8)
|
2012-01-17 04:28:34 +00:00
|
|
|
self.assertTrue(edition.work.publication_date)
|
|
|
|
edition.publication_date = None
|
|
|
|
self.assertTrue(edition.work.publication_date)
|
2012-05-07 05:18:11 +00:00
|
|
|
self.assertTrue(len(edition.work.description) > 20)
|
2012-05-07 02:31:38 +00:00
|
|
|
self.assertTrue(edition.work.identifiers.filter(type='oclc')[0])
|
|
|
|
|
2011-10-14 04:02:19 +00:00
|
|
|
|
2012-02-13 22:35:08 +00:00
|
|
|
def test_merge_works_mechanics(self):
|
|
|
|
"""Make sure then merge_works is still okay when we try to merge works with themselves and with deleted works"""
|
2013-03-01 18:13:14 +00:00
|
|
|
sub1= Subject(name='test1')
|
|
|
|
sub1.save()
|
|
|
|
sub2= Subject(name='test2')
|
|
|
|
sub2.save()
|
2012-02-13 22:35:08 +00:00
|
|
|
w1 = Work(title="Work 1")
|
|
|
|
w1.save()
|
2013-03-01 18:13:14 +00:00
|
|
|
w1.subjects.add(sub1)
|
2012-02-13 22:35:08 +00:00
|
|
|
|
|
|
|
w2 = Work(title="Work 2")
|
|
|
|
w2.save()
|
2013-03-01 18:13:14 +00:00
|
|
|
w2.subjects.add(sub1,sub2)
|
2012-02-13 22:35:08 +00:00
|
|
|
|
|
|
|
e1 = Edition(work=w1)
|
|
|
|
e1.save()
|
|
|
|
|
|
|
|
e2 = Edition(work=w2)
|
|
|
|
e2.save()
|
|
|
|
|
2014-12-13 17:37:35 +00:00
|
|
|
eb1 = Ebook(edition = e2)
|
|
|
|
eb1.save()
|
|
|
|
|
2012-02-13 22:35:08 +00:00
|
|
|
e2a = Edition(work=w2)
|
|
|
|
e2a.save()
|
|
|
|
|
|
|
|
self.assertTrue(e1)
|
|
|
|
self.assertTrue(e2)
|
|
|
|
self.assertTrue(e2a)
|
|
|
|
self.assertTrue(e1.work)
|
|
|
|
self.assertTrue(e2.work)
|
|
|
|
self.assertEqual(models.Work.objects.count(), 2)
|
2014-12-13 17:37:35 +00:00
|
|
|
|
|
|
|
self.assertTrue(w2.is_free)
|
|
|
|
self.assertFalse(w1.is_free)
|
|
|
|
|
2012-02-13 22:35:08 +00:00
|
|
|
w1_id = w1.id
|
|
|
|
w2_id = w2.id
|
|
|
|
|
|
|
|
# first try to merge work 1 into itself -- should not do anything
|
|
|
|
bookloader.merge_works(w1,w1)
|
|
|
|
self.assertEqual(models.Work.objects.count(), 2)
|
|
|
|
|
|
|
|
# merge the second work into the first
|
|
|
|
bookloader.merge_works(e1.work, e2.work)
|
|
|
|
self.assertEqual(models.Work.objects.count(),1)
|
|
|
|
self.assertEqual(models.WasWork.objects.count(),1)
|
2013-03-01 18:13:14 +00:00
|
|
|
self.assertEqual(w1.subjects.count(),2)
|
|
|
|
|
2014-12-13 17:37:35 +00:00
|
|
|
self.assertTrue(w1.is_free)
|
|
|
|
|
2012-02-13 22:35:08 +00:00
|
|
|
# getting proper view?
|
|
|
|
anon_client = Client()
|
|
|
|
r = anon_client.get("/work/%s/" % w1_id)
|
|
|
|
self.assertEqual(r.status_code, 200)
|
|
|
|
r = anon_client.get("/work/%s/" % w2_id)
|
|
|
|
self.assertEqual(r.status_code, 200)
|
|
|
|
|
|
|
|
# try to do it twice -- nothing should happen
|
|
|
|
bookloader.merge_works(e1.work, e2a.work)
|
|
|
|
r = anon_client.get("/work/%s/" % w1_id)
|
|
|
|
self.assertEqual(r.status_code, 200)
|
|
|
|
r = anon_client.get("/work/%s/" % w2_id)
|
|
|
|
self.assertEqual(r.status_code, 200)
|
|
|
|
|
2014-04-14 21:43:06 +00:00
|
|
|
# if the work has a selected edition, then don't touch the work.
|
|
|
|
w3= Work(title='work 3')
|
|
|
|
e_pref= Edition(work=w1)
|
|
|
|
w1.selected_edition=e_pref
|
|
|
|
bookloader.merge_works(w3, w1)
|
|
|
|
self.assertTrue(w1.title=='Work 1')
|
2012-02-13 22:35:08 +00:00
|
|
|
|
2011-10-19 03:00:07 +00:00
|
|
|
def test_merge_works(self):
|
|
|
|
# add two editions and see that there are two stub works
|
2013-07-16 23:08:20 +00:00
|
|
|
|
|
|
|
# for this test, we need two isbns that are considered related in LibraryThing and are both
|
|
|
|
# recognized by Google Books API
|
|
|
|
# see http://nbviewer.ipython.org/70f0b17b9d0c8b9b651b for a way to calculate a match
|
|
|
|
# for a given input ISBN
|
|
|
|
|
|
|
|
# Crawfish Dreams by Nancy Rawles -- what could work once the LT thingisbn cache clears
|
|
|
|
#isbn1 = '0385722133'
|
|
|
|
#isbn2 = '0307425363'
|
|
|
|
|
|
|
|
# RY switched to Atwood's Handmaid's Tale for hopefully longer term resilience for this test
|
|
|
|
isbn1 = '9780395404256'
|
2015-12-19 19:10:51 +00:00
|
|
|
isbn2 = '9780771008795'
|
2013-07-16 23:08:20 +00:00
|
|
|
e1 = bookloader.add_by_isbn(isbn1)
|
|
|
|
e2 = bookloader.add_by_isbn(isbn2)
|
2011-11-06 22:42:09 +00:00
|
|
|
self.assertTrue(e1)
|
|
|
|
self.assertTrue(e2)
|
2011-12-19 06:33:13 +00:00
|
|
|
self.assertTrue(e1.work)
|
|
|
|
self.assertTrue(e2.work)
|
2011-10-19 03:00:07 +00:00
|
|
|
self.assertEqual(models.Work.objects.count(), 2)
|
|
|
|
|
|
|
|
# add the stub works to a wishlist
|
2013-03-06 14:39:06 +00:00
|
|
|
user = User.objects.create_user('test', 'test@example.org', 'testpass')
|
2011-12-08 23:22:05 +00:00
|
|
|
user.wishlist.add_work(e1.work, 'test')
|
|
|
|
user.wishlist.add_work(e2.work, 'test')
|
2013-03-06 14:39:06 +00:00
|
|
|
manager = User.objects.create_user('manager', 'manager@example.org', 'managerpass')
|
2011-10-19 03:47:48 +00:00
|
|
|
# create campaigns for the stub works
|
2011-10-19 03:00:07 +00:00
|
|
|
c1 = models.Campaign.objects.create(
|
|
|
|
name=e1.work.title,
|
2012-05-25 18:52:50 +00:00
|
|
|
work=e1.work,
|
2011-10-19 03:00:07 +00:00
|
|
|
description='Test Campaign 1',
|
2012-03-09 23:31:30 +00:00
|
|
|
deadline=now(),
|
2011-10-19 03:00:07 +00:00
|
|
|
target=D('1000.00'),
|
|
|
|
)
|
|
|
|
c2 = models.Campaign.objects.create(
|
|
|
|
name=e2.work.title,
|
|
|
|
work=e2.work,
|
|
|
|
description='Test Campaign 2',
|
2012-03-09 23:31:30 +00:00
|
|
|
deadline=now(),
|
2011-10-19 03:00:07 +00:00
|
|
|
target=D('1000.00'),
|
|
|
|
)
|
2012-05-25 18:52:50 +00:00
|
|
|
c2.managers.add(manager)
|
|
|
|
c2.save()
|
|
|
|
self.assertEqual(c2.pk, e2.work.last_campaign().pk)
|
2012-02-10 01:51:10 +00:00
|
|
|
# comment on the works
|
|
|
|
site = Site.objects.all()[0]
|
|
|
|
wct = ContentType.objects.get_for_model(models.Work)
|
|
|
|
comment1 = Comment(
|
|
|
|
content_type=wct,
|
|
|
|
object_pk=e1.work.pk,
|
|
|
|
comment="test comment1",
|
|
|
|
user=user,
|
|
|
|
site=site
|
|
|
|
)
|
|
|
|
comment1.save()
|
|
|
|
comment2 = Comment(
|
|
|
|
content_type=wct,
|
|
|
|
object_pk=e2.work.pk,
|
|
|
|
comment="test comment2",
|
|
|
|
user=user,
|
|
|
|
site=site
|
|
|
|
)
|
|
|
|
comment2.save()
|
2012-05-25 18:52:50 +00:00
|
|
|
comment3 = Comment(
|
|
|
|
content_type=wct,
|
|
|
|
object_pk=e2.work.pk,
|
|
|
|
comment="test comment3",
|
|
|
|
user=manager,
|
|
|
|
site=site
|
|
|
|
)
|
|
|
|
comment3.save()
|
|
|
|
|
2012-02-10 01:51:10 +00:00
|
|
|
|
2011-10-19 03:00:07 +00:00
|
|
|
# now add related edition to make sure Works get merged
|
2013-07-16 23:08:20 +00:00
|
|
|
bookloader.add_related(isbn1)
|
|
|
|
# non-zero
|
|
|
|
self.assertGreater(models.Work.objects.count(), 0)
|
|
|
|
w3 = models.Edition.get_by_isbn(isbn1).work
|
2011-10-19 03:00:07 +00:00
|
|
|
|
|
|
|
# and that relevant Campaigns and Wishlists are updated
|
2012-05-25 18:52:50 +00:00
|
|
|
c1=Campaign.objects.get(pk=c1.pk)
|
|
|
|
c2=Campaign.objects.get(pk=c2.pk)
|
2012-05-25 16:52:25 +00:00
|
|
|
|
2011-10-19 03:00:07 +00:00
|
|
|
self.assertEqual(c1.work, c2.work)
|
|
|
|
self.assertEqual(user.wishlist.works.all().count(), 1)
|
2012-05-25 18:52:50 +00:00
|
|
|
self.assertEqual(Comment.objects.for_model(w3).count(), 3)
|
2012-02-10 03:30:33 +00:00
|
|
|
|
|
|
|
anon_client = Client()
|
|
|
|
r = anon_client.get("/work/%s/" % w3.pk)
|
|
|
|
self.assertEqual(r.status_code, 200)
|
|
|
|
r = anon_client.get("/work/%s/" % e2.work.pk)
|
|
|
|
self.assertEqual(r.status_code, 200)
|
|
|
|
|
2011-11-06 21:33:04 +00:00
|
|
|
|
|
|
|
def test_ebook(self):
|
|
|
|
edition = bookloader.add_by_oclc('1246014')
|
2014-02-14 19:18:35 +00:00
|
|
|
# we've seen the public domain status of this book fluctuate -- and the OCLC number can disappear. So if the ebook count is 2 then test
|
|
|
|
if edition is not None and edition.ebooks.count() == 2:
|
2013-12-11 00:17:12 +00:00
|
|
|
#self.assertEqual(edition.ebooks.count(), 2)
|
|
|
|
#ebook_epub = edition.ebooks.all()[0]
|
|
|
|
ebook_epub = edition.ebooks.filter(format='epub')[0]
|
|
|
|
self.assertEqual(ebook_epub.format, 'epub')
|
|
|
|
#self.assertEqual(ebook_epub.url, 'http://books.google.com/books/download/The_Latin_language.epub?id=N1RfAAAAMAAJ&ie=ISO-8859-1&output=epub&source=gbs_api')
|
|
|
|
self.assertEqual(parse_qs(urlparse(ebook_epub.url).query).get("id"), ['N1RfAAAAMAAJ'])
|
|
|
|
self.assertEqual(parse_qs(urlparse(ebook_epub.url).query).get("output"), ['epub'])
|
|
|
|
self.assertEqual(ebook_epub.provider, 'Google Books')
|
|
|
|
self.assertEqual(ebook_epub.set_provider(), 'Google Books')
|
|
|
|
ebook_pdf = edition.ebooks.filter(format='pdf')[0]
|
|
|
|
self.assertEqual(ebook_pdf.format, 'pdf')
|
|
|
|
#self.assertEqual(ebook_pdf.url, 'http://books.google.com/books/download/The_Latin_language.pdf?id=N1RfAAAAMAAJ&ie=ISO-8859-1&output=pdf&sig=ACfU3U2yLt3nmTncB8ozxOWUc4iHKUznCA&source=gbs_api')
|
|
|
|
self.assertEqual(parse_qs(urlparse(ebook_pdf.url).query).get("id"), ['N1RfAAAAMAAJ'])
|
|
|
|
self.assertEqual(parse_qs(urlparse(ebook_pdf.url).query).get("output"), ['pdf'])
|
|
|
|
self.assertEqual(ebook_pdf.provider, 'Google Books')
|
|
|
|
|
|
|
|
w = edition.work
|
|
|
|
self.assertEqual(w.first_epub().url, ebook_epub.url)
|
|
|
|
self.assertEqual(w.first_pdf().url, ebook_pdf.url)
|
|
|
|
self.assertEqual(w.first_epub_url(), ebook_epub.url)
|
|
|
|
self.assertEqual(w.first_pdf_url(), ebook_pdf.url)
|
|
|
|
|
|
|
|
ebook_pdf.url='http://en.wikisource.org/wiki/Frankenstein'
|
|
|
|
self.assertEqual(ebook_pdf.set_provider(), 'Wikisource')
|
|
|
|
|
|
|
|
self.user.wishlist.add_work(w, 'test')
|
|
|
|
tasks.report_new_ebooks(date_today())
|
|
|
|
r = self.client.get("/notification/" )
|
|
|
|
self.assertEqual(r.status_code, 200)
|
|
|
|
|
|
|
|
ebook_pdf.increment()
|
|
|
|
updated_ebook = Ebook.objects.get(pk=ebook_pdf.pk)
|
|
|
|
self.assertEqual(int(updated_ebook.download_count), 1)
|
|
|
|
self.assertEqual(int(edition.work.download_count), 1)
|
2012-04-27 21:29:57 +00:00
|
|
|
|
2011-11-06 22:42:09 +00:00
|
|
|
def test_add_no_ebook(self):
|
|
|
|
# this edition lacks an ebook, but we should still be able to load it
|
2013-02-18 17:17:15 +00:00
|
|
|
# http://books.google.com/books?id=D-WjL_HRbNQC&printsec=frontcover#v=onepage&q&f=false
|
|
|
|
# Social Life of Information
|
|
|
|
e = bookloader.add_by_isbn('1578517087')
|
2011-11-06 22:42:09 +00:00
|
|
|
self.assertTrue(e)
|
|
|
|
|
2012-07-20 16:28:14 +00:00
|
|
|
@unittest.expectedFailure
|
2011-12-13 14:55:26 +00:00
|
|
|
def test_one_language(self):
|
|
|
|
# english edition for cat's cradle should only pull in other
|
|
|
|
# english editions
|
2012-07-20 16:28:14 +00:00
|
|
|
# expected failure right now because Google seems to have bad data about language of Cat's Cradle
|
|
|
|
# e.g., https://www.googleapis.com/books/v1/volumes?q=isbn:9789513033774
|
|
|
|
# title = "Kissan kehto" -- language according to API = English
|
2011-12-13 14:55:26 +00:00
|
|
|
work = bookloader.add_by_isbn('079530272X').work
|
|
|
|
self.assertEqual(work.language, 'en')
|
|
|
|
bookloader.add_related('079530272X')
|
|
|
|
for edition in work.editions.all():
|
|
|
|
self.assertEqual(edition.title.lower(), "cat's cradle")
|
|
|
|
|
2011-12-19 06:33:13 +00:00
|
|
|
def test_add_openlibrary(self):
|
2012-07-20 15:40:11 +00:00
|
|
|
work = bookloader.add_by_isbn('0441007465').work
|
|
|
|
bookloader.add_related('0441007465')
|
2011-12-19 06:33:13 +00:00
|
|
|
bookloader.add_openlibrary(work)
|
2011-12-19 07:34:29 +00:00
|
|
|
subjects = [s.name for s in work.subjects.all()]
|
2011-12-19 07:20:24 +00:00
|
|
|
self.assertTrue(len(subjects) > 10)
|
2011-12-19 07:27:07 +00:00
|
|
|
self.assertTrue('Science fiction' in subjects)
|
2012-05-07 05:18:11 +00:00
|
|
|
self.assertTrue('/works/OL27258W' in work.identifiers.filter(type='olwk').values_list('value',flat=True) )
|
2012-07-20 15:40:11 +00:00
|
|
|
self.assertTrue('888628' in work.identifiers.filter(type='gdrd').values_list('value',flat=True))
|
2012-05-07 05:18:11 +00:00
|
|
|
self.assertTrue('609' in work.identifiers.filter(type='ltwk').values_list('value',flat=True))
|
|
|
|
|
2012-07-26 16:06:39 +00:00
|
|
|
def test_unicode_openlibrary(self):
|
|
|
|
work = bookloader.add_by_isbn('9783894808358').work
|
|
|
|
bookloader.add_openlibrary(work)
|
|
|
|
self.assertTrue(work.description.startswith('Sie sind jung,'))
|
|
|
|
|
2015-08-21 22:31:52 +00:00
|
|
|
def notest_load_gutenberg_edition(self):
|
2012-02-15 02:01:13 +00:00
|
|
|
"""Let's try this out for Moby Dick"""
|
|
|
|
|
|
|
|
title = "Moby Dick"
|
|
|
|
ol_work_id = "/works/OL102749W"
|
|
|
|
gutenberg_etext_id = 2701
|
|
|
|
epub_url = "http://www.gutenberg.org/cache/epub/2701/pg2701.epub"
|
|
|
|
license = 'http://www.gutenberg.org/license'
|
|
|
|
lang = 'en'
|
|
|
|
format = 'epub'
|
|
|
|
publication_date = datetime(2001,7,1)
|
|
|
|
seed_isbn = '9780142000083' # http://www.amazon.com/Moby-Dick-Whale-Penguin-Classics-Deluxe/dp/0142000086
|
|
|
|
|
|
|
|
ebook = bookloader.load_gutenberg_edition(title, gutenberg_etext_id, ol_work_id, seed_isbn, epub_url, format, license, lang, publication_date)
|
|
|
|
self.assertEqual(ebook.url, epub_url)
|
|
|
|
|
2011-12-19 06:33:13 +00:00
|
|
|
|
2011-09-29 06:23:50 +00:00
|
|
|
class SearchTests(TestCase):
|
|
|
|
|
|
|
|
def test_basic_search(self):
|
2011-11-20 14:28:53 +00:00
|
|
|
results = search.gluejar_search('melville')
|
2011-09-29 06:23:50 +00:00
|
|
|
self.assertEqual(len(results), 10)
|
|
|
|
|
|
|
|
r = results[0]
|
2011-09-29 19:07:16 +00:00
|
|
|
self.assertTrue(r.has_key('title'))
|
2011-09-29 06:23:50 +00:00
|
|
|
self.assertTrue(r.has_key('author'))
|
|
|
|
self.assertTrue(r.has_key('description'))
|
2011-11-23 18:18:32 +00:00
|
|
|
self.assertTrue(r.has_key('cover_image_thumbnail'))
|
2014-12-08 18:09:05 +00:00
|
|
|
self.assertTrue(r['cover_image_thumbnail'].startswith('https') or r['cover_image_thumbnail'].startswith('http'))
|
2011-09-29 06:23:50 +00:00
|
|
|
self.assertTrue(r.has_key('publisher'))
|
2011-12-20 04:26:55 +00:00
|
|
|
self.assertTrue(r.has_key('isbn_13'))
|
2011-10-10 16:57:10 +00:00
|
|
|
self.assertTrue(r.has_key('googlebooks_id'))
|
2011-09-29 06:23:50 +00:00
|
|
|
|
2012-02-05 00:22:04 +00:00
|
|
|
def test_pagination(self):
|
|
|
|
r1 = search.gluejar_search('melville', page=1)
|
|
|
|
r2 = search.gluejar_search('melville', page=2)
|
|
|
|
isbns1 = set([r['isbn_13'] for r in r1])
|
|
|
|
isbns2 = set([r['isbn_13'] for r in r2])
|
|
|
|
self.assertTrue(isbns1 != isbns2)
|
2012-02-05 00:06:53 +00:00
|
|
|
|
2011-09-29 06:23:50 +00:00
|
|
|
def test_googlebooks_search(self):
|
2012-02-05 00:22:04 +00:00
|
|
|
response = search.googlebooks_search('melville', '69.243.24.29', 1)
|
2011-09-29 06:23:50 +00:00
|
|
|
self.assertEqual(len(response['items']), 10)
|
2011-10-07 21:17:54 +00:00
|
|
|
|
2011-10-10 21:26:38 +00:00
|
|
|
|
2011-10-07 21:17:54 +00:00
|
|
|
class CampaignTests(TestCase):
|
|
|
|
|
2013-08-08 23:56:26 +00:00
|
|
|
def test_b2u(self):
|
|
|
|
w = Work()
|
|
|
|
w.save()
|
|
|
|
c = Campaign(
|
|
|
|
target=D('12000.00'),
|
|
|
|
deadline=datetime(2013, 1, 1),
|
|
|
|
work=w, type=2,
|
|
|
|
cc_date_initial=datetime(2113, 1, 1),
|
|
|
|
)
|
|
|
|
self.assertTrue(c.set_dollar_per_day()<0.34)
|
|
|
|
self.assertTrue(c.dollar_per_day>0.31)
|
2014-03-02 03:42:26 +00:00
|
|
|
t = Transaction(type=1, campaign=c, approved=True, amount= D(6000.1), status="Complete")
|
|
|
|
t.save()
|
2013-08-09 02:32:58 +00:00
|
|
|
c.status = 'ACTIVE'
|
|
|
|
c.save()
|
|
|
|
c.update_left()
|
2013-08-10 20:29:58 +00:00
|
|
|
#print(w.percent_of_goal())
|
2013-08-09 02:32:58 +00:00
|
|
|
self.assertEqual(w.percent_unglued(),3)
|
|
|
|
self.assertTrue(w.percent_of_goal()>49)
|
2013-08-22 18:23:47 +00:00
|
|
|
ofr = Offer.objects.create(work=w,price=D(10),active=True)
|
|
|
|
self.assertTrue(c.days_per_copy <D(32.26))
|
|
|
|
self.assertTrue(c.days_per_copy >D(29.41))
|
2013-08-08 23:56:26 +00:00
|
|
|
|
2011-10-09 18:48:03 +00:00
|
|
|
def test_required_fields(self):
|
|
|
|
# a campaign must have a target, deadline and a work
|
|
|
|
|
|
|
|
c = Campaign()
|
|
|
|
self.assertRaises(IntegrityError, c.save)
|
|
|
|
|
|
|
|
c = Campaign(target=D('1000.00'))
|
|
|
|
self.assertRaises(IntegrityError, c.save)
|
|
|
|
|
2012-04-03 00:57:30 +00:00
|
|
|
c = Campaign(target=D('1000.00'), deadline=datetime(2013, 1, 1))
|
2011-10-09 18:48:03 +00:00
|
|
|
self.assertRaises(IntegrityError, c.save)
|
|
|
|
|
2011-10-14 04:02:19 +00:00
|
|
|
w = Work()
|
|
|
|
w.save()
|
2012-04-03 00:57:30 +00:00
|
|
|
c = Campaign(target=D('1000.00'), deadline=datetime(2013, 1, 1), work=w)
|
2012-05-20 04:12:16 +00:00
|
|
|
c.license = 'CC BY-NC'
|
2011-10-14 04:02:19 +00:00
|
|
|
c.save()
|
2012-05-20 04:12:16 +00:00
|
|
|
self.assertEqual(c.license_url, 'http://creativecommons.org/licenses/by-nc/3.0/')
|
2014-11-10 18:14:59 +00:00
|
|
|
self.assertEqual(c.license_badge, '/static/images/ccbync.png')
|
2012-05-20 04:12:16 +00:00
|
|
|
|
2011-10-08 03:11:57 +00:00
|
|
|
def test_campaign_status(self):
|
2012-04-03 00:57:30 +00:00
|
|
|
|
|
|
|
# need a user to associate with a transaction
|
2013-03-06 14:39:06 +00:00
|
|
|
user = User.objects.create_user('test', 'test@example.org', 'testpass')
|
2012-04-03 00:57:30 +00:00
|
|
|
|
2011-10-08 03:11:57 +00:00
|
|
|
w = Work()
|
|
|
|
w.save()
|
2012-09-25 20:43:25 +00:00
|
|
|
w2 = Work()
|
|
|
|
w2.save()
|
2011-10-08 03:11:57 +00:00
|
|
|
# INITIALIZED
|
2013-06-17 21:12:58 +00:00
|
|
|
c1 = Campaign(target=D('1000.00'),deadline=Campaign.latest_ending(),work=w)
|
2011-10-08 03:11:57 +00:00
|
|
|
c1.save()
|
2011-10-10 20:35:22 +00:00
|
|
|
self.assertEqual(c1.status, 'INITIALIZED')
|
2011-10-08 03:11:57 +00:00
|
|
|
# ACTIVATED
|
2014-02-21 18:16:55 +00:00
|
|
|
c2 = Campaign(target=D('1000.00'),deadline=datetime(2013,1,1),work=w,description='dummy description')
|
2011-10-08 03:11:57 +00:00
|
|
|
c2.save()
|
2011-10-10 20:35:22 +00:00
|
|
|
self.assertEqual(c2.status, 'INITIALIZED')
|
2013-03-06 14:39:06 +00:00
|
|
|
u = User.objects.create_user('claimer', 'claimer@example.org', 'claimer')
|
2012-04-03 14:45:48 +00:00
|
|
|
u.save()
|
|
|
|
rh = RightsHolder(owner = u, rights_holder_name = 'rights holder name')
|
|
|
|
rh.save()
|
|
|
|
cl = Claim(rights_holder = rh, work = w, user = u, status = 'active')
|
|
|
|
cl.save()
|
2012-09-25 20:43:25 +00:00
|
|
|
cl2 = Claim(rights_holder = rh, work = w2, user = u, status = 'active')
|
|
|
|
cl2.save()
|
2011-10-08 03:11:57 +00:00
|
|
|
c2.activate()
|
2011-10-10 20:35:22 +00:00
|
|
|
self.assertEqual(c2.status, 'ACTIVE')
|
2011-10-08 03:11:57 +00:00
|
|
|
# SUSPENDED
|
|
|
|
c2.suspend(reason="for testing")
|
2011-10-10 20:35:22 +00:00
|
|
|
self.assertEqual(c2.status, 'SUSPENDED')
|
2011-10-08 03:11:57 +00:00
|
|
|
# RESUMING
|
2011-12-13 21:24:39 +00:00
|
|
|
c2.resume(reason="for testing")
|
|
|
|
#self.assertEqual(c2.suspended, None)
|
2011-10-10 20:35:22 +00:00
|
|
|
self.assertEqual(c2.status,'ACTIVE')
|
2011-10-08 03:11:57 +00:00
|
|
|
# should not let me suspend a campaign that hasn't been initialized
|
|
|
|
self.assertRaises(UnglueitError, c1.suspend, "for testing")
|
|
|
|
# UNSUCCESSFUL
|
2014-02-21 18:16:55 +00:00
|
|
|
c3 = Campaign(target=D('1000.00'),deadline=now() - timedelta(days=1),work=w2,description='dummy description')
|
2011-10-08 03:11:57 +00:00
|
|
|
c3.save()
|
|
|
|
c3.activate()
|
2012-04-03 00:57:30 +00:00
|
|
|
self.assertEqual(c3.status, 'ACTIVE')
|
|
|
|
# at this point, since the deadline has passed, the status should change and be UNSUCCESSFUL
|
2012-03-09 22:18:11 +00:00
|
|
|
self.assertTrue(c3.update_status())
|
2011-10-10 20:35:22 +00:00
|
|
|
self.assertEqual(c3.status, 'UNSUCCESSFUL')
|
2012-09-25 20:43:25 +00:00
|
|
|
|
|
|
|
# premiums
|
|
|
|
pr1= Premium(type='CU', campaign=c3, amount=10, description='botsnack', limit=1)
|
|
|
|
pr1.save()
|
|
|
|
self.assertEqual(pr1.premium_remaining,1)
|
|
|
|
|
|
|
|
#cloning (note we changed c3 to w2 to make it clonable)
|
|
|
|
c7= c3.clone()
|
|
|
|
self.assertEqual(c7.status, 'INITIALIZED')
|
|
|
|
self.assertEqual(c7.premiums.all()[0].description , 'botsnack')
|
|
|
|
|
|
|
|
|
2011-10-08 03:11:57 +00:00
|
|
|
# SUCCESSFUL
|
2014-02-21 18:16:55 +00:00
|
|
|
c4 = Campaign(target=D('1000.00'),deadline=now() - timedelta(days=1),work=w,description='dummy description')
|
2011-10-08 03:11:57 +00:00
|
|
|
c4.save()
|
|
|
|
c4.activate()
|
|
|
|
t = Transaction()
|
|
|
|
t.amount = D('1234.00')
|
|
|
|
t.type = PAYMENT_TYPE_AUTHORIZATION
|
|
|
|
t.status = 'ACTIVE'
|
2012-01-11 23:31:26 +00:00
|
|
|
t.approved = True
|
2011-10-08 03:11:57 +00:00
|
|
|
t.campaign = c4
|
2012-04-03 00:57:30 +00:00
|
|
|
t.user = user
|
2011-10-08 03:11:57 +00:00
|
|
|
t.save()
|
2012-04-03 00:57:30 +00:00
|
|
|
self.assertTrue(c4.update_status())
|
2011-10-10 20:35:22 +00:00
|
|
|
self.assertEqual(c4.status, 'SUCCESSFUL')
|
2011-10-08 03:11:57 +00:00
|
|
|
|
|
|
|
# WITHDRAWN
|
2014-02-21 18:16:55 +00:00
|
|
|
c5 = Campaign(target=D('1000.00'),deadline=datetime(2013,1,1),work=w,description='dummy description')
|
2011-10-08 03:11:57 +00:00
|
|
|
c5.save()
|
|
|
|
c5.activate().withdraw('testing')
|
2012-05-22 15:07:05 +00:00
|
|
|
self.assertEqual(c5.status, 'WITHDRAWN')
|
2011-10-14 02:16:28 +00:00
|
|
|
|
2012-05-22 15:07:05 +00:00
|
|
|
# testing percent-of-goal
|
|
|
|
w2 = Work()
|
|
|
|
w2.save()
|
2014-02-21 18:16:55 +00:00
|
|
|
c6 = Campaign(target=D('1000.00'),deadline=now() + timedelta(days=1),work=w2,description='dummy description')
|
2012-05-22 15:07:05 +00:00
|
|
|
c6.save()
|
|
|
|
cl = Claim(rights_holder = rh, work = w2, user = u, status = 'active')
|
|
|
|
cl.save()
|
|
|
|
c6.activate()
|
|
|
|
t = Transaction()
|
|
|
|
t.amount = D('234.00')
|
|
|
|
t.type = PAYMENT_TYPE_AUTHORIZATION
|
|
|
|
t.status = 'ACTIVE'
|
|
|
|
t.approved = True
|
|
|
|
t.campaign = c6
|
|
|
|
t.user = user
|
|
|
|
t.save()
|
|
|
|
self.assertEqual(w2.percent_of_goal(), 23)
|
2013-06-17 22:53:21 +00:00
|
|
|
|
2014-01-15 15:19:57 +00:00
|
|
|
self.assertEqual(c1.launchable, False)
|
|
|
|
c1.description="description"
|
2013-06-17 22:53:21 +00:00
|
|
|
self.assertEqual(c1.launchable, True)
|
|
|
|
c1.work.create_offers()
|
|
|
|
self.assertEqual(c1.work.offers.count(), 2)
|
|
|
|
self.assertEqual(c1.work.offers.filter(license=2).count(), 1)
|
|
|
|
c1.type = 2
|
|
|
|
c1.save()
|
|
|
|
self.assertEqual(c1.launchable, False)
|
2013-08-18 19:18:01 +00:00
|
|
|
of1=c1.work.offers.get(license=2)
|
2013-08-22 18:23:47 +00:00
|
|
|
of1.price=D(2)
|
2013-08-18 19:18:01 +00:00
|
|
|
of1.active=True
|
2013-06-17 22:53:21 +00:00
|
|
|
of1.save()
|
|
|
|
self.assertEqual(c1.launchable, False)
|
|
|
|
e1= models.Edition(title="title",work=c1.work)
|
|
|
|
e1.save()
|
|
|
|
ebf1= models.EbookFile(edition=e1, format=1)
|
|
|
|
ebf1.save()
|
2013-08-19 20:01:32 +00:00
|
|
|
c1.set_cc_date_initial()
|
|
|
|
self.assertEqual(c1.cc_date, settings.MAX_CC_DATE)
|
2013-08-18 19:18:01 +00:00
|
|
|
c1.target = D(settings.UNGLUEIT_MAXIMUM_TARGET)
|
|
|
|
c1.save()
|
2013-06-17 22:53:21 +00:00
|
|
|
self.assertEqual(c1.launchable, True)
|
2011-10-14 02:16:28 +00:00
|
|
|
|
2011-10-14 14:18:38 +00:00
|
|
|
class WishlistTest(TestCase):
|
|
|
|
|
|
|
|
def test_add_remove(self):
|
|
|
|
# add a work to a user's wishlist
|
2013-03-06 14:39:06 +00:00
|
|
|
user = User.objects.create_user('test', 'test@example.org', 'testpass')
|
2012-07-20 15:40:11 +00:00
|
|
|
edition = bookloader.add_by_isbn('0441007465')
|
2011-10-14 14:18:38 +00:00
|
|
|
work = edition.work
|
2012-02-11 19:15:06 +00:00
|
|
|
num_wishes=work.num_wishes
|
2011-12-08 23:22:05 +00:00
|
|
|
user.wishlist.add_work(work, 'test')
|
2011-10-14 14:18:38 +00:00
|
|
|
self.assertEqual(user.wishlist.works.count(), 1)
|
2012-02-11 19:15:06 +00:00
|
|
|
self.assertEqual(work.num_wishes, num_wishes+1)
|
2016-01-20 01:53:55 +00:00
|
|
|
self.assertEqual(work.priority(),1)
|
2011-12-08 23:22:05 +00:00
|
|
|
user.wishlist.remove_work(work)
|
2011-10-14 14:18:38 +00:00
|
|
|
self.assertEqual(user.wishlist.works.count(), 0)
|
2012-02-11 19:15:06 +00:00
|
|
|
self.assertEqual(work.num_wishes, num_wishes)
|
|
|
|
|
2011-11-10 23:14:33 +00:00
|
|
|
class CeleryTaskTest(TestCase):
|
2011-12-03 03:16:11 +00:00
|
|
|
|
2011-11-10 23:14:33 +00:00
|
|
|
def test_single_fac(self):
|
|
|
|
n = 10
|
|
|
|
task = tasks.fac.delay(n)
|
|
|
|
result = task.get(timeout=10)
|
|
|
|
self.assertEqual(result,factorial(n))
|
2011-12-03 03:16:11 +00:00
|
|
|
|
2011-11-10 23:14:33 +00:00
|
|
|
def test_subtask(self):
|
|
|
|
n = 30
|
|
|
|
subtasks = [tasks.fac.subtask(args=(x,)) for x in range(n)]
|
|
|
|
job = TaskSet(tasks=subtasks)
|
|
|
|
result = job.apply_async()
|
|
|
|
while not result.ready():
|
|
|
|
sleep(0.2)
|
|
|
|
self.assertEqual(result.join(),[factorial(x) for x in range(n)])
|
|
|
|
|
2011-11-18 00:45:26 +00:00
|
|
|
class GoodreadsTest(TestCase):
|
2011-12-03 03:16:11 +00:00
|
|
|
|
2014-05-02 21:20:37 +00:00
|
|
|
@unittest.skip("Goodreads down at the moment")
|
2011-11-18 00:45:26 +00:00
|
|
|
def test_goodreads_shelves(self):
|
|
|
|
# test to see whether the core undeletable shelves are on the list
|
|
|
|
gr_uid = "767708" # for Raymond Yee
|
|
|
|
gc = goodreads.GoodreadsClient(key=settings.GOODREADS_API_KEY, secret=settings.GOODREADS_API_SECRET)
|
|
|
|
shelves = gc.shelves_list(gr_uid)
|
|
|
|
shelf_names = [s['name'] for s in shelves['user_shelves']]
|
|
|
|
self.assertTrue('currently-reading' in shelf_names)
|
|
|
|
self.assertTrue('read' in shelf_names)
|
|
|
|
self.assertTrue('to-read' in shelf_names)
|
2011-12-03 03:16:11 +00:00
|
|
|
|
2014-05-02 21:20:37 +00:00
|
|
|
@unittest.skip("Goodreads down at the moment")
|
2011-11-18 14:14:33 +00:00
|
|
|
def test_review_list_unauth(self):
|
|
|
|
gr_uid = "767708" # for Raymond Yee
|
|
|
|
gc = goodreads.GoodreadsClient(key=settings.GOODREADS_API_KEY, secret=settings.GOODREADS_API_SECRET)
|
|
|
|
reviews = gc.review_list_unauth(user_id=gr_uid, shelf='read')
|
|
|
|
# test to see whether there is a book field in each of the review
|
2012-04-13 21:53:18 +00:00
|
|
|
# url for test is http://www.goodreads.com/review/list.xml?id=767708&shelf=read&page=1&per_page=20&order=a&v=2&key=[key]
|
2011-11-18 14:14:33 +00:00
|
|
|
self.assertTrue(all([r.has_key("book") for r in reviews]))
|
2011-11-18 00:45:26 +00:00
|
|
|
|
|
|
|
class LibraryThingTest(TestCase):
|
2011-12-03 03:16:11 +00:00
|
|
|
|
2011-11-18 00:45:26 +00:00
|
|
|
def test_scrape_test_lib(self):
|
|
|
|
# account yujx : has one book: 0471925675
|
|
|
|
lt_username = 'yujx'
|
|
|
|
lt = librarything.LibraryThing(username=lt_username)
|
|
|
|
books = list(lt.parse_user_catalog(view_style=5))
|
|
|
|
self.assertEqual(len(books),1)
|
|
|
|
self.assertEqual(books[0]['isbn'], '0471925675')
|
2011-12-03 03:16:11 +00:00
|
|
|
self.assertEqual(books[0]['work_id'], '80826')
|
|
|
|
self.assertEqual(books[0]['book_id'], '79883733')
|
2011-11-18 18:01:37 +00:00
|
|
|
|
|
|
|
class ISBNTest(TestCase):
|
2011-12-03 03:16:11 +00:00
|
|
|
|
2011-11-18 18:01:37 +00:00
|
|
|
def test_ISBN(self):
|
|
|
|
milosz_10 = '006019667X'
|
|
|
|
milosz_13 = '9780060196677'
|
|
|
|
python_10 = '0-672-32978-6'
|
|
|
|
python_10_wrong = '0-672-32978-7'
|
|
|
|
python_13 = '978-0-672-32978-4'
|
|
|
|
|
|
|
|
isbn_python_10 = isbn.ISBN(python_10)
|
|
|
|
isbn_python_13 = isbn.ISBN(python_13)
|
2012-02-08 17:19:17 +00:00
|
|
|
# return None for invalid characters
|
|
|
|
self.assertEqual(None, isbn.ISBN("978-0-M72-32978-X").to_string('13'))
|
|
|
|
self.assertEqual(isbn.ISBN("978-0-M72-32978-X").valid, False)
|
2011-11-18 19:25:13 +00:00
|
|
|
# check that only ISBN 13 starting with 978 or 979 are accepted
|
2012-02-08 17:19:17 +00:00
|
|
|
self.assertEqual(None, isbn.ISBN("111-0-M72-32978-X").to_string())
|
2011-11-18 19:25:13 +00:00
|
|
|
|
2011-11-18 18:01:37 +00:00
|
|
|
# right type?
|
|
|
|
self.assertEqual(isbn_python_10.type, '10')
|
|
|
|
self.assertEqual(isbn_python_13.type, '13')
|
|
|
|
# valid?
|
|
|
|
self.assertEqual(isbn_python_10.valid, True)
|
|
|
|
self.assertEqual(isbn.ISBN(python_10_wrong).valid, False)
|
2011-10-14 02:16:28 +00:00
|
|
|
|
2011-11-18 18:01:37 +00:00
|
|
|
# do conversion -- first the outside methods
|
|
|
|
self.assertEqual(isbn.convert_10_to_13(isbn.strip(python_10)),isbn.strip(python_13))
|
|
|
|
self.assertEqual(isbn.convert_13_to_10(isbn.strip(python_13)),isbn.strip(python_10))
|
2014-11-05 23:33:30 +00:00
|
|
|
self.assertEqual(isbn.convert_13_to_10('xxxxxxxxxxxxx'),None)
|
|
|
|
self.assertEqual(isbn.convert_10_to_13('xxxxxxxxxx'),None)
|
2011-11-18 18:01:37 +00:00
|
|
|
|
|
|
|
# check formatting
|
|
|
|
self.assertEqual(isbn.ISBN(python_13).to_string(type='13'), '9780672329784')
|
|
|
|
self.assertEqual(isbn.ISBN(python_13).to_string('13',True), '978-0-672-32978-4')
|
|
|
|
self.assertEqual(isbn.ISBN(python_13).to_string(type='10'), '0672329786')
|
|
|
|
self.assertEqual(isbn.ISBN(python_10).to_string(type='13'), '9780672329784')
|
|
|
|
self.assertEqual(isbn.ISBN(python_10).to_string(10,True), '0-672-32978-6')
|
|
|
|
|
2011-11-18 19:25:13 +00:00
|
|
|
# complain if one tries to get ISBN-10 for a 979 ISBN 13
|
|
|
|
# making up a 979 ISBN
|
|
|
|
isbn_979 = isbn.ISBN("979-1-234-56789-0").validate()
|
2012-02-08 17:19:17 +00:00
|
|
|
self.assertEqual(isbn_979.to_string('10'), None)
|
2011-11-18 19:25:13 +00:00
|
|
|
|
2011-11-18 18:01:37 +00:00
|
|
|
# check casting to string -- ISBN 13
|
2011-11-18 18:21:29 +00:00
|
|
|
self.assertEqual(str(isbn.ISBN(python_10)), '0672329786')
|
2011-11-18 18:01:37 +00:00
|
|
|
|
|
|
|
# test __eq__ and __ne__ and validate
|
|
|
|
self.assertTrue(isbn.ISBN(milosz_10) == isbn.ISBN(milosz_13))
|
|
|
|
self.assertTrue(isbn.ISBN(milosz_10) == milosz_13)
|
|
|
|
self.assertFalse(isbn.ISBN(milosz_10) == 'ddds')
|
|
|
|
self.assertFalse(isbn.ISBN(milosz_10) != milosz_10)
|
|
|
|
self.assertTrue(isbn.ISBN(python_10) != python_10_wrong)
|
|
|
|
self.assertEqual(isbn.ISBN(python_10_wrong).validate(), python_10)
|
|
|
|
self.assertEqual(isbn.ISBN(python_13).validate(), python_10)
|
|
|
|
|
|
|
|
# curious about set membership
|
|
|
|
self.assertEqual(len(set([isbn.ISBN(milosz_10), isbn.ISBN(milosz_13)])),2)
|
2011-11-18 18:21:29 +00:00
|
|
|
self.assertEqual(len(set([str(isbn.ISBN(milosz_10)), str(isbn.ISBN(milosz_13))])),2)
|
|
|
|
self.assertEqual(len(set([isbn.ISBN(milosz_10).to_string(), isbn.ISBN(milosz_13).to_string()])),1)
|
2011-11-18 18:01:37 +00:00
|
|
|
|
2012-05-08 23:08:36 +00:00
|
|
|
class EncryptedKeyTest(TestCase):
|
|
|
|
def test_create_read_key(self):
|
|
|
|
name = "the great answer"
|
|
|
|
value = "42"
|
|
|
|
key = Key.objects.create(name=name, value=value)
|
|
|
|
key.save()
|
|
|
|
# do we get back the value?
|
|
|
|
self.assertEqual(Key.objects.filter(name=name)[0].value, value)
|
|
|
|
# just checking that the encrypted value is not the same as the value
|
|
|
|
self.assertNotEqual(key.encrypted_value, value) # is this always true?
|
2012-08-29 19:56:14 +00:00
|
|
|
|
|
|
|
class SafeGetWorkTest(TestCase):
|
|
|
|
def test_good_work(self):
|
|
|
|
w1 = models.Work()
|
|
|
|
w1.save()
|
|
|
|
w2 = models.Work()
|
|
|
|
w2.save()
|
|
|
|
w2_id = w2.id
|
|
|
|
bookloader.merge_works(w1, w2)
|
|
|
|
|
|
|
|
work = safe_get_work(w1.id)
|
|
|
|
self.assertEqual(work, w1)
|
|
|
|
work = safe_get_work(w2_id)
|
|
|
|
self.assertEqual(work, w1)
|
|
|
|
self.assertRaises(Http404, safe_get_work, 3)
|
2015-08-22 18:29:35 +00:00
|
|
|
|
|
|
|
class WorkTests(TestCase):
|
|
|
|
def test_preferred_edition(self):
|
|
|
|
w1 = models.Work.objects.create()
|
|
|
|
w2 = models.Work.objects.create()
|
|
|
|
ww = models.WasWork.objects.create(work=w1, was= w2.id)
|
|
|
|
e1 = models.Edition.objects.create(work=w1)
|
|
|
|
self.assertEqual(e1, w1.preferred_edition)
|
|
|
|
e2 = models.Edition.objects.create(work=w1)
|
|
|
|
w1.selected_edition=e2
|
|
|
|
w1.save()
|
|
|
|
self.assertEqual(e2, w1.preferred_edition)
|
|
|
|
self.assertEqual(e2, w2.preferred_edition)
|
|
|
|
|
2012-08-29 19:56:14 +00:00
|
|
|
|
|
|
|
class DownloadPageTest(TestCase):
|
|
|
|
def test_download_page(self):
|
|
|
|
w = models.Work()
|
|
|
|
w.save()
|
|
|
|
|
|
|
|
e1 = models.Edition()
|
|
|
|
e1.work = w
|
2012-09-19 16:37:37 +00:00
|
|
|
e1.unglued = True
|
2012-08-29 19:56:14 +00:00
|
|
|
e2 = models.Edition()
|
|
|
|
e2.work = w
|
|
|
|
e1.save()
|
|
|
|
e2.save()
|
|
|
|
|
|
|
|
eb1 = models.Ebook()
|
2013-03-06 14:39:06 +00:00
|
|
|
eb1.url = "http://example.org"
|
2012-08-29 19:56:14 +00:00
|
|
|
eb1.edition = e1
|
2012-09-19 16:37:37 +00:00
|
|
|
eb1.format = 'epub'
|
2012-08-29 19:56:14 +00:00
|
|
|
|
|
|
|
eb2 = models.Ebook()
|
|
|
|
eb2.url = "http://example2.com"
|
|
|
|
eb2.edition = e2
|
2012-09-25 16:27:39 +00:00
|
|
|
eb2.format = 'mobi'
|
2012-08-29 19:56:14 +00:00
|
|
|
|
|
|
|
eb1.save()
|
|
|
|
eb2.save()
|
|
|
|
|
|
|
|
anon_client = Client()
|
2013-04-24 19:41:35 +00:00
|
|
|
response = anon_client.get("/work/%s/download/" % w.id, follow=True)
|
2013-09-06 04:14:06 +00:00
|
|
|
self.assertContains(response, "/download_ebook/%s/"% eb1.id, count=10)
|
2014-05-22 17:19:05 +00:00
|
|
|
self.assertContains(response, "/download_ebook/%s/"% eb2.id, count=5)
|
2014-12-13 17:37:35 +00:00
|
|
|
self.assertTrue(eb1.edition.work.is_free)
|
|
|
|
eb1.delete()
|
|
|
|
self.assertTrue(eb2.edition.work.is_free)
|
|
|
|
eb2.delete()
|
|
|
|
self.assertFalse(eb2.edition.work.is_free)
|
2012-11-15 22:37:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
class LocaldatetimeTest(TestCase):
|
|
|
|
@override_settings(LOCALDATETIME_NOW=None)
|
|
|
|
def test_LOCALDATETIME_NOW_none(self):
|
|
|
|
|
|
|
|
try:
|
|
|
|
localdatetime.now
|
|
|
|
except NameError:
|
|
|
|
from regluit.utils import localdatetime
|
|
|
|
else:
|
|
|
|
reload(localdatetime)
|
|
|
|
|
|
|
|
self.assertAlmostEqual(mktime(datetime.now().timetuple()), mktime(localdatetime.now().timetuple()), 1.0)
|
|
|
|
|
|
|
|
@override_settings(LOCALDATETIME_NOW=lambda : datetime.now() + timedelta(365))
|
|
|
|
def test_LOCALDATETIME_NOW_year_ahead(self):
|
|
|
|
|
|
|
|
try:
|
|
|
|
localdatetime.now
|
|
|
|
except NameError:
|
|
|
|
from regluit.utils import localdatetime
|
|
|
|
else:
|
|
|
|
reload(localdatetime)
|
|
|
|
|
|
|
|
self.assertAlmostEqual(mktime((datetime.now() + timedelta(365)).timetuple()), mktime(localdatetime.now().timetuple()), 1.0)
|
|
|
|
|
|
|
|
def test_no_time_override(self):
|
|
|
|
|
|
|
|
from regluit.utils import localdatetime
|
|
|
|
self.assertAlmostEqual(mktime(datetime.now().timetuple()), mktime(localdatetime.now().timetuple()), 1.0)
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
# restore localdatetime.now() to what's in the settings file
|
|
|
|
try:
|
|
|
|
localdatetime.now
|
|
|
|
except NameError:
|
|
|
|
from regluit.utils import localdatetime
|
|
|
|
else:
|
|
|
|
reload(localdatetime)
|
|
|
|
|
2013-03-04 22:19:39 +00:00
|
|
|
class MailingListTests(TestCase):
|
|
|
|
#mostly to check that MailChimp account is setp correctly
|
2012-11-15 22:37:04 +00:00
|
|
|
|
2013-03-04 22:19:39 +00:00
|
|
|
def test_mailchimp(self):
|
|
|
|
from postmonkey import PostMonkey
|
|
|
|
pm = PostMonkey(settings.MAILCHIMP_API_KEY)
|
|
|
|
self.assertEqual(pm.ping(),"Everything's Chimpy!" )
|
|
|
|
self.user = User.objects.create_user('chimp_test', 'eric@gluejar.com', 'chimp_test')
|
|
|
|
self.assertTrue(self.user.profile.on_ml)
|
|
|
|
|
2013-11-15 16:25:41 +00:00
|
|
|
@override_settings(LOCAL_TEST=True)
|
2013-08-27 22:03:35 +00:00
|
|
|
class EbookFileTests(TestCase):
|
2014-08-28 19:29:41 +00:00
|
|
|
|
2014-01-15 13:32:55 +00:00
|
|
|
def test_badepub_errors(self):
|
|
|
|
textfile = NamedTemporaryFile(delete=False)
|
|
|
|
textfile.write("bad text file")
|
|
|
|
textfile.seek(0)
|
|
|
|
self.assertTrue(test_epub(textfile))
|
2013-08-27 22:03:35 +00:00
|
|
|
|
|
|
|
def test_ebookfile(self):
|
2013-08-29 00:13:35 +00:00
|
|
|
"""
|
|
|
|
Read the test epub file
|
|
|
|
"""
|
2013-08-27 22:03:35 +00:00
|
|
|
w = Work.objects.create(title="Work 1")
|
|
|
|
e = Edition.objects.create(title=w.title,work=w)
|
|
|
|
u = User.objects.create_user('test', 'test@example.org', 'testpass')
|
2013-11-15 16:25:41 +00:00
|
|
|
rh = RightsHolder.objects.create(owner = u, rights_holder_name = 'rights holder name')
|
|
|
|
cl = Claim.objects.create(rights_holder = rh, work = w, user = u, status = 'active')
|
|
|
|
c = Campaign.objects.create(work = w,
|
|
|
|
type = parameters.BUY2UNGLUE,
|
|
|
|
cc_date_initial = datetime(2020,1,1),
|
|
|
|
target = 1000,
|
|
|
|
deadline = datetime(2020,1,1),
|
|
|
|
license = 'CC BY',
|
2014-02-21 18:16:55 +00:00
|
|
|
description = "dummy description",
|
2013-11-15 16:25:41 +00:00
|
|
|
)
|
2013-08-29 00:13:35 +00:00
|
|
|
# download the test epub into a temp file
|
|
|
|
temp = NamedTemporaryFile(delete=False)
|
|
|
|
test_file_content = requests.get(settings.BOOXTREAM_TEST_EPUB_URL).content
|
|
|
|
|
|
|
|
temp.write(test_file_content)
|
|
|
|
temp.close()
|
|
|
|
|
|
|
|
try:
|
|
|
|
# now we can try putting the test epub file into Django storage
|
|
|
|
temp_file = open(temp.name)
|
|
|
|
|
|
|
|
dj_file = DjangoFile(temp_file)
|
|
|
|
ebf = EbookFile( format='epub', edition=e, file=dj_file)
|
|
|
|
ebf.save()
|
|
|
|
|
|
|
|
temp_file.close()
|
|
|
|
finally:
|
|
|
|
# make sure we get rid of temp file
|
|
|
|
os.remove(temp.name)
|
|
|
|
|
2013-09-16 01:43:58 +00:00
|
|
|
test_epub= EPUB(ebf.file, mode='a')
|
|
|
|
self.assertEqual(len(test_epub.opf) , 4)
|
|
|
|
self.assertTrue(len(test_epub.opf[2]) < 30)
|
2013-08-27 22:03:35 +00:00
|
|
|
|
|
|
|
acq=Acq.objects.create(user=u,work=w,license=TESTING)
|
2013-09-06 02:54:11 +00:00
|
|
|
self.assertIsNot(acq.nonce, None)
|
|
|
|
|
|
|
|
url= acq.get_watermarked().download_link_epub
|
2013-11-15 16:25:41 +00:00
|
|
|
self.assertRegexpMatches(url,'github.com/eshellman/42_ebook/blob/master/download/42')
|
2013-11-18 04:24:03 +00:00
|
|
|
#self.assertRegexpMatches(url,'booxtream.com/')
|
2014-02-21 18:16:55 +00:00
|
|
|
|
|
|
|
with self.assertRaises(UnglueitError) as cm:
|
|
|
|
c.activate()
|
|
|
|
off = Offer(price=10.00, work=w, active=True)
|
|
|
|
off.save()
|
2013-11-15 16:25:41 +00:00
|
|
|
c.activate()
|
|
|
|
#flip the campaign to success
|
|
|
|
c.cc_date_initial= datetime(2012,1,1)
|
|
|
|
c.update_status()
|
|
|
|
self.assertEqual( c.work.ebooks().count(),2 )
|
2013-12-18 17:34:53 +00:00
|
|
|
c.do_watermark=False
|
|
|
|
c.save()
|
|
|
|
url= acq.get_watermarked().download_link_epub
|
2013-11-15 16:25:41 +00:00
|
|
|
|
2014-08-28 19:29:41 +00:00
|
|
|
def test_ebookfile_pdf(self):
|
|
|
|
w = Work.objects.create(title="Work 2")
|
|
|
|
e = Edition.objects.create(title=w.title,work=w)
|
|
|
|
u = User.objects.create_user('test2', 'test@example.org', 'testpass')
|
|
|
|
rh = RightsHolder.objects.create(owner = u, rights_holder_name = 'rights holder name 2')
|
|
|
|
cl = Claim.objects.create(rights_holder = rh, work = w, user = u, status = 'active')
|
|
|
|
c = Campaign.objects.create(work = w,
|
|
|
|
type = parameters.THANKS,
|
|
|
|
license = 'CC BY-NC',
|
|
|
|
description = "Please send me money",
|
|
|
|
)
|
|
|
|
# download the test epub into a temp file
|
|
|
|
temp = NamedTemporaryFile(delete=False)
|
|
|
|
test_file_content = requests.get(settings.TEST_PDF_URL).content
|
|
|
|
|
|
|
|
temp.write(test_file_content)
|
|
|
|
temp.close()
|
|
|
|
try:
|
|
|
|
# now we can try putting the test pdf file into Django storage
|
|
|
|
temp_file = open(temp.name)
|
|
|
|
|
|
|
|
dj_file = DjangoFile(temp_file)
|
|
|
|
ebf = EbookFile( format='pdf', edition=e, file=dj_file)
|
|
|
|
ebf.save()
|
|
|
|
|
|
|
|
temp_file.close()
|
|
|
|
finally:
|
|
|
|
# make sure we get rid of temp file
|
|
|
|
os.remove(temp.name)
|
|
|
|
#test the ask-appender
|
|
|
|
c.add_ask_to_ebfs()
|
|
|
|
asking_pdf = c.work.ebookfiles().filter(asking = True)[0].file.url
|
|
|
|
assert test_pdf(asking_pdf)
|
|
|
|
|
|
|
|
|
2015-01-26 17:48:16 +00:00
|
|
|
class MobigenTests(TestCase):
|
|
|
|
def test_convert_to_mobi(self):
|
|
|
|
"""
|
|
|
|
check the size of the mobi output of a Moby Dick epub
|
|
|
|
"""
|
|
|
|
from regluit.core.mobigen import convert_to_mobi
|
|
|
|
|
|
|
|
output = convert_to_mobi("https://archive.org/download/mobydickorthewha02701gut/pg2701.epub")
|
|
|
|
self.assertTrue(len(output)==2207877)
|
|
|
|
|
2013-10-17 02:48:29 +00:00
|
|
|
from .signals import handle_transaction_charged
|
2013-11-15 16:25:41 +00:00
|
|
|
@override_settings(LOCAL_TEST=True)
|
2013-10-17 02:48:29 +00:00
|
|
|
class LibTests(TestCase):
|
|
|
|
|
|
|
|
class transaction:
|
|
|
|
pass
|
|
|
|
|
|
|
|
def test_purchase(self):
|
|
|
|
w = Work.objects.create(title="Work 1")
|
|
|
|
e = Edition.objects.create(title=w.title,work=w)
|
|
|
|
u = User.objects.create_user('test', 'test@example.org', 'testpass')
|
|
|
|
lu = User.objects.create_user('library', 'testu@example.org', 'testpass')
|
2013-11-29 21:04:22 +00:00
|
|
|
lib = Library.objects.create(user=lu,owner=u)
|
2013-10-17 02:48:29 +00:00
|
|
|
c = Campaign.objects.create(work=w, type = parameters.BUY2UNGLUE, cc_date_initial= datetime(2020,1,1),target=1000, deadline=datetime(2020,1,1))
|
2013-08-27 22:03:35 +00:00
|
|
|
|
2013-10-17 02:48:29 +00:00
|
|
|
new_acq = Acq.objects.create(user=lib.user,work=c.work,license= LIBRARY)
|
|
|
|
self.assertTrue(new_acq.borrowable)
|
|
|
|
reserve_acq = Acq.objects.create(user=u,work=c.work,license= RESERVE, lib_acq = new_acq)
|
|
|
|
self.assertTrue(reserve_acq.borrowable)
|
|
|
|
self.assertFalse(new_acq.borrowable)
|
2013-10-18 16:36:55 +00:00
|
|
|
|
2013-11-08 17:13:34 +00:00
|
|
|
self.assertTrue(reserve_acq.expires< now()+timedelta(hours=25))
|
2013-10-18 16:36:55 +00:00
|
|
|
reserve_acq.borrow()
|
2013-11-08 17:13:34 +00:00
|
|
|
self.assertTrue(reserve_acq.expires> now()+timedelta(hours=25))
|
|
|
|
|
|
|
|
u2 = User.objects.create_user('user2', 'test2@example.org', 'testpass')
|
|
|
|
Hold.objects.get_or_create(library=lib,work=w,user=u2)
|
|
|
|
reserve_acq.expire_in(timedelta(seconds=0))
|
|
|
|
tasks.refresh_acqs()
|
|
|
|
self.assertEqual(reserve_acq.holds.count(),0)
|
|
|
|
|
2013-03-04 22:19:39 +00:00
|
|
|
|