1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
# -*- coding: utf-8 -*-
##############################################################################
#
# Copyright (c) 2011 Nexedi SA and Contributors. All Rights Reserved.
# Lucas Carvalho <lucas@nexedi.com>
#
# WARNING: This program as such is intended to be used by professional
# programmers who take the whole responsability of assessing all potential
# consequences resulting from its eventual inadequacies and bugs
# End users who are looking for a ready-to-use solution with commercial
# garantees and support are strongly adviced to contract a Free Software
# Service Company
#
# This program is Free Software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#
##############################################################################
import base64
import httplib
from DateTime import DateTime
from Products.ERP5Type.tests.ERP5TypeTestCase import ERP5TypeTestCase
from erp5.component.test.ShaCacheMixin import ShaCacheMixin
from erp5.component.test.ShaSecurityMixin import ShaSecurityMixin
from Products.ERP5Type.tests.backportUnittest import expectedFailure
class TestShaCacheExternal(ShaCacheMixin, ShaSecurityMixin, ERP5TypeTestCase):
"""
ShaCache - HTTP File Cache server
We must simulate the real usage of ShaCache using httplib.
"""
def getTitle(self):
"""
Return the title of the current test set.
"""
return "SHACACHE External - Real Usage Of ShaCache"
def afterSetUp(self):
"""
Initialize the ERP5 site.
"""
self.expected_content_type = 'application/octet-stream'
self.group = 'shacache'
ShaCacheMixin.afterSetUp(self)
ShaSecurityMixin.afterSetUp(self)
# Define POST headers with Authentication
self.content_type = 'application/json'
authentication_string = '%s:%s' % (self.lucas_user, self.lucas_user)
base64string = base64.encodestring(authentication_string).strip()
self.header_dict = {'Authorization': 'Basic %s' % base64string,
'Content-Type': self.content_type}
# HTTP Connection properties
self.host = self.portal.REQUEST.get('SERVER_NAME')
self.port = self.portal.REQUEST.get('SERVER_PORT')
self.path = self.shacache.getPath()
def test_external_post(self):
"""
Test the external usage to POST information
"""
now = DateTime()
connection = httplib.HTTPConnection('%s:%s' % (self.host, self.port))
try:
connection.request('POST', self.path, self.data, self.header_dict)
result = connection.getresponse()
self.tic()
data = result.read()
finally:
connection.close()
self.assertEqual(self.key, data)
self.assertEqual(httplib.CREATED, result.status)
# Check Document
document = self.portal.portal_catalog.getResultValue(portal_type='File',
reference=self.key,
creation_date=' >= "%s"' % now)
self.assertNotEquals(None, document)
self.assertEqual(self.data, document.getData())
self.assertEqual('File', document.getPortalType())
self.assertEqual('Published', document.getValidationStateTitle())
self.assertEqual(self.expected_content_type, document.getContentType())
def test_external_get(self, annonymous=False):
"""
Test the external usage to retrive the information
"""
self.test_external_post()
header_dict = {}
if not annonymous:
header_dict = self.header_dict
connection = httplib.HTTPConnection('%s:%s' % (self.host, self.port))
try:
connection.request('GET', '/'.join([self.path, self.key]),
headers=header_dict)
result = connection.getresponse()
data = result.read()
finally:
connection.close()
self.assertEqual(self.data, data)
self.assertEqual(httplib.OK, result.status)
self.assertEqual(self.expected_content_type,
result.getheader("content-type"))
def test_external_get_anonymous(self):
"""
Test the external usage to retrive information
accessing as Anonymous User.
"""
self.test_external_get(annonymous=True)
@expectedFailure
def test_external_post_anonymous(self):
"""
Anonymous should not be able to POST a file.
"""
connection = httplib.HTTPConnection('%s:%s' % (self.host, self.port))
header_dict = {'Content-Type': self.content_type}
try:
connection.request('POST', self.path, self.data, header_dict)
result = connection.getresponse()
self.tic()
finally:
connection.close()
# For now ERP5 returns httplib.FOUND which is wrong reply in case of trying
# to POST resource while begin not authorised
# One of UNAUTHORIZED or FORBIDDEN shall be returned
# Ref: http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html#sec10.4
# self.assertEqual(httplib.UNAUTHORIZED, result.status)
# FORBIDDEN seems more suitable for RESTful server...
self.assertEqual(httplib.FORBIDDEN, result.status)