web/ldt/text/tests.py
changeset 21 1a061f244254
parent 19 7cf81d58a968
--- a/web/ldt/text/tests.py	Fri Nov 19 18:14:02 2010 +0100
+++ b/web/ldt/text/tests.py	Tue Nov 23 17:54:36 2010 +0100
@@ -18,15 +18,10 @@
 from ldt.text import VERSION_STR
 from django.db import transaction
 from django.contrib.auth.models import User
-from oauth_provider.models import Resource, Consumer
 import time
-from oauth_provider.models import Token
-from oauth.oauth import OAuthRequest, OAuthSignatureMethod_HMAC_SHA1
-from django.contrib.auth.models import User
-from oauth_provider.models import Resource, Consumer, Token, Nonce
-import time
-from oauth_provider.consts import OUT_OF_BAND
-from oauth.oauth import OAuthRequest, OAuthSignatureMethod_PLAINTEXT, generate_nonce
+import lucene
+from ldt.text import STORE, ANALYZER
+from ldt.text.utils import *
 
 
 # This test creates an annotation and checks that:
@@ -129,7 +124,7 @@
         uri = "http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168"
         filter = 'lors'
         limit = None
-        response = self.c.get('/api/'+ VERSION_STR +'/text/filter/', {'uri':uri,'filter':'lors'})
+        response = self.c.get('/api/'+ VERSION_STR +'/text/filter/', {'uri':uri,'filter':filter})
         doc = lxml.etree.fromstring(response.content)
         for elem in doc.xpath("/iri/text-annotation/content/text/text()"):
             self.assertTrue('lors' in elem)  
@@ -144,11 +139,12 @@
     def setUp(self):
         self.annotation = Annotation(external_id="d2c1d1fa-629d-4520-a3d2-955b4f2582c0",title="titre de l\'annotation",text="texte selectionne lors de la creation de l\'annotation",color="#AAAAAA", creation_date="2010-09-06T12:33:53.417550", update_date="2010-09-06T12:33:53.420459")
         self.annotation.save()
-        self.c = Client()    
+        self.c = Client()
     def tearDown(self):
         annotlist=Annotation.objects.all()
         for annot in annotlist:
             annot.delete()
+        
     
     def test_delete_annotation(self):
         id = urllib.urlencode({'id':'d2c1d1fa-629d-4520-a3d2-955b4f2582c0'})
@@ -160,7 +156,8 @@
         self.assertEqual(doc.xpath("/iri/text-annotation/tags/tag/text()"), [])
         self.assertEqual(doc.xpath("/iri/text-annotation/content/color/text()"),[])
         self.assertEqual(doc.xpath("/iri/text-annotation/meta/creator/text()"),[])
-        self.assertEqual(response2.status_code, 404)   
+        self.assertEqual(response2.status_code, 404)
+
 
     def test_error_delete(self):
         response = self.c.post('/api/'+ VERSION_STR +'/text/ldt/delete/', {'id':'1'})
@@ -203,151 +200,35 @@
         self.filt1 = urllib.urlencode({"uri":"http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168", "creator":"","limit":"","filter":""})
         self.filt2 = urllib.urlencode({"uri":"http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168","creator":"wakimd","limit":"","filter":""})
         self.up = urllib.urlencode({'content':'<iri><text-annotation><id></id><uri></uri><tags><tag>tag1</tag><tag>tag2new</tag><tag>tag3</tag></tags><content><color>#DDDDDD</color><description><![CDATA[texte de description update]]></description><title></title><text><![CDATA[texte selectionne a nouveau lors de la creation de l\'annotation]]></text></content><meta><contributor>oaubert</contributor><contributor-id>80cd0532-1dda-4130-b351-6a181130a7c9</contributor-id><created></created><creator></creator><creator-id></creator-id><modified>2010-11-06 12:33:53.420459</modified></meta></text-annotation></iri>','id':'mypersonnalid'})
+        self.LS = LdtSearch()
     
     def test_everything(self):
         creation = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/create/", self.content)
         creation2 = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/create/", self.content2)
+
+        res1 = self.LS.query("title","titre de l'annotation")
+        self.assertEqual(len(res1),1)
+        res2 = self.LS.query("title","titre de l'annotation2")
+        self.assertEqual(len(res2),1)
+
         
         get = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/get/?%s" % self.id)
         
         update = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/update/", self.up)
         
-        filt1 = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/filter/?%s", self.uri)
+        res3 = self.LS.query("abstract","texte de description update")
+        self.assertEqual(len(res3),1)
+        
+        filt1 = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/filter/?%s" % self.uri)
         filt2 = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/filter/?uri=http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168?creator=wakimd")
-        tmp = open('debug.html','r+')
-        tmp.write(filt2.read())
-        
+
         delete = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/delete/", self.id)
         delete = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/delete/", self.id2)
 
-        
-class OauthTestDelete(unittest.TestCase):
-    def setUp(self):
-        #create a user
-        self.jane = User.objects.create_user('jane', 'jane@example.com', 'toto')
-
-        resource = Resource(name='delete', url='/api/1.0/text/delete/')
-        resource.save()
-
-        self.CONSUMER_KEY = 'dpf43f3p2l4k3l03'
-        self.CONSUMER_SECRET = 'kd94hf93k423kf44'
-        self.consumer = Consumer(key=self.CONSUMER_KEY, secret=self.CONSUMER_SECRET, name='printer.example.com', user=self.jane)
-        self.consumer.save()
-        
-        self.nonce = generate_nonce(8)
-        
-        #auth parameters
-        self.parameters = {
-            'oauth_consumer_key': self.CONSUMER_KEY,
-            'oauth_signature_method': 'PLAINTEXT',
-            'oauth_signature': '%s&' % self.CONSUMER_SECRET,
-            'oauth_timestamp': str(int(time.time())),
-            'oauth_nonce': self.nonce,
-            'oauth_version': '1.0',
-            'oauth_callback': 'http://printer.example.com/request_token_ready',
-            'scope':'delete'
-        }
-        
-        #test client
-        self.c = Client()
-        
-        self.annotation = Annotation(external_id="d2c1d1fa-629d-4520-a3d2-955b4f2582c0",title="titre de l\'annotation",text="texte selectionne lors de la creation de l\'annotation",color="#AAAAAA", creation_date="2010-09-06T12:33:53.417550", update_date="2010-09-06T12:33:53.420459")
-        self.annotation.save()
-        
-    def tearDown(self):
-        Token.objects.all().delete()
-        Resource.objects.all().delete()
-        Consumer.objects.all().delete()
-        Nonce.objects.all().delete()
-        User.objects.all().delete()
+        res4 = self.LS.query("title","titre de l'annotation")
+        self.assertEqual(len(res4),0)
+        res5 = self.LS.query("title","titre de l'annotation2")
+        self.assertEqual(len(res5),0)
 
         
-    def test_auth_access_delete(self):
-        ## REQUEST TOKEN
         
-        response = self.c.get("/oauth/request_token/", self.parameters)
-        #self.assertEqual(response.content,"  ")
-        self.assertEqual(response.status_code,200)   
-        token = list(Token.objects.all())[-1]
-        self.assertTrue(token.key in response.content)
-        self.assertTrue(token.secret in response.content)
-        self.assertEqual(token.callback, u'http://printer.example.com/request_token_ready'),
-        self.assertTrue(token.callback_confirmed)
-
-#        token.callback = OUT_OF_BAND
-#        token.save()
-#        
-        ## USER AUTHORIZATION
-        
-        parameters = {
-            'oauth_token': token.key,
-        }
-        
-        response = self.c.get("/oauth/authorize/", parameters)
-        self.assertEqual(response.status_code,302)
-        self.assertTrue(token.key in response['Location'])
-        
-        self.c.login(username='jane', password='toto')
-        
-        response = self.c.get("/oauth/authorize/", parameters)
-        self.assertEqual(response.status_code,200)
-        self.assertEqual(response.content,'Fake authorize view for printer.example.com.')
-    
-#        parameters['authorize_access'] = 0
-#        response = self.c.post("/oauth/authorize/", parameters)
-#        self.assertEqual(response.content, "Fake callback view.")
-        
-        # fake authorization by the user
-        parameters['authorize_access'] = 1
-        response = self.c.post("/oauth/authorize/", parameters)
-        self.assertEqual(response.status_code,302)
-        token = list(Token.objects.all())[-1]
-        self.assertTrue(token.key in response['Location'])
-        self.assertTrue(token.is_approved)
-        
-        ## ACCESS TOKEN
-        
-        parameters = {
-            'oauth_consumer_key': self.CONSUMER_KEY,
-            'oauth_token': token.key,
-            'oauth_signature_method': 'PLAINTEXT',
-            'oauth_signature': '%s&%s' % (self.CONSUMER_SECRET, token.secret),
-            'oauth_timestamp': str(int(time.time())),
-            'oauth_nonce': self.nonce,
-            'oauth_version': '1.0',
-            'oauth_verifier': token.verifier,
-        }
-        response = self.c.get("/oauth/access_token/", parameters)
-        
-        access_token = list(Token.objects.filter(token_type=Token.ACCESS))[-1]
-        self.assertTrue(access_token.key in response.content)
-        self.assertTrue(access_token.secret in response.content)
-        self.assertEqual(access_token.user.username, u'jane')
-        
-        ## ACCESSING PROTECTED VIEW
-        
-        parameters = {
-            'oauth_consumer_key': self.CONSUMER_KEY,
-            'oauth_token': access_token.key,
-            'oauth_signature_method': 'HMAC-SHA1',
-            'oauth_timestamp': str(int(time.time())),
-            'oauth_nonce': self.nonce,
-            'oauth_version': '1.0',
-        }
-        
-        oauth_request = OAuthRequest.from_token_and_callback(access_token, http_url='/api/1.0/text/delete/', parameters=parameters)
-        signature_method = OAuthSignatureMethod_HMAC_SHA1()
-        signature = signature_method.build_signature(oauth_request, self.consumer, access_token)
-
-        parameters['oauth_signature'] = signature
-        #self.assertEqual(signature, "  ")
-        parameters['id'] = 'd2c1d1fa-629d-4520-a3d2-955b4f2582c0'
-        response = self.c.post("/api/1.0/text/delete/", parameters)
-        self.assertEqual(response.content, "  ")
-        self.assertEqual(response.status_code,200)
-        
-        self.c.logout()
-        access_token.delete()
-#/api/1.0/text/delete/
-#/api/1.0/text/update/
-#/api/1.0/text/create/        
\ No newline at end of file