| author | wakimd |
| Fri, 19 Nov 2010 18:12:57 +0100 | |
| changeset 19 | 7cf81d58a968 |
| parent 17 | 683ce4109c28 |
| child 21 | 1a061f244254 |
| permissions | -rw-r--r-- |
| 9 | 1 |
#encoding:UTF-8 |
2 |
||
3 |
""" Run these tests with 'python manage.py test text' """ |
|
4 |
||
5 |
from django.test import TestCase |
|
6 |
import unittest |
|
7 |
import lxml.etree |
|
8 |
from ldt.text.models import * |
|
9 |
from ldt.core.models import Owner |
|
10 |
from views import * |
|
| 16 | 11 |
import urllib |
| 9 | 12 |
import uuid |
13 |
import tempfile |
|
14 |
import datetime |
|
15 |
from django.contrib.auth.models import * |
|
16 |
from django.conf import settings |
|
17 |
from django.test.client import Client |
|
18 |
from ldt.text import VERSION_STR |
|
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
19 |
from django.db import transaction |
| 19 | 20 |
from django.contrib.auth.models import User |
21 |
from oauth_provider.models import Resource, Consumer |
|
22 |
import time |
|
23 |
from oauth_provider.models import Token |
|
24 |
from oauth.oauth import OAuthRequest, OAuthSignatureMethod_HMAC_SHA1 |
|
25 |
from django.contrib.auth.models import User |
|
26 |
from oauth_provider.models import Resource, Consumer, Token, Nonce |
|
27 |
import time |
|
28 |
from oauth_provider.consts import OUT_OF_BAND |
|
29 |
from oauth.oauth import OAuthRequest, OAuthSignatureMethod_PLAINTEXT, generate_nonce |
|
| 9 | 30 |
|
31 |
||
32 |
# This test creates an annotation and checks that: |
|
33 |
# 1. the annotation was created in the database (by trying to access it through a 'get') |
|
34 |
# 2. the returned xml contains correct data |
|
35 |
class CreateTest(unittest.TestCase): |
|
36 |
def setUp(self): |
|
| 16 | 37 |
self.content = str('<iri><text-annotation><id>f2c1d1fa-629d-4520-a3d2-955b4f2582c0</id><uri>http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168</uri><tags><tag>tag1</tag><tag>tag2</tag></tags><content><color>#AAAAAA</color><description><![CDATA[texte de description]]></description><title><![CDATA[titre de l\'annotation]]></title><text><![CDATA[texte selectionne lors de la creation de l\'annotation]]></text></content><meta><contributor>oaubert</contributor><contributor-id>79cd0532-1dda-4130-b351-6a181130a7c9</contributor-id><created>2010-09-06 12:33:53.417550</created><creator>oaubert</creator><creator-id>79cd0532-1dda-4130-b351-6a181130a7c9</creator-id><modified>2010-09-06 12:33:53.420459</modified></meta></text-annotation></iri>') |
| 9 | 38 |
self.c = Client() |
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
39 |
self.annot = Annotation(external_id=u'd2c1d1fa-629d-4520-a3d2-955b4f2582c0', uri=u'http://iri.blabla', tags=u"tag1,tag2", title=u'montitre', description=u'madesc', text=u'letexteselectionne', color=u'#AAAAAA', creator=u'wakimd', contributor=u'wakimd', creation_date=u'2010-09-06 12:33:53.417550', update_date=u'2010-09-06 12:33:53.417550') |
| 9 | 40 |
self.annot.save() |
41 |
def tearDown(self): |
|
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
42 |
transaction.rollback() |
| 9 | 43 |
annotlist=Annotation.objects.all() |
44 |
for annot in annotlist: |
|
45 |
annot.delete() |
|
46 |
||
47 |
def test_create_annotation(self): |
|
48 |
response = self.c.post('/api/'+ VERSION_STR +'/text/create/', {'content':self.content}) |
|
| 16 | 49 |
#self.assertEqual(response.content, " ") |
| 9 | 50 |
self.annot1 = lxml.etree.fromstring(response.content) |
51 |
self.assertEqual(self.annot1.xpath("/iri/text-annotation/id/text()")[0],"f2c1d1fa-629d-4520-a3d2-955b4f2582c0") |
|
52 |
self.assertEqual(self.annot1.xpath("/iri/text-annotation/content")[0].tag,"content") |
|
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
53 |
self.assertEqual(self.annot1.xpath("/iri/text-annotation/tags/tag/text()")[0],u"tag1") |
| 9 | 54 |
self.assertEqual(self.annot1.xpath("/iri/text-annotation/content/text/text()")[0],u"texte selectionne lors de la creation de l\'annotation") |
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
55 |
#self.assertEqual(self.annot1.xpath("/iri/text-annotation/meta/created/text()")[0],"2010-09-06 12:33:53.417550") |
| 16 | 56 |
response2 = self.c.get('/api/'+ VERSION_STR +'/text/get/', {'id':'f2c1d1fa-629d-4520-a3d2-955b4f2582c0'}) |
57 |
annot2 = lxml.etree.fromstring(response.content) |
|
58 |
self.assertEqual(annot2.xpath("/iri/text-annotation/uri/text()")[0], "http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168") |
|
| 9 | 59 |
|
| 16 | 60 |
def test_error_create(self): |
61 |
content = '<iri><text-annotation><id>d2c1d1fa-629d-4520-a3d2-955b4f2582c0</id><uri>http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168</uri><tags><tag>tag1</tag><tag>tag2</tag></tags><content><color>#AAAAAA</color><description><![CDATA[texte de description]]></description><title><![CDATA[titre de l\'annotation]]></title><text><![CDATA[texte selectionne lors de la creation de l\'annotation]]></text></content><meta><contributor>oaubert</contributor><contributor-id>79cd0532-1dda-4130-b351-6a181130a7c9</contributor-id><created>2010-09-06 12:33:53.417550</created><creator>oaubert</creator><creator-id>79cd0532-1dda-4130-b351-6a181130a7c9</creator-id><modified>2010-09-06 12:33:53.420459</modified></meta></text-annotation></iri>' |
|
62 |
response = self.c.post('/api/'+ VERSION_STR +'/text/create/', {'content':content}) |
|
63 |
self.assertEqual(response.status_code, 409) |
|
| 9 | 64 |
|
65 |
||
66 |
# This test creates an annotation, then gets it, and checks that the returned xml contains correct data |
|
67 |
class GetTest(unittest.TestCase): |
|
68 |
def setUp(self): |
|
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
69 |
self.annotation = Annotation(external_id="d2c1d1fa-629d-4520-a3d2-955b4f2582c0", tags=u"tag1 ,tag2 , tag3", title="titre de l\'annotation",text="texte selectionne lors de la creation de l\'annotation",color="#AAAAAA", creation_date="2010-09-06 12:33:53.417550", update_date="2010-09-06 12:33:53.420459") |
| 9 | 70 |
self.annotation.save() |
71 |
self.c = Client() |
|
72 |
def tearDown(self): |
|
73 |
annotlist=Annotation.objects.all() |
|
74 |
for annot in annotlist: |
|
75 |
annot.delete() |
|
76 |
||
77 |
def test_get_annotation(self): |
|
78 |
response = self.c.get('/api/'+ VERSION_STR +'/text/get/', {'id':'d2c1d1fa-629d-4520-a3d2-955b4f2582c0'}) |
|
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
79 |
print response |
| 9 | 80 |
self.annot1 = lxml.etree.fromstring(response.content) |
81 |
self.assertEqual(self.annot1.xpath("/iri/text-annotation/id/text()")[0],self.annotation.external_id) |
|
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
82 |
self.assertEqual(self.annot1.xpath("/iri/text-annotation/tags/tag/text()")[1], "tag2") |
| 9 | 83 |
self.assertEqual(self.annot1.xpath("/iri/text-annotation/content/color/text()")[0],self.annotation.color) |
84 |
self.assertEqual(self.annot1.xpath("/iri/text-annotation/meta/created/text()")[0], str(self.annotation.creation_date)) |
|
85 |
||
| 10 | 86 |
def test_error_get(self): |
87 |
response = self.c.get('/api/'+ VERSION_STR +'/text/get/', {'id':'2'}) |
|
88 |
self.assertEqual(response.status_code,404) |
|
| 9 | 89 |
|
90 |
||
91 |
class FilterTest(unittest.TestCase): |
|
92 |
def setUp(self): |
|
93 |
self.annotation = Annotation(external_id="k2c1d1fa-629d-4520-a3d2-955b4f2582c0",title="titre de l\'annotation",text="texte selectionne lors de la creation de l\'annotation",color="#AAAAAA", uri="http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168", creator="wakimd") |
|
94 |
self.annotation.save() |
|
95 |
self.annotation2 = Annotation(external_id="l2c1d1fa-629d-4520-a3d2-955b4f2582c0",title="titre de l\'annotation2",text="texte selectionne lors de la creation de l\'annotation2",color="#BBBBBB", uri="http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168", creator="wakimd") |
|
96 |
self.annotation2.save() |
|
97 |
self.annotation3 = Annotation(external_id="m2c1d1fa-629d-4520-a3d2-955b4f2582c0", title="titre3", text="texte3", color="#CCCCCC", uri="http://blabla", creator="wakimd") |
|
98 |
self.annotation3.save() |
|
99 |
self.c = Client() |
|
100 |
def tearDown(self): |
|
101 |
annotlist=Annotation.objects.all() |
|
102 |
for annot in annotlist: |
|
103 |
annot.delete() |
|
104 |
||
105 |
def test_filter_annotation_creator_limit(self): |
|
106 |
user = 'wakimd' |
|
107 |
uri = "http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168" |
|
108 |
limit= 1 |
|
109 |
response = self.c.get('/api/'+ VERSION_STR +'/text/filter/', {'uri':uri,'creator':user,'limit':limit}) |
|
110 |
doc = lxml.etree.fromstring(response.content) |
|
111 |
cpt = 0 |
|
112 |
for elem in doc.xpath("/iri/text-annotation"): |
|
113 |
cpt = cpt + 1 |
|
114 |
if limit is not None: |
|
115 |
self.assertEqual(cpt,limit) |
|
116 |
for elem in doc.xpath("/iri/text-annotation/meta/creator/text()"): |
|
117 |
self.assertEqual(elem,user) |
|
118 |
for elem in doc.xpath("/iri/text-annotation/uri/text()"): |
|
119 |
self.assertEqual(elem[:57],"http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml") |
|
120 |
||
121 |
def test_filter_annotation_uri(self): |
|
122 |
uri = "http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168" |
|
123 |
response = self.c.get('/api/'+ VERSION_STR +'/text/filter/', {'uri':uri}) |
|
124 |
doc = lxml.etree.fromstring(response.content) |
|
125 |
for elem in doc.xpath("/iri/text-annotation/uri/text()"): |
|
126 |
self.assertEqual(elem[:57],"http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml") |
|
127 |
||
128 |
def test_filter_annotation_filter(self): |
|
129 |
uri = "http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168" |
|
130 |
filter = 'lors' |
|
131 |
limit = None |
|
132 |
response = self.c.get('/api/'+ VERSION_STR +'/text/filter/', {'uri':uri,'filter':'lors'}) |
|
133 |
doc = lxml.etree.fromstring(response.content) |
|
134 |
for elem in doc.xpath("/iri/text-annotation/content/text/text()"): |
|
135 |
self.assertTrue('lors' in elem) |
|
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
136 |
#for elem in doc.xpath("/iri/text-annotation/meta/creator/text()"): |
|
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
137 |
# self.assertEqual(elem,user) |
| 9 | 138 |
|
139 |
||
140 |
# This test creates an annotation, then deletes it, and checks that: |
|
141 |
# 1. the annotation doesn't exist anymore in the database (by trying to access it through a 'get') |
|
142 |
# 2. the returned xml contains no data |
|
143 |
class DeleteTest(unittest.TestCase): |
|
144 |
def setUp(self): |
|
145 |
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") |
|
146 |
self.annotation.save() |
|
147 |
self.c = Client() |
|
148 |
def tearDown(self): |
|
149 |
annotlist=Annotation.objects.all() |
|
150 |
for annot in annotlist: |
|
151 |
annot.delete() |
|
152 |
||
153 |
def test_delete_annotation(self): |
|
| 16 | 154 |
id = urllib.urlencode({'id':'d2c1d1fa-629d-4520-a3d2-955b4f2582c0'}) |
155 |
f = urllib.urlopen("http://127.0.0.1:8000/api/1.0/text/delete/", id) |
|
| 9 | 156 |
response = self.c.post('/api/'+ VERSION_STR +'/text/delete/', {'id':'d2c1d1fa-629d-4520-a3d2-955b4f2582c0'}) |
| 10 | 157 |
response2 = self.c.get('/ldt/get/', {'id':'d2c1d1fa-629d-4520-a3d2-955b4f2582c0'}) |
| 9 | 158 |
doc = lxml.etree.fromstring(response.content) |
159 |
self.assertEqual(doc.xpath("/iri/text-annotation/id/text()"),[]) |
|
160 |
self.assertEqual(doc.xpath("/iri/text-annotation/tags/tag/text()"), []) |
|
161 |
self.assertEqual(doc.xpath("/iri/text-annotation/content/color/text()"),[]) |
|
162 |
self.assertEqual(doc.xpath("/iri/text-annotation/meta/creator/text()"),[]) |
|
| 10 | 163 |
self.assertEqual(response2.status_code, 404) |
| 9 | 164 |
|
| 10 | 165 |
def test_error_delete(self): |
166 |
response = self.c.post('/api/'+ VERSION_STR +'/text/ldt/delete/', {'id':'1'}) |
|
167 |
self.assertEqual(response.status_code,404) |
|
| 9 | 168 |
|
169 |
||
170 |
# This test creates an annotation, then updates it with new content, and checks that the returned xml contains the updated data |
|
171 |
class UpdateTest(unittest.TestCase): |
|
172 |
def setUp(self): |
|
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
173 |
self.annotation = Annotation(external_id="d2c1d1fa-629d-4520-a3d2-955b4f2582c0", tags=u"tag1, mytag",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") |
| 9 | 174 |
self.annotation.save() |
175 |
self.c = Client() |
|
176 |
def tearDown(self): |
|
177 |
annotlist=Annotation.objects.all() |
|
178 |
for annot in annotlist: |
|
179 |
annot.delete() |
|
180 |
||
181 |
def test_update_annotation(self): |
|
| 16 | 182 |
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>' |
183 |
response = self.c.post('/api/'+ VERSION_STR +'/text/update/', {'content':content,'id':'d2c1d1fa-629d-4520-a3d2-955b4f2582c0'}) |
|
| 9 | 184 |
doc = lxml.etree.fromstring(response.content) |
| 16 | 185 |
#self.assertEqual(lxml.etree.tostring(doc), " ") |
186 |
self.assertEqual(doc.xpath("/iri/text-annotation/id/text()")[0],"d2c1d1fa-629d-4520-a3d2-955b4f2582c0") |
|
|
17
683ce4109c28
various corrections, especially on the model (and tags)
ymh <ymh.work@gmail.com>
parents:
16
diff
changeset
|
187 |
self.assertEqual(doc.xpath("/iri/text-annotation/tags/tag/text()")[1], "tag2new") |
| 9 | 188 |
self.assertEqual(doc.xpath("/iri/text-annotation/content/color/text()")[0],"#DDDDDD") |
189 |
||
| 10 | 190 |
def test_error_update(self): |
| 16 | 191 |
content = '<iri><text-annotation><id>d2c1d1fa-629d-4520-a3d2-955b4f2582c0</id><uri>http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168</uri><tags><tag>tag1</tag><tag>tag2</tag></tags><content><color>#AAAAAA</color><description><![CDATA[texte de description]]></description><title><![CDATA[titre de l\'annotation]]></title><text><![CDATA[texte selectionne lors de la creation de l\'annotation]]></text></content><meta><contributor>oaubert</contributor><contributor-id>79cd0532-1dda-4130-b351-6a181130a7c9</contributor-id><created>2010-09-06 12:33:53.417550</created><creator>oaubert</creator><creator-id>79cd0532-1dda-4130-b351-6a181130a7c9</creator-id><modified>2010-09-06 12:33:53.420459</modified></meta></text-annotation></iri>' |
| 10 | 192 |
response = self.c.post('/api/'+ VERSION_STR +'/text/update/', {'content':content,'id':'1'}) |
193 |
self.assertEqual(response.status_code,404) |
|
194 |
||
| 9 | 195 |
|
| 16 | 196 |
class OnServerGlobalTest(unittest.TestCase): |
197 |
def setUp(self): |
|
198 |
self.content = urllib.urlencode({'content':'<iri><text-annotation><id>mypersonnalid</id><uri>http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168</uri><tags><tag>tag1</tag><tag>tag2</tag></tags><content><color>#AAAAAA</color><description><![CDATA[texte de description]]></description><title><![CDATA[titre de l\'annotation]]></title><text><![CDATA[texte selectionne lors de la creation de l\'annotation]]></text></content><meta><contributor>oaubert</contributor><contributor-id>79cd0532-1dda-4130-b351-6a181130a7c9</contributor-id><created>2010-09-06 12:33:53.417550</created><creator>oaubert</creator><creator-id>79cd0532-1dda-4130-b351-6a181130a7c9</creator-id><modified>2010-09-06 12:33:53.420459</modified></meta></text-annotation></iri>'}) |
|
199 |
self.content2 = urllib.urlencode({'content':'<iri><text-annotation><id>mypersonnalid2</id><uri>http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168</uri><tags><tag>tag1</tag><tag>tag2</tag></tags><content><color>#BBBBBB</color><description><![CDATA[texte de description2]]></description><title><![CDATA[titre de l\'annotation2]]></title><text><![CDATA[texte selectionne lors de la creation de l\'annotation2]]></text></content><meta><contributor>wakimd</contributor><contributor-id>79cd0532-1dda-4130-b351-6a181130a7c9</contributor-id><created>2010-09-06 12:33:53.417550</created><creator>oaubert</creator><creator-id>79cd0532-1dda-4130-b351-6a181130a7c9</creator-id><modified>2010-09-06 12:33:53.420459</modified></meta></text-annotation></iri>'}) |
|
200 |
self.id = urllib.urlencode({"id":"mypersonnalid"}) |
|
201 |
self.id2 = urllib.urlencode({"id":"mypersonnalid2"}) |
|
202 |
self.uri = urllib.urlencode({"uri":"http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168"}) |
|
203 |
self.filt1 = urllib.urlencode({"uri":"http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168", "creator":"","limit":"","filter":""}) |
|
204 |
self.filt2 = urllib.urlencode({"uri":"http://www.leezam.com/pub/epub/123456!/OPS/chapter2.xhtml#pos=56,168","creator":"wakimd","limit":"","filter":""}) |
|
205 |
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'}) |
|
206 |
||
207 |
def test_everything(self): |
|
208 |
creation = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/create/", self.content) |
|
209 |
creation2 = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/create/", self.content2) |
|
210 |
||
211 |
get = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/get/?%s" % self.id) |
|
212 |
||
213 |
update = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/update/", self.up) |
|
214 |
||
215 |
filt1 = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/filter/?%s", self.uri) |
|
216 |
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") |
|
217 |
tmp = open('debug.html','r+') |
|
218 |
tmp.write(filt2.read()) |
|
219 |
||
220 |
delete = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/delete/", self.id) |
|
221 |
delete = urllib.urlopen("http://127.0.0.1:8000/api/"+VERSION_STR+"/text/delete/", self.id2) |
|
| 19 | 222 |
|
| 16 | 223 |
|
| 19 | 224 |
class OauthTestDelete(unittest.TestCase): |
225 |
def setUp(self): |
|
226 |
#create a user |
|
227 |
self.jane = User.objects.create_user('jane', 'jane@example.com', 'toto') |
|
228 |
||
229 |
resource = Resource(name='delete', url='/api/1.0/text/delete/') |
|
230 |
resource.save() |
|
231 |
||
232 |
self.CONSUMER_KEY = 'dpf43f3p2l4k3l03' |
|
233 |
self.CONSUMER_SECRET = 'kd94hf93k423kf44' |
|
234 |
self.consumer = Consumer(key=self.CONSUMER_KEY, secret=self.CONSUMER_SECRET, name='printer.example.com', user=self.jane) |
|
235 |
self.consumer.save() |
|
236 |
||
237 |
self.nonce = generate_nonce(8) |
|
238 |
||
239 |
#auth parameters |
|
240 |
self.parameters = { |
|
241 |
'oauth_consumer_key': self.CONSUMER_KEY, |
|
242 |
'oauth_signature_method': 'PLAINTEXT', |
|
243 |
'oauth_signature': '%s&' % self.CONSUMER_SECRET, |
|
244 |
'oauth_timestamp': str(int(time.time())), |
|
245 |
'oauth_nonce': self.nonce, |
|
246 |
'oauth_version': '1.0', |
|
247 |
'oauth_callback': 'http://printer.example.com/request_token_ready', |
|
248 |
'scope':'delete' |
|
249 |
} |
|
250 |
||
251 |
#test client |
|
252 |
self.c = Client() |
|
253 |
||
254 |
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") |
|
255 |
self.annotation.save() |
|
256 |
||
257 |
def tearDown(self): |
|
258 |
Token.objects.all().delete() |
|
259 |
Resource.objects.all().delete() |
|
260 |
Consumer.objects.all().delete() |
|
261 |
Nonce.objects.all().delete() |
|
262 |
User.objects.all().delete() |
|
263 |
||
264 |
||
265 |
def test_auth_access_delete(self): |
|
266 |
## REQUEST TOKEN |
|
267 |
||
268 |
response = self.c.get("/oauth/request_token/", self.parameters) |
|
269 |
#self.assertEqual(response.content," ") |
|
270 |
self.assertEqual(response.status_code,200) |
|
271 |
token = list(Token.objects.all())[-1] |
|
272 |
self.assertTrue(token.key in response.content) |
|
273 |
self.assertTrue(token.secret in response.content) |
|
274 |
self.assertEqual(token.callback, u'http://printer.example.com/request_token_ready'), |
|
275 |
self.assertTrue(token.callback_confirmed) |
|
276 |
||
277 |
# token.callback = OUT_OF_BAND |
|
278 |
# token.save() |
|
279 |
# |
|
280 |
## USER AUTHORIZATION |
|
281 |
||
282 |
parameters = { |
|
283 |
'oauth_token': token.key, |
|
284 |
} |
|
285 |
||
286 |
response = self.c.get("/oauth/authorize/", parameters) |
|
287 |
self.assertEqual(response.status_code,302) |
|
288 |
self.assertTrue(token.key in response['Location']) |
|
289 |
||
290 |
self.c.login(username='jane', password='toto') |
|
291 |
||
292 |
response = self.c.get("/oauth/authorize/", parameters) |
|
293 |
self.assertEqual(response.status_code,200) |
|
294 |
self.assertEqual(response.content,'Fake authorize view for printer.example.com.') |
|
295 |
||
296 |
# parameters['authorize_access'] = 0 |
|
297 |
# response = self.c.post("/oauth/authorize/", parameters) |
|
298 |
# self.assertEqual(response.content, "Fake callback view.") |
|
299 |
||
300 |
# fake authorization by the user |
|
301 |
parameters['authorize_access'] = 1 |
|
302 |
response = self.c.post("/oauth/authorize/", parameters) |
|
303 |
self.assertEqual(response.status_code,302) |
|
304 |
token = list(Token.objects.all())[-1] |
|
305 |
self.assertTrue(token.key in response['Location']) |
|
306 |
self.assertTrue(token.is_approved) |
|
307 |
||
308 |
## ACCESS TOKEN |
|
309 |
||
310 |
parameters = { |
|
311 |
'oauth_consumer_key': self.CONSUMER_KEY, |
|
312 |
'oauth_token': token.key, |
|
313 |
'oauth_signature_method': 'PLAINTEXT', |
|
314 |
'oauth_signature': '%s&%s' % (self.CONSUMER_SECRET, token.secret), |
|
315 |
'oauth_timestamp': str(int(time.time())), |
|
316 |
'oauth_nonce': self.nonce, |
|
317 |
'oauth_version': '1.0', |
|
318 |
'oauth_verifier': token.verifier, |
|
319 |
} |
|
320 |
response = self.c.get("/oauth/access_token/", parameters) |
|
321 |
||
322 |
access_token = list(Token.objects.filter(token_type=Token.ACCESS))[-1] |
|
323 |
self.assertTrue(access_token.key in response.content) |
|
324 |
self.assertTrue(access_token.secret in response.content) |
|
325 |
self.assertEqual(access_token.user.username, u'jane') |
|
326 |
||
327 |
## ACCESSING PROTECTED VIEW |
|
328 |
||
329 |
parameters = { |
|
330 |
'oauth_consumer_key': self.CONSUMER_KEY, |
|
331 |
'oauth_token': access_token.key, |
|
332 |
'oauth_signature_method': 'HMAC-SHA1', |
|
333 |
'oauth_timestamp': str(int(time.time())), |
|
334 |
'oauth_nonce': self.nonce, |
|
335 |
'oauth_version': '1.0', |
|
336 |
} |
|
337 |
||
338 |
oauth_request = OAuthRequest.from_token_and_callback(access_token, http_url='/api/1.0/text/delete/', parameters=parameters) |
|
339 |
signature_method = OAuthSignatureMethod_HMAC_SHA1() |
|
340 |
signature = signature_method.build_signature(oauth_request, self.consumer, access_token) |
|
341 |
||
342 |
parameters['oauth_signature'] = signature |
|
343 |
#self.assertEqual(signature, " ") |
|
344 |
parameters['id'] = 'd2c1d1fa-629d-4520-a3d2-955b4f2582c0' |
|
345 |
response = self.c.post("/api/1.0/text/delete/", parameters) |
|
346 |
self.assertEqual(response.content, " ") |
|
347 |
self.assertEqual(response.status_code,200) |
|
348 |
||
349 |
self.c.logout() |
|
350 |
access_token.delete() |
|
351 |
#/api/1.0/text/delete/ |
|
352 |
#/api/1.0/text/update/ |
|
353 |
#/api/1.0/text/create/ |