# HG changeset patch # User rougeronj # Date 1351593025 -3600 # Node ID 31770c3f29faa1b2b8c23e0a1ea8c7e801a0af0f # Parent 1d071843f134c2dce35bbbf847bbaca64d45dee7 Unit test diff -r 1d071843f134 -r 31770c3f29fa src/ldt/ldt/ldt_utils/tests/content_tests.py --- a/src/ldt/ldt/ldt_utils/tests/content_tests.py Thu Oct 25 11:43:01 2012 +0200 +++ b/src/ldt/ldt/ldt_utils/tests/content_tests.py Tue Oct 30 11:30:25 2012 +0100 @@ -30,30 +30,44 @@ self.user = User() self.user.username = 'blop' - def test_create_content(self): + #test the creation of a content without media + def test_create_content_v1(self): self.cont12 = Content(iriurl="id12/iriurl12", duration = 100) self.cont12.iri_id = "id112" self.cont12.save() self.assertEqual(Content.objects.get(iri_id=self.cont12.iri_id), self.cont12) - def test_del_content(self): + #test the creation of a content with a media + def test_create_content_v2(self): + self.media13 = Media() + self.cont13 = Content(iriurl="id13/iriurl13", duration = 100, media_obj = self.media13) self.cont13 = Content(iriurl="id13/iriurl13", duration = 100) self.cont13.iri_id = "id113" self.cont13.save() - self.cont13.delete() - self.cont13.commit() - #self.assertEqual(Content.objects.get(iri_id=self.cont13.iri_id), None) - + self.assertEqual(Content.objects.get(iri_id=self.cont13.iri_id), self.cont13) + + #test the deletion of a content without media + def test_del_content_v1(self): + self.cont14 = Content(iriurl="id14/iriurl14", duration = 100) + self.cont14.iri_id = "id114" + self.cont14.save() + + self.cont14.delete() + self.cont14.commit() -""" - self.project.contents.add(self.cont5, self.cont6) - self.project.ldt = "" - create_ldt(self.project, self.user) - ldt = lxml.etree.fromstring(self.project.ldt_encoded) - self.assertEqual(ldt.xpath("/iri")[0].tag, "iri") - self.assertEqual(ldt.xpath("/iri/project")[0].get("title"), self.project.title) - self.assertEqual(ldt.xpath("/iri/medias/media")[0].get("src"), self.cont5.iri_url()) - self.assertEqual(ldt.xpath("/iri/medias/media")[1].get("id"), self.cont6.iri_id) -""" + self.assertIsNone(Content.objects.get(iri_id=self.cont14.iri_id)) + + #test the deletion of a content with media + def test_del_content_v2(self): + self.media15 = Media() + self.cont15 = Content(iriurl="id15/iriurl15", duration = 100, media_obj = self.media15) + self.cont15.iri_id = "id115" + self.cont15.save() + + self.cont15.delete() + self.cont15.commit() + + self.assertIsNone(Content.objects.get(iri_id=self.cont15.iri_id)) + \ No newline at end of file diff -r 1d071843f134 -r 31770c3f29fa src/ldt/ldt/ldt_utils/tests/media_tests.py --- a/src/ldt/ldt/ldt_utils/tests/media_tests.py Thu Oct 25 11:43:01 2012 +0200 +++ b/src/ldt/ldt/ldt_utils/tests/media_tests.py Tue Oct 30 11:30:25 2012 +0100 @@ -44,4 +44,4 @@ self.media2.delete() - #self.assertEqual(Media.objects.get(id=self.media2.id), None) \ No newline at end of file + self.assertIsNone(Media.objects.get(id=self.media2.id)) \ No newline at end of file diff -r 1d071843f134 -r 31770c3f29fa src/ldt/ldt/ldt_utils/tests/project_tests.py --- a/src/ldt/ldt/ldt_utils/tests/project_tests.py Thu Oct 25 11:43:01 2012 +0200 +++ b/src/ldt/ldt/ldt_utils/tests/project_tests.py Tue Oct 30 11:30:25 2012 +0100 @@ -31,9 +31,25 @@ self.user.username = 'blop' def test_create_project(self): - self.project = Project(title="titleproj1", owner=self.user) - self.project.ldt = ' CA: prof et admin <abstract/> <audio source=""/> <tags/> </element> <element id="s_0050F043-3AD2-0A7C-6699-D2A03A1EBA02" begin="5052858" dur="124407" author="" date="2010/09/02" color="10053375" src=""> <title>conseil de classe Reprise de la figure precedente TC: prof et admin Conseil de classe conseil de classe Reprise de la figure precedente Bout a bout 1 ' - self.project.id = "111" - self.project.ldt_id = str(uuid.uuid1()) - self.project.description = "proj1description" - self.project.save() \ No newline at end of file + self.project2 = Project(title="titleproj2", owner=self.user) + self.project2.ldt = ' CA: prof et admin <abstract/> <audio source=""/> <tags/> </element> <element id="s_0050F043-3AD2-0A7C-6699-D2A03A1EBA02" begin="5052858" dur="124407" author="" date="2010/09/02" color="10053375" src=""> <title>conseil de classe Reprise de la figure precedente TC: prof et admin Conseil de classe conseil de classe Reprise de la figure precedente Bout a bout 1 ' + self.project2.id = "222" + self.project2.ldt_id = str(uuid.uuid1()) + self.project2.description = "proj2description" + self.project2.save() + + self.assertIs(Project.objects.get(id=self.project2.id), self.project2) + + #test deletion of project without annotation + def test_del_project_v1(self): + self.project3 = Project(title="titleproj3", owner=self.user) + self.project3.ldt = ' CA: prof et admin <abstract/> <audio source=""/> <tags/> </element> <element id="s_0050F043-3AD2-0A7C-6699-D2A03A1EBA02" begin="5052858" dur="124407" author="" date="2010/09/02" color="10053375" src=""> <title>conseil de classe Reprise de la figure precedente TC: prof et admin Conseil de classe conseil de classe Reprise de la figure precedente Bout a bout 1 ' + self.project3.id = "333" + self.project3.ldt_id = str(uuid.uuid1()) + self.project3.description = "proj2description" + self.project3.save() + + self.project3.delete() + + self.assertIsNone(Project.objects.get(ldt_id=self.project3.ldt_id)) + \ No newline at end of file diff -r 1d071843f134 -r 31770c3f29fa src/ldt/ldt/ldt_utils/tests/tests.py --- a/src/ldt/ldt/ldt_utils/tests/tests.py Thu Oct 25 11:43:01 2012 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,215 +0,0 @@ -""" -This file demonstrates two different styles of tests (one doctest and one -unittest). These will both pass when you run "manage.py test". - -Replace these with more appropriate tests for your application. -""" - -from ldt.test.testcases import OAuthTestCase, TestCase -from django.conf import settings -from django.test import TestCase -from ldt.ldt_utils.models import User, Project, Content, Media -from ldt.ldt_utils.utils import LdtUtils, LdtAnnotation, create_ldt, create_empty_iri, copy_ldt -from ldt.test.client import WebClient -import lxml.etree -import tempfile -import unittest -import uuid -import logging - -CONSUMER_KEY = 'dpf43f3p2l4k3l03' -CONSUMER_SECRET = 'kd94hf93k423kf44' - -class UtilsTest(OAuthTestCase): - - fixtures = ['base_data.json', 'user_data.json'] - - def setUp(self): - logging.disable(logging.CRITICAL) - self.user = User() - self.user.username = 'admin' - #self.set_login_url("/auth_accounts/login/") - self.set_consumer(CONSUMER_KEY, CONSUMER_SECRET) - self.client.login(username='admin', password='') - - self.LU = LdtUtils() - self.project = Project(title="titleproj1", owner=self.user) - self.project.ldt = ' CA: prof et admin <abstract/> <audio source=""/> <tags/> </element> <element id="s_0050F043-3AD2-0A7C-6699-D2A03A1EBA02" begin="5052858" dur="124407" author="" date="2010/09/02" color="10053375" src=""> <title>conseil de classe Reprise de la figure precedente TC: prof et admin Conseil de classe conseil de classe Reprise de la figure precedente Bout a bout 1 ' - self.project.id = "11" - self.project.ldt_id = str(uuid.uuid1()) - self.project.description = "proj1description" - self.project.save() - - self.projectcopy = Project(title="the2ndproject") - self.projectcopy.id = "22" - - def tearDown(self): - self.project.delete() - self.projectcopy.delete() - #self.cont1.delete() - #self.cont2.delete() - - def test_generate_ldt(self): - self.cont1 = Content(iriurl="id1/iriurl1") - self.cont1.iri_id = "id1" - self.cont1.save() - - self.cont2 = Content(iriurl="id2/iriurl2") - self.cont2.iri_id = "id2" - self.cont2.save() - - self.project.contents.add(self.cont1, self.cont2) - - f = tempfile.TemporaryFile(mode='r+') - doc = self.LU.generate_ldt(Content.objects.all()) - doc.write(f, pretty_print=True) - f.seek(0) - ldoc = lxml.etree.parse(f) - self.assertEqual(ldoc.xpath("/iri/displays/display/content")[10].get("id"), self.cont2.iri_id) - self.assertEqual(ldoc.xpath("/iri/medias/media")[9].get("id"), self.cont1.iri_id) - f.close() - - def test_generate_init(self): - self.cont3 = Content(iriurl="id3/iriurl1") - self.cont3.iri_id = "id3" - self.cont3.save() - - self.cont4 = Content(iriurl="id4/iriurl2") - self.cont4.iri_id = "id4" - self.cont4.save() - - self.project.contents.add(self.cont3, self.cont4) - ldoc = self.LU.generate_init(['all', 'foo'], 'ldt.ldt_utils.views.search_ldt') - self.assertEqual(ldoc.xpath("/iri/files/init")[0].tag, "init") - self.assertEqual(ldoc.xpath("/iri/files/library")[0].tag, "library") - - def test_create_ldt(self): - self.cont5 = Content(iriurl="id5/iriurl1") - self.cont5.iri_id = "id5" - self.cont5.save() - - self.cont6 = Content(iriurl="id6/iriurl2") - self.cont6.iri_id = "id6" - self.cont6.save() - - self.project.contents.add(self.cont5, self.cont6) - self.project.ldt = "" - create_ldt(self.project, self.user) - ldt = lxml.etree.fromstring(self.project.ldt_encoded) - self.assertEqual(ldt.xpath("/iri")[0].tag, "iri") - self.assertEqual(ldt.xpath("/iri/project")[0].get("title"), self.project.title) - self.assertEqual(ldt.xpath("/iri/medias/media")[0].get("src"), self.cont5.iri_url()) - self.assertEqual(ldt.xpath("/iri/medias/media")[1].get("id"), self.cont6.iri_id) - - def test_copy_ldt(self): - self.cont7 = Content(iriurl="id7/iriurl1") - self.cont7.iri_id = "id7" - self.cont7.save() - - self.cont8 = Content(iriurl="id8/iriurl2") - self.cont8.iri_id = "id8" - self.cont8.save() - - self.project.contents.add(self.cont7, self.cont8) - copy_ldt(self.project, self.projectcopy, self.user) - ldt1 = lxml.etree.fromstring(self.project.ldt_encoded) - ldt2 = lxml.etree.fromstring(self.projectcopy.ldt_encoded) - self.assertTrue(ldt1.xpath("/iri/project")[0].get("id") != ldt2.xpath("/iri/project")[0].get("id")) - self.assertEqual(ldt1.xpath("/iri/medias/media")[0].get("id"), ldt2.xpath("/iri/medias/media")[0].get("id")) - self.assertEqual(ldt1.xpath("/iri/annotations/content/ensemble")[0].get("title"), ldt2.xpath("/iri/annotations/content/ensemble")[0].get("title")) - self.assertEqual(ldt1.xpath("/iri/annotations/content/ensemble/decoupage")[0].get("id"), ldt2.xpath("/iri/annotations/content/ensemble/decoupage")[0].get("id")) - self.assertEqual(ldt1.xpath("/iri/annotations/content/ensemble/decoupage/title")[1].text, ldt2.xpath("/iri/annotations/content/ensemble/decoupage/title")[1].text.strip("\n\t")) - - def test_create_empty_iri(self): - self.cont9 = Content(iriurl="id9/iriurl1") - self.cont9.iri_id = "id9" - self.cont9.save() - - self.cont10 = Content(iriurl="id10/iriurl2") - self.cont10.iri_id = "id10" - self.cont10.save() - - self.project.contents.add(self.cont9, self.cont10) - tmp = tempfile.TemporaryFile(mode='r+') - create_empty_iri(tmp, self.cont9, "admin") - tmp.seek(0) - ldoc = lxml.etree.parse(tmp) - self.assertEqual(ldoc.xpath("/iri/head/meta")[0].get("content"), self.cont9.iri_id) - self.assertEqual(ldoc.xpath("/iri/body/medias/media/video")[0].get("id"), self.cont9.iri_id) - tmp.close() - - def test_add_annotation(self): - - self.cont11 = Content(iriurl="id11/iriurl1") - self.cont11.iri_id = "id11" - self.cont11.save() - - self.project.contents.add(self.cont11) - self.project.ldt = "" - create_ldt(self.project, self.user) - - self.LA = LdtAnnotation(self.project) - - self.LA.add("id11", "cutting", "title", "text", ["tag1", "tag2"], "800", - "10000", "jdoe", "2011-09-10T09:12:58") - self.LA.save() - ldt = lxml.etree.fromstring(self.project.ldt) - ann = ldt.xpath('/iri/annotations/content[@id="id11"]/ensemble/decoupage/elements/element')[0] - title = ann.xpath('title')[0].text - abstract = ann.xpath('abstract')[0].text - - self.assertEqual(ann.get("author"), "jdoe") - self.assertEqual(title, "title") - self.assertEqual(abstract, "text") - - def test_create_content(self): - self.cont12 = Content(iriurl="id12/iriurl1") - self.cont12.iri_id = "id112" - self.cont12.save() - - """ - def test_create_media(self): - self.media = Media() - - def test_create_project(self): - self.project = Project() - - def test_del_content(self): - self.cont13 = Content(iriurl="id13/iriurl1") - self.cont13.iri_id = "id113" - self.cont13.save() - - self.cont13.delete() - - def test_del_media(self): - self.media2 = Media() - - seld.media2.delete() - - def test_del_project(self): - self.project = Project() - - self.project.delete() - """ - - -class ViewsTest(unittest.TestCase): - def setUp(self): - self.project = Project() - self.project.id = "121" - self.project.save() - self.project.ldt = ' CA: prof et admin <abstract/> <audio source=""/> <tags/> </element> <element id="s_0050F043-3AD2-0A7C-6699-D2A03A1EBA02" begin="5052858" dur="124407" author="" date="2010/09/02" color="10053375" src=""> <title>conseil de classe Reprise de la figure precedente TC: prof et admin Conseil de classe conseil de classe Reprise de la figure precedente Bout a bout 1 ' - - self.cont1 = Content(iriurl="/laurentcantet_entrelesmurs/iriurl1") - self.cont1.iri_id = 'laurentcantet_entrelesmurs' - self.cont1.save() - - self.cont2 = Content(iriurl="/content_notinldt/iriurl2") - self.cont2.iri_id = 'content_notinldt' - self.cont2.save() - - self.project.contents.add(self.cont1, self.cont2) - - def tearDown(self): - self.project.delete() -