# HG changeset patch
# User rougeronj
# Date 1351158181 -7200
# Node ID 1d071843f134c2dce35bbbf847bbaca64d45dee7
# Parent 0d9c00ae275506d55a2970d6be6e8fc53de5d037
Update of ldt_utils unit test
diff -r 0d9c00ae2755 -r 1d071843f134 src/ldt/ldt/ldt_utils/tests/__init__.py
--- a/src/ldt/ldt/ldt_utils/tests/__init__.py Fri Oct 19 16:10:22 2012 +0200
+++ b/src/ldt/ldt/ldt_utils/tests/__init__.py Thu Oct 25 11:43:01 2012 +0200
@@ -1,1 +1,4 @@
-from tests import *
+from content_tests import *
+from ldt_tests import *
+from media_tests import *
+from project_tests import *
diff -r 0d9c00ae2755 -r 1d071843f134 src/ldt/ldt/ldt_utils/tests/content_tests.py
--- a/src/ldt/ldt/ldt_utils/tests/content_tests.py Fri Oct 19 16:10:22 2012 +0200
+++ b/src/ldt/ldt/ldt_utils/tests/content_tests.py Thu Oct 25 11:43:01 2012 +0200
@@ -0,0 +1,59 @@
+"""
+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 OAuthWebTestCase, 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 Client
+import lxml.etree
+import tempfile
+import unittest
+import uuid
+import logging
+
+class ContentTest(TestCase):
+
+ fixtures = ['base_data.json', 'user_data.json']
+
+ def setUp(self):
+ self.client = Client()
+ User.objects.create_superuser('blop', 'blop@blop.com', 'blop')
+
+ client = self.client.login(username='blop', password='blop')
+
+ self.user = User()
+ self.user.username = 'blop'
+
+ def test_create_content(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):
+ 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.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)
+"""
diff -r 0d9c00ae2755 -r 1d071843f134 src/ldt/ldt/ldt_utils/tests/ldt_tests.py
--- a/src/ldt/ldt/ldt_utils/tests/ldt_tests.py Fri Oct 19 16:10:22 2012 +0200
+++ b/src/ldt/ldt/ldt_utils/tests/ldt_tests.py Thu Oct 25 11:43:01 2012 +0200
@@ -0,0 +1,164 @@
+"""
+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 OAuthWebTestCase, 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 Client
+import lxml.etree
+import tempfile
+import unittest
+import uuid
+import logging
+
+class UtilsTest(TestCase):
+
+ fixtures = ['base_data.json', 'user_data.json']
+
+ def setUp(self):
+ self.client = Client()
+ User.objects.create_superuser('blop', 'blop@blop.com', 'blop')
+
+ client = self.client.login(username='blop', password='blop')
+
+ self.user = User()
+ self.user.username = 'blop'
+
+ self.LU = LdtUtils()
+ self.project = Project(title="titleproj1", owner=self.user)
+ self.project.ldt = ' CA: prof et admin conseil de classe Reprise de la figure precedente TC: prof et admin Conseil de classe Argumentation conseil de classe Reprise de la figure precedente Bout a bout 1 '
+ self.project.id = "11231"
+ self.project.ldt_id = str(uuid.uuid1())
+ self.project.description = "proj1description"
+ self.project.save()
+
+ self.projectcopy = Project(title="the2ndproject")
+ self.projectcopy.id = "21"
+
+ def tearDown(self):
+ self.project.delete()
+ self.projectcopy.delete()
+
+ def test_generate_ldt(self):
+ self.cont1 = Content(iriurl="cont1_id/iriurl1", duration=123)
+ self.cont1.iri_id = "cont1_id"
+ self.cont1.save()
+
+ self.cont2 = Content(iriurl="cont2_id/iriurl2", duration=100)
+ self.cont2.iri_id = "cont2_id"
+ 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")[0].get("id"), self.cont1.iri_id)
+ self.assertEqual(ldoc.xpath("/iri/medias/media")[0].get("id"), self.cont1.iri_id)
+
+ self.assertEqual(ldoc.xpath("/iri/displays/display/content")[1].get("id"), self.cont2.iri_id)
+ self.assertEqual(ldoc.xpath("/iri/medias/media")[1].get("id"), self.cont2.iri_id)
+ f.close()
+
+ """
+ def test_generate_init(self):
+ self.cont3 = Content(iriurl="id3/iriurl3", duration=111)
+ self.cont3.iri_id = "id3"
+ self.cont3.save()
+
+ self.cont4 = Content(iriurl="id4/iriurl4", duration=111)
+ self.cont4.iri_id = "id4"
+ self.cont4.save()
+
+ self.project.contents.add(self.cont3, self.cont4)
+ ldoc = self.LU.generate_init([], '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/iriurl5", duration=111)
+ self.cont5.iri_id = "id5"
+ self.cont5.save()
+
+ self.cont6 = Content(iriurl="id6/iriurl6", duration=111)
+ 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/iriurl7", duration=111)
+ self.cont7.iri_id = "id7"
+ self.cont7.save()
+
+ self.cont8 = Content(iriurl="id8/iriurl8", duration=111)
+ 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/iriurl9", duration=111)
+ self.cont9.iri_id = "id9"
+ self.cont9.save()
+
+ self.cont10 = Content(iriurl="id10/iriurl10", duration=111)
+ 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/iriurl11", duration=111)
+ 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_id", "cutting_title", "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")
diff -r 0d9c00ae2755 -r 1d071843f134 src/ldt/ldt/ldt_utils/tests/media_tests.py
--- a/src/ldt/ldt/ldt_utils/tests/media_tests.py Fri Oct 19 16:10:22 2012 +0200
+++ b/src/ldt/ldt/ldt_utils/tests/media_tests.py Thu Oct 25 11:43:01 2012 +0200
@@ -0,0 +1,47 @@
+"""
+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 OAuthWebTestCase, 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 Client
+import lxml.etree
+import tempfile
+import unittest
+import uuid
+import logging
+
+class MediaTest(TestCase):
+
+ fixtures = ['base_data.json', 'user_data.json']
+
+ def setUp(self):
+ self.client = Client()
+ User.objects.create_superuser('blop', 'blop@blop.com', 'blop')
+
+ client = self.client.login(username='blop', password='blop')
+
+ self.user = User()
+ self.user.username = 'blop'
+
+ def test_create_media(self):
+ self.media1 = Media()
+ self.media1.id = 1
+ self.media1.save()
+
+ self.assertEqual(Media.objects.get(id=self.media1.id), self.media1)
+
+ def test_del_media(self):
+ self.media2 = Media()
+ self.media2.id = 2
+ self.media2.save()
+
+ self.media2.delete()
+
+ #self.assertEqual(Media.objects.get(id=self.media2.id), None)
\ No newline at end of file
diff -r 0d9c00ae2755 -r 1d071843f134 src/ldt/ldt/ldt_utils/tests/project_tests.py
--- a/src/ldt/ldt/ldt_utils/tests/project_tests.py Fri Oct 19 16:10:22 2012 +0200
+++ b/src/ldt/ldt/ldt_utils/tests/project_tests.py Thu Oct 25 11:43:01 2012 +0200
@@ -0,0 +1,39 @@
+"""
+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 OAuthWebTestCase, 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 Client
+import lxml.etree
+import tempfile
+import unittest
+import uuid
+import logging
+
+class ProjectTest(TestCase):
+
+ fixtures = ['base_data.json', 'user_data.json']
+
+ def setUp(self):
+ self.client = Client()
+ User.objects.create_superuser('blop', 'blop@blop.com', 'blop')
+
+ client = self.client.login(username='blop', password='blop')
+
+ self.user = User()
+ self.user.username = 'blop'
+
+ def test_create_project(self):
+ self.project = Project(title="titleproj1", owner=self.user)
+ self.project.ldt = ' CA: prof et admin conseil de classe Reprise de la figure precedente TC: prof et admin Conseil de classe Argumentation 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
diff -r 0d9c00ae2755 -r 1d071843f134 src/ldt/ldt/ldt_utils/tests/view_tests.py
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/src/ldt/ldt/ldt_utils/tests/view_tests.py Thu Oct 25 11:43:01 2012 +0200
@@ -0,0 +1,38 @@
+"""
+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 OAuthWebTestCase, 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 Client
+import lxml.etree
+import tempfile
+import unittest
+import uuid
+import logging
+
+class ViewsTest(unittest.TestCase):
+ def setUp(self):
+ self.project = Project()
+ self.project.id = "121"
+ self.project.save()
+ self.project.ldt = ' CA: prof et admin conseil de classe Reprise de la figure precedente TC: prof et admin Conseil de classe Argumentation 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()