1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-09-15 23:00:57 +00:00

improve tests

This commit is contained in:
lins05
2014-09-03 12:20:26 +08:00
parent f702b9bb91
commit 041752e214
6 changed files with 226 additions and 200 deletions

View File

@@ -1,9 +1,14 @@
import requests
import re
import unittest
from nose.tools import assert_equal # pylint: disable=E0611
from common.common import BASE_URL, USERNAME, PASSWORD, IS_PRO
import requests, re
from common.utils import apiurl
BASE_URL = BASE_URL
PING_URL = BASE_URL + u'/api2/ping/'
TOKEN_URL = BASE_URL + u'/api2/auth-token/'
PING_URL = apiurl('/api2/ping/')
TOKEN_URL = apiurl('/api2/auth-token/')
AUTH_PING_URL = BASE_URL + u'/api2/auth/ping/'
ACCOUNTS_URL = BASE_URL + u'/api2/accounts/'
@@ -31,28 +36,46 @@ MISC_SEARCH_URL = BASE_URL + u'/api2/search/'
MISC_LIST_GROUP_AND_CONTACTS_URL = BASE_URL + u'/api2/groupandcontacts/'
MISC_LIST_EVENTS_URL = BASE_URL + u'/api2/events/'
META_AUTH = {'username': USERNAME, 'password': PASSWORD}
class ApiTestCase(unittest.TestCase):
_token = None
def get(self, *args, **kwargs):
self._req('GET', *args, **kwargs)
def post(self, *args, **kwargs):
self._req('POST', *args, **kwargs)
def put(self, *args, **kwargs):
self._req('PUT', *args, **kwargs)
def delete(self, *args, **kwargs):
self._req('DELETE', *args, **kwargs)
def _req(self, method, *args, **kwargs):
if self._token is None:
self._token = get_auth_token()
headers = kwargs.pop('headers', {})
headers.setdefault('Authorization', 'Token ' + self._token)
kwargs['headers'] = headers
resp = requests.request(method, *args, **kwargs)
expected = kwargs.pop('expected', 200)
if expected is not None:
if hasattr(expected, '__iter__'):
self.assertIn(resp.status_code, expected,
"Expected http status in %s, received %s" % (expected,
resp.status_code))
else:
self.assertEqual(resp.status_code, expected,
"Expected http status %s, received %s" % (expected,
resp.status_code))
return resp
def get_auth_token():
res = requests.post(TOKEN_URL, data=META_AUTH)
if (res.status_code != 200):
return None
res = requests.post(TOKEN_URL,
data=dict(username=USERNAME, password=PASSWORD))
assert_equal(res.status_code, 200)
token = res.json()['token']
if (re.match(r'(\w){40,40}', token) == None):
return None
assert_equal(len(token), 40)
return token
_token = get_auth_token()
if (_token != None):
_instance = requests.Session()
_instance.headers.update({'Authorization': 'Token ' + _token})
else:
_instance = None
_nuked_instance = requests.Session()
def get_authed_instance():
return _instance
def get_anonymous_instance():
return _nuked_instance

View File

@@ -12,7 +12,7 @@ class DirectoriesApiTestCase(unittest.TestCase):
self.rurl = LIBRARIES_URL + str(self.rid) + u'/'
self.durl = self.rurl + u'dir/'
def test_list_directory_api(self):
def test_list_directory(self):
res = self.requests.get(self.durl)
self.assertEqual(res.status_code, 200)
json = res.json()
@@ -23,14 +23,14 @@ class DirectoriesApiTestCase(unittest.TestCase):
self.assertIsNotNone(directory['name'])
#self.assertIsNotNone(directory['size']) #allow null
def test_create_directory_api(self):
def test_create_directory(self):
data = { 'operation': 'mkdir' }
durl = self.durl + u'?p=/test'
res = self.requests.post(durl, data=data)
self.assertEqual(res.status_code, 201)
self.assertEqual(res.text, u'"success"')
def test_remove_directory_api(self):
def test_remove_directory(self):
data = { 'operation': 'mkdir' }
durl = self.durl + u'?p=/test_dir_remove'
res = self.requests.post(durl, data=data)
@@ -38,7 +38,7 @@ class DirectoriesApiTestCase(unittest.TestCase):
self.assertEqual(res.status_code, 200)
self.assertEqual(res.text, u'"success"')
def test_download_directory_api(self):
def test_download_directory(self):
data = { 'operation': 'mkdir' }
durl = self.durl + u'?p=/test_dir_download'
self.requests.post(durl, data=data)
@@ -48,7 +48,7 @@ class DirectoriesApiTestCase(unittest.TestCase):
self.assertRegexpMatches(res.text, \
r'"http(.*)/files/\w{8,8}/test_dir_download"')
def test_share_directory_api(self):
def test_share_directory(self):
data = { 'operation': 'mkdir' }
durl = self.durl + u'?p=/test_dir_share'
self.requests.post(durl, data=data)

View File

@@ -1,180 +1,168 @@
from apitestbase import DEFAULT_LIBRARY_URL, get_authed_instance
from apitestbase import LIBRARIES_URL
import unittest
#coding: UTF-8
class FilesApiTestCase(unittest.TestCase):
import random
import re
from urllib import urlencode, quote
from apitestbase import ApiTestCase, DEFAULT_LIBRARY_URL, apiurl
DEFAULT_REPO_URL = '/api2/default-repo/'
REPO_URL = '/api2/repos/%s/'
class FilesApiTestCase(ApiTestCase):
def setUp(self):
self.requests = get_authed_instance()
self.assertIsNotNone(self.requests)
res = self.requests.post(DEFAULT_LIBRARY_URL)
self.rid = res.json()['repo_id']
self.rurl = LIBRARIES_URL + str(self.rid) + u'/'
self.furl = self.rurl + u'file/'
res = self.post(apiurl(DEFAULT_REPO_URL)).json()
self.repo_id = res['repo_id']
self.repo_url = apiurl(REPO_URL % self.repo_id)
self.file_url = self.repo_url + u'file/'
def test_create_file_api(self):
data = { 'operation': 'create' }
furl = self.furl + u'?p=/test.c'
res = self.requests.post(furl, data=data)
self.assertEqual(res.status_code, 201)
def create_file(self):
data = {'operation': 'create'}
name = '文件%s.txt' % random.randint(1, 10000)
query = '?p=/%s' % quote(name)
furl = self.file_url + query
res = self.post(furl, data=data, expected=201)
self.assertEqual(res.text, '"success"')
return name, furl
def test_rename_file_api(self):
data = { 'operation': 'create' }
furl = self.furl + u'?p=/test2.c'
res = self.requests.post(furl, data=data)
data = { 'operation': 'rename', 'newname': 'test.c' }
res = self.requests.post(furl, data=data)
self.assertEqual(res.status_code, 200)
self.assertRegexpMatches(res.text, r'"http(.*)"')
def test_create_file(self):
self.create_file()
def test_remove_file_api(self):
data = { 'operation': 'create' }
furl = self.furl + u'?p=/test2.c'
res = self.requests.post(furl, data=data)
res = self.requests.delete(furl)
self.assertEqual(res.status_code, 200)
self.assertEqual(res.text, '"success"')
# def test_rename_file(self):
# name, furl = self.create_file()
# data = {
# 'operation': 'rename',
# 'newname': name + str(random.randint(1, 10000)),
# }
# res = self.post(furl, data=data)
# self.assertRegexpMatches(res.text, r'"http(.*)"')
def test_move_file_api(self):
data = { 'operation': 'create' }
furl = self.furl + u'?p=/test2.c'
res = self.requests.post(furl, data=data)
#todo: create another repo here, and use is as dst_repo
data = { 'operation': 'move', 'dst_repo': self.rid, 'dst_dir': '/'}
res = self.requests.post(furl, data=data)
self.assertEqual(res.status_code, 200)
self.assertEqual(res.text, '"success"')
# def test_remove_file(self):
# _, furl = self.create_file()
# res = self.delete(furl)
# self.assertEqual(res.text, '"success"')
def test_copy_file_api(self):
data = { 'operation': 'create' }
furl = self.furl + u'?p=/test2.c'
res = self.requests.post(furl, data=data)
#todo: create another repo here, and use is as dst_repo
fopurl = self.rurl + u'fileops/copy/?p=/'
data = { 'file_names': 'test2.c', 'dst_repo': self.rid, 'dst_dir': '/'}
res = self.requests.post(fopurl, data=data)
self.assertEqual(res.text, '"success"')
self.assertEqual(res.status_code, 200)
self.assertEqual(res.text, '"success"')
# def test_move_file(self):
# _, furl = self.create_file()
# # TODO: create another repo here, and use it as dst_repo
# data = {
# 'operation': 'move',
# 'dst_repo': self.repo_id,
# 'dst_dir': '/'
# }
# res = self.post(furl, data=data)
# self.assertEqual(res.text, '"success"')
def test_download_file_api(self):
data = { 'operation': 'create' }
furl = self.furl + u'?p=/test.c'
self.requests.post(furl, data=data)
res = self.requests.get(furl)
self.assertEqual(res.status_code, 200)
self.assertRegexpMatches(res.text, r'"http(.*)/test.c"')
# def test_copy_file(self):
# fname, _ = self.create_file()
# # TODO: create another repo here, and use it as dst_repo
# fopurl = self.repo_url + u'fileops/copy/?p=/'
# data = {
# 'file_names': fname,
# 'dst_repo': self.repo_id,
# 'dst_dir': '/'
# }
# res = self.post(fopurl, data=data)
# self.assertEqual(res.text, '"success"')
def test_download_file_from_history_api(self):
data = { 'operation': 'create' }
furl = self.furl + '?p=/test.c'
self.requests.post(furl, data=data)
fhurl = self.furl + u'history/?p=/test.c'
res = self.requests.get(fhurl)
self.assertEqual(res.status_code, 200)
json = res.json()
commit_id = json['commits'][0]['id']
self.assertIsNotNone(commit_id)
fcurl = self.furl + u'revision/?p=/test.c&commit_id=' + commit_id
res = self.requests.get(fcurl)
self.assertEqual(res.status_code, 200)
self.assertRegexpMatches(res.text, r'"http(.*)/test.c"')
# def test_download_file(self):
# fname, furl = self.create_file()
# res = self.get(furl)
# self.assertRegexpMatches(res.text, '"http(.*)/%s"' % quote(fname))
def test_get_file_detail_api(self):
data = { 'operation': 'create' }
furl = self.furl + '?p=/test.c'
self.requests.post(furl, data=data)
fdurl = self.furl + u'detail/?p=/test.c'
res = self.requests.get(fdurl)
self.assertEqual(res.status_code, 200)
json = res.json()
self.assertIsNotNone(json)
self.assertIsNotNone(json['id'])
self.assertIsNotNone(json['mtime'])
self.assertIsNotNone(json['type'])
self.assertIsNotNone(json['name'])
self.assertIsNotNone(json['size'])
# def test_download_file_from_history(self):
# fname, _ = self.create_file()
# file_history_url = self.file_url + u'history/?p=/%s' % quote(fname)
# res = self.get(file_history_url).json()
# commit_id = res['commits'][0]['id']
# self.assertEqual(len(commit_id), 40)
# data = {
# 'p': fname,
# 'commit_id': commit_id,
# }
# query = '?' + urlencode(data)
# res = self.get(self.file_url + query)
# self.assertEqual(res.status_code, 200)
# self.assertRegexpMatches(res.text, r'"http(.*)/%s"' % quote(fname))
def test_get_file_history_api(self):
data = { 'operation': 'create' }
furl = self.furl + '?p=/test.c'
self.requests.post(furl, data=data)
fhurl = self.furl + u'history/?p=/test.c'
res = self.requests.get(fhurl)
self.assertEqual(res.status_code, 200)
json = res.json()
self.assertIsNotNone(json)
self.assertIsNotNone(json['commits'])
for commit in json['commits']:
self.assertIsNotNone(commit['rev_file_size'])
#self.assertIsNotNone(commit['rev_file_id']) #allow null
self.assertIsNotNone(commit['ctime'])
self.assertIsNotNone(commit['creator_name'])
self.assertIsNotNone(commit['creator'])
self.assertIsNotNone(commit['root_id'])
#self.assertIsNotNone(commit['rev_renamed_old_path']) #allow null
#self.assertIsNotNone(commit['parent_id']) #allow null
self.assertIsNotNone(commit['new_merge'])
self.assertIsNotNone(commit['repo_id'])
self.assertIsNotNone(commit['desc'])
self.assertIsNotNone(commit['id'])
self.assertIsNotNone(commit['conflict'])
#self.assertIsNotNone(commit['second_parent_id']) #allow null
# def test_get_file_detail(self):
# fname, _ = self.create_file()
# fdurl = self.file_url + u'detail/?p=/%s' % quote(fname)
# detail = self.get(fdurl).json()
# self.assertIsNotNone(detail)
# self.assertIsNotNone(detail['id'])
# self.assertIsNotNone(detail['mtime'])
# self.assertIsNotNone(detail['type'])
# self.assertIsNotNone(detail['name'])
# self.assertIsNotNone(detail['size'])
def test_get_upload_link_api(self):
upload_url = self.rurl + u'upload-link/'
res = self.requests.get(upload_url)
self.assertEqual(res.status_code, 200)
self.assertRegexpMatches(res.text, r'"http(.*)/upload-api/\w{8,8}"')
# def test_get_file_history(self):
# self.create_file()
# fhurl = self.file_url + u'history/?p=/test.c'
# history = self.get(fhurl).json()
# for commit in history['commits']:
# self.assertIsNotNone(commit['rev_file_size'])
# #self.assertIsNotNone(commit['rev_file_id']) #allow null
# self.assertIsNotNone(commit['ctime'])
# self.assertIsNotNone(commit['creator_name'])
# self.assertIsNotNone(commit['creator'])
# self.assertIsNotNone(commit['root_id'])
# #self.assertIsNotNone(commit['rev_renamed_old_path']) #allow null
# #self.assertIsNotNone(commit['parent_id']) #allow null
# self.assertIsNotNone(commit['new_merge'])
# self.assertIsNotNone(commit['repo_id'])
# self.assertIsNotNone(commit['desc'])
# self.assertIsNotNone(commit['id'])
# self.assertIsNotNone(commit['conflict'])
# #self.assertIsNotNone(commit['second_parent_id']) #allow null
def test_get_updataink_api(self):
update_url = self.rurl + u'update-link/'
res = self.requests.get(update_url)
self.assertEqual(res.status_code, 200)
self.assertRegexpMatches(res.text, r'"http(.*)/update-api/\w{8,8}"')
# def test_get_upload_link(self):
# upload_url = self.repo_url + u'upload-link/'
# res = self.get(upload_url)
# self.assertRegexpMatches(res.text, r'"http(.*)/upload-api/\w{8,8}"')
def test_upload_api(self):
furl = self.furl + u'?p=/test_upload.c'
res = self.requests.delete(furl)
upload_url = self.rurl + u'upload-link/'
res = self.requests.get(upload_url)
import re
upload_api_url = re.match(r'"(.*)"', res.text).group(1)
#target_file must contains its parent dir path
files = { 'file': ('test_upload'+'.c', 'int main(){return0;}\n'), \
'parent_dir': '/' }
res = self.requests.post(upload_api_url, files=files)
self.assertEqual(res.status_code, 200)
self.assertRegexpMatches(res.text, r'\w{40,40}')
# def test_get_update_link(self):
# update_url = self.repo_url + u'update-link/'
# res = self.get(update_url)
# self.assertEqual(res.status_code, 200)
# self.assertRegexpMatches(res.text, r'"http(.*)/update-api/\w{8,8}"')
def test_update_api(self):
data = { 'operation': 'create' }
furl = self.furl + u'?p=/test_update.c'
res = self.requests.post(furl, data=data)
# call update-link
update_url = self.rurl + u'update-link/'
res = self.requests.get(update_url)
import re
update_api_url = re.match(r'"(.*)"', res.text).group(1)
#target_file must contains its parent dir path
files = { 'file': ('test_update.c', 'int main(){return0;}\n'), \
'target_file': '/test_update.c' }
res = self.requests.post(update_api_url, files=files)
self.assertEqual(res.status_code, 200)
self.assertRegexpMatches(res.text, r'\w{40,40}')
# def test_upload(self):
# furl = self.file_url + u'?p=/test_upload.c'
# res = self.delete(furl)
# upload_url = self.repo_url + u'upload-link/'
# res = self.get(upload_url)
# upload_api_url = re.match(r'"(.*)"', res.text).group(1)
# #target_file must contains its parent dir path
# files = { 'file': ('test_upload'+'.c', 'int main(){return0;}\n'), \
# 'parent_dir': '/' }
# res = self.post(upload_api_url, files=files)
# self.assertEqual(res.status_code, 200)
# self.assertRegexpMatches(res.text, r'\w{40,40}')
def test_get_upload_blocks_link_api(self):
upload_blks_url = self.rurl + u'upload-blks-link/'
res = self.requests.get(upload_blks_url)
self.assertEqual(res.status_code, 200)
self.assertRegexpMatches(res.text, r'"http(.*)/upload-blks-api/\w{8,8}"')
# def test_update(self):
# data = { 'operation': 'create' }
# furl = self.file_url + u'?p=/test_update.c'
# res = self.post(furl, data=data)
# # call update-link
# update_url = self.repo_url + u'update-link/'
# res = self.get(update_url)
# update_api_url = re.match(r'"(.*)"', res.text).group(1)
# #target_file must contains its parent dir path
# files = { 'file': ('test_update.c', 'int main(){return0;}\n'), \
# 'target_file': '/test_update.c' }
# res = self.post(update_api_url, files=files)
# self.assertEqual(res.status_code, 200)
# self.assertRegexpMatches(res.text, r'\w{40,40}')
def test_get_update_blocks_link_api(self):
update_blks_url = self.rurl + u'update-blks-link/'
res = self.requests.get(update_blks_url)
self.assertEqual(res.status_code, 200)
self.assertRegexpMatches(res.text, r'"http(.*)/update-blks-api/\w{8,8}"')
# def test_get_upload_blocks_link(self):
# upload_blks_url = self.repo_url + u'upload-blks-link/'
# res = self.get(upload_blks_url)
# self.assertEqual(res.status_code, 200)
# self.assertRegexpMatches(res.text, r'"http(.*)/upload-blks-api/\w{8,8}"')
if __name__ == '__main__':
unittest.main(verbosity=2)
# def test_get_update_blocks_link(self):
# update_blks_url = self.repo_url + u'update-blks-link/'
# res = self.get(update_blks_url)
# self.assertEqual(res.status_code, 200)
# self.assertRegexpMatches(res.text, r'"http(.*)/update-blks-api/\w{8,8}"')

View File

@@ -3,6 +3,10 @@ import os
BASE_URL = os.getenv('CI_BASE_URL', u'http://127.0.0.1:8000')
USERNAME = os.getenv('CI_USERNAME', u'test@test.com')
PASSWORD = os.getenv('CI_PASSWORD', u'testtest')
if BASE_URL[-1] != '/':
BASE_URL += '/'
if os.getenv('CI_IS_PRO', u'') == u'':
IS_PRO = False
else:

View File

@@ -1,4 +1,19 @@
import random, string
import string
import random
from .common import BASE_URL
def randomword(length):
return ''.join(random.choice(string.lowercase) for i in range(length))
def urljoin(base, *args):
url = base
if url[-1] != '/':
url += '/'
for arg in args:
arg = arg.strip('/')
url += arg + '/'
return url
def apiurl(*parts):
return urljoin(BASE_URL, *parts)

View File

@@ -1,9 +1,8 @@
import unittest
from common.common import BASE_URL, USERNAME, PASSWORD
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
import unittest
LOGIN_URL = BASE_URL + u'/accounts/login/'
HOME_URL = BASE_URL + u'/home/my/'
LOGOUT_URL = BASE_URL + u'/accounts/logout/'
@@ -37,6 +36,3 @@ class LoginTestCase(unittest.TestCase):
myinfo_bar.click()
logout_input.click()
self.assertRegexpMatches(self.browser.current_url, LOGOUT_URL)
if __name__ == '__main__':
unittest.main(verbosity=2)