X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/90a3704b70f16b87bc17b3a1f2c6d497316c9019..b15410e8b6dc970a92d0716dd54f154090ff6946:/apps/catalogue/tests/book_import.py
diff --git a/apps/catalogue/tests/book_import.py b/apps/catalogue/tests/book_import.py
index cb63fc069..eb5cea734 100644
--- a/apps/catalogue/tests/book_import.py
+++ b/apps/catalogue/tests/book_import.py
@@ -3,12 +3,15 @@ from django.core.files.base import ContentFile
from catalogue.test_utils import *
from catalogue import models
+from nose.tools import raises
+
+
class BookImportLogicTests(WLTestCase):
def setUp(self):
WLTestCase.setUp(self)
self.book_info = BookInfoStub(
- url=u"http://wolnelektury.pl/example/default_book",
+ url=u"http://wolnelektury.pl/example/default-book",
about=u"http://wolnelektury.pl/example/URI/default_book",
title=u"Default Book",
author=PersonStub(("Jim",), "Lazy"),
@@ -30,7 +33,7 @@ class BookImportLogicTests(WLTestCase):
book = models.Book.from_text_and_meta(ContentFile(BOOK_TEXT), self.book_info)
self.assertEqual(book.title, "Default Book")
- self.assertEqual(book.slug, "default_book")
+ self.assertEqual(book.slug, "default-book")
self.assert_(book.parent is None)
self.assertFalse(book.has_html_file())
@@ -104,6 +107,13 @@ class BookImportLogicTests(WLTestCase):
self.assertEqual(book.fragments.count(), 0)
self.assertEqual(book.tags.filter(category='theme').count(), 0)
+ @raises(ValueError)
+ def test_book_with_invalid_slug(self):
+ """ Book with invalid characters in slug shouldn't be imported """
+ self.book_info.url = "http://wolnelektury.pl/example/default_book"
+ BOOK_TEXT = ""
+ book = models.Book.from_text_and_meta(ContentFile(BOOK_TEXT), self.book_info)
+
def test_book_replace_title(self):
BOOK_TEXT = """"""
book = models.Book.from_text_and_meta(ContentFile(BOOK_TEXT), self.book_info)
@@ -153,3 +163,46 @@ class BookImportLogicTests(WLTestCase):
tags.sort()
self.assertEqual(tags, self.expected_tags)
+
+
+class ChildImportTests(WLTestCase):
+
+ def setUp(self):
+ WLTestCase.setUp(self)
+ self.child_info = BookInfoStub(
+ genre='X-Genre',
+ epoch='X-Epoch',
+ kind='X-Kind',
+ author=PersonStub(("Joe",), "Doe"),
+ **info_args("Child")
+ )
+
+ self.parent_info = BookInfoStub(
+ genre='X-Genre',
+ epoch='X-Epoch',
+ kind='X-Kind',
+ author=PersonStub(("Jim",), "Lazy"),
+ parts=[self.child_info.url],
+ **info_args("Parent")
+ )
+
+ def test_child_replace(self):
+ PARENT_TEXT = """"""
+ CHILD_TEXT = """
+
+ PiesAla ma kota
+
+ """
+ child = models.Book.from_text_and_meta(ContentFile(CHILD_TEXT), self.child_info)
+ parent = models.Book.from_text_and_meta(ContentFile(PARENT_TEXT), self.parent_info)
+ CHILD_TEXT = """
+
+ KotAla ma kota
+
+ """
+ child = models.Book.from_text_and_meta(ContentFile(CHILD_TEXT), self.child_info, overwrite=True)
+
+ themes = self.client.get(parent.get_absolute_url()).context['book_themes']
+
+ self.assertEqual(['Kot'], [tag.name for tag in themes],
+ 'wrong related theme list')