1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-04-27 02:51:00 +00:00

improved tests

This commit is contained in:
lins05 2014-09-06 11:38:20 +08:00
parent 2687bdbea4
commit f65c783fb6
16 changed files with 434 additions and 755 deletions

View File

@ -1,14 +0,0 @@
# Copyright 2014 seahub authors
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from common import common

View File

@ -1,11 +1,12 @@
#coding: UTF-8
import re
import requests
import unittest
from contextlib import contextmanager
from nose.tools import assert_equal, assert_in # pylint: disable=E0611
from urllib import quote
from tests.common.common import USERNAME, PASSWORD, IS_PRO, \
from tests.common.common import USERNAME, PASSWORD, \
ADMIN_USERNAME, ADMIN_PASSWORD
from tests.common.utils import apiurl, urljoin, randstring
@ -14,75 +15,11 @@ from tests.api.urls import TOKEN_URL, GROUPS_URL, ACCOUNTS_URL, REPOS_URL
class ApiTestBase(unittest.TestCase):
_token = None
_admin_token = None
use_test_user = False
use_test_group = False
use_test_repo = False
test_user_name = None
test_user_url = None
test_group_name = None
test_group_id = None
test_group_url = None
test_repo_id = None
test_repo_url = None
test_file_url = None
test_dir_url = None
def setUp(self):
if self.use_test_user:
self.create_tmp_user()
if self.use_test_group:
self.create_tmp_group()
if self.use_test_repo:
self.create_tmp_repo()
def tearDown(self):
if self.use_test_user:
self.remove_tmp_user()
if self.use_test_group:
self.remove_tmp_group()
if self.use_test_repo:
self.remove_tmp_repo()
def create_tmp_repo(self):
repo_name = '测试-test-repo-%s' % randstring(6)
data = {
'name': repo_name,
'desc': 'just for test - 测试用资料库',
}
repo = self.post(REPOS_URL, data=data).json()
self.test_repo_id = repo['repo_id']
self.test_repo_url = urljoin(REPOS_URL, self.test_repo_id)
self.test_file_url = urljoin(self.test_repo_url, 'file')
self.test_dir_url = urljoin(self.test_repo_url, 'dir')
def remove_tmp_repo(self):
if self.test_repo_id:
self.delete(self.test_repo_url)
def create_tmp_group(self):
self.test_group_name = '测试群组-%s' % randstring(16)
data = {'group_name': self.test_group_name}
self.test_group_id = self.put(GROUPS_URL, data=data).json()['group_id']
self.test_group_url = urljoin(GROUPS_URL, str(self.test_group_id))
def remove_tmp_group(self):
if self.test_group_id:
self.delete(self.test_group_url)
def create_tmp_user(self):
data = {'password': 'testtest'}
username = '%s@test.com' % randstring(20)
self.put(urljoin(ACCOUNTS_URL, username), data=data, expected=201)
self.test_user_name = username
self.test_user_url = urljoin(ACCOUNTS_URL, username)
def remove_tmp_user(self):
if self.test_user_name:
self.delete(self.test_user_url)
username = USERNAME
password = PASSWORD
admin_username = ADMIN_USERNAME
admin_password = ADMIN_PASSWORD
@classmethod
def get(cls, *args, **kwargs):
@ -165,10 +102,134 @@ class ApiTestBase(unittest.TestCase):
msg = 'Expected not empty, but it is'
self.assertGreater(len(lst), 0, msg)
@contextmanager
def get_tmp_repo(self):
"""
Context manager to create a tmp repo, and automatically delete it after use
with self.tmp_repo() as repo:
self.get(repo.file_url + '?p=/')
"""
repo = self.create_repo()
try:
yield repo
finally:
self.remove_repo(repo.repo_id)
@contextmanager
def get_tmp_group(self):
"""
Context manager to create a tmp group, and automatically delete it after use
with self.tmp_repo() as repo:
self.get(repo.file_url + '?p=/')
"""
group = self.create_group()
try:
yield group
finally:
self.remove_group(group.group_id)
@contextmanager
def get_tmp_user(self):
"""
Context manager to create a tmp user, and automatically delete it after use
with self.tmp_repo() as repo:
self.get(repo.file_url + '?p=/')
"""
user = self.create_user()
try:
yield user
finally:
self.remove_user(user.user_name)
def create_repo(self):
repo_name = '测试-test-repo-%s' % randstring(6)
data = {
'name': repo_name,
'desc': 'just for test - 测试用资料库',
}
repo = self.post(REPOS_URL, data=data).json()
repo_id = repo['repo_id']
return _Repo(repo_id)
def remove_repo(self, repo_id):
repo_url = urljoin(REPOS_URL, repo_id)
self.delete(repo_url)
def create_group(self):
group_name = '测试群组-%s' % randstring(16)
data = {'group_name': group_name}
group_id = self.put(GROUPS_URL, data=data).json()['group_id']
return _Group(group_name, group_id)
def remove_group(self, group_id):
group_url = urljoin(GROUPS_URL, str(group_id))
self.delete(group_url)
def create_user(self):
username = '%s@test.com' % randstring(20)
password = randstring(20)
data = {'password': password}
self.admin_put(urljoin(ACCOUNTS_URL, username), data=data, expected=201)
return _User(username, password)
def remove_user(self, username):
user_url = urljoin(ACCOUNTS_URL, username)
self.admin_delete(user_url)
def create_file(self, repo, fname=None):
fname = fname or ('文件 %s.txt' % randstring())
furl = repo.get_filepath_url('/' + fname)
data = {'operation': 'create'}
res = self.post(furl, data=data, expected=201)
self.assertEqual(res.text, '"success"')
return fname, furl
def create_dir(self, repo):
data = {'operation': 'mkdir'}
dpath = '/目录 %s' % randstring()
durl = repo.get_dirpath_url(dpath)
res = self.post(durl, data=data, expected=201)
self.assertEqual(res.text, u'"success"')
return dpath, durl
def get_auth_token(username, password):
res = requests.post(TOKEN_URL,
data=dict(username=username, password=password))
data = {
'username': username,
'password': password,
}
res = requests.post(TOKEN_URL, data=data)
assert_equal(res.status_code, 200)
token = res.json()['token']
assert_equal(len(token), 40)
return token
class _Repo(object):
def __init__(self, repo_id):
self.repo_id = repo_id
self.repo_url = urljoin(REPOS_URL, self.repo_id)
self.file_url = urljoin(self.repo_url, 'file')
self.dir_url = urljoin(self.repo_url, 'dir')
def get_filepath_url(self, path):
query = '?p=%s' % quote(path)
return self.file_url + query
def get_dirpath_url(self, path):
query = '?p=%s' % quote(path)
return self.dir_url + query
class _Group(object):
def __init__(self, group_name, group_id):
self.group_name = group_name
self.group_id = group_id
self.group_url = urljoin(GROUPS_URL, str(self.group_id))
class _User(object):
def __init__(self, username, password):
self.user_name = username
self.password = password
self.user_url = urljoin(ACCOUNTS_URL, username)

View File

@ -2,7 +2,7 @@ import requests
import unittest
from tests.common.utils import apiurl, urljoin, randstring
from tests.api.apitestbase import USERNAME, ApiTestBase
from tests.api.apitestbase import ApiTestBase
from tests.api.urls import ACCOUNTS_URL, ACCOUNT_INFO_URL, PING_URL, \
AUTH_PING_URL
@ -15,7 +15,7 @@ class AccountsApiTest(ApiTestBase):
def test_check_account_info(self):
info = self.get(ACCOUNT_INFO_URL).json()
self.assertIsNotNone(info)
self.assertEqual(info['email'], USERNAME)
self.assertEqual(info['email'], self.username)
self.assertIsNotNone(info['total'])
self.assertIsNotNone(info['usage'])

View File

@ -1,12 +1,12 @@
import unittest
from tests.api.apitestbase import ApiTestBase, USERNAME
from tests.api.apitestbase import ApiTestBase
from tests.api.urls import AVATAR_BASE_URL, GROUPS_URL
from tests.common.utils import randstring, apiurl, urljoin
class AvatarApiTest(ApiTestBase):
def test_user_avatar(self):
avatar_url = urljoin(AVATAR_BASE_URL, 'user', USERNAME, '/resized/80/')
avatar_url = urljoin(AVATAR_BASE_URL, 'user', self.username, '/resized/80/')
info = self.get(avatar_url).json()
self.assertIsNotNone(info['url'])
self.assertIsNotNone(info['is_default'])

View File

@ -12,129 +12,114 @@ from tests.api.urls import DEFAULT_REPO_URL, REPOS_URL
from tests.api.apitestbase import ApiTestBase, USERNAME
class FilesApiTest(ApiTestBase):
use_test_repo = True
use_test_user = True
def create_file(self, fname=None):
data = {'operation': 'create'}
fname = fname or ('文件 %s.txt' % randstring())
fpath = '/' + fname
query = urlencode(dict(p=fpath))
furl = self.test_file_url + '?' + query
res = self.post(furl, data=data, expected=201)
self.assertEqual(res.text, '"success"')
return fname, furl
def create_dir(self):
data = {'operation': 'mkdir'}
dpath = '/目录 %s' % randstring()
query = urlencode(dict(p=dpath))
durl = self.test_dir_url + '?' + query
res = self.post(durl, data=data, expected=201)
self.assertEqual(res.text, u'"success"')
return dpath, durl
def test_create_file(self):
self.create_file()
def test_rename_file(self):
name, furl = self.create_file()
data = {
'operation': 'rename',
'newname': name + randstring(),
}
res = self.post(furl, data=data)
self.assertRegexpMatches(res.text, r'"http(.*)"')
with self.get_tmp_repo() as repo:
name, furl = self.create_file(repo)
data = {
'operation': 'rename',
'newname': name + randstring(),
}
res = self.post(furl, data=data)
self.assertRegexpMatches(res.text, r'"http(.*)"')
def test_remove_file(self):
_, furl = self.create_file()
res = self.delete(furl)
self.assertEqual(res.text, '"success"')
with self.get_tmp_repo() as repo:
_, furl = self.create_file(repo)
res = self.delete(furl)
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.test_repo_id,
'dst_dir': '/'
}
res = self.post(furl, data=data)
self.assertEqual(res.text, '"success"')
with self.get_tmp_repo() as repo:
_, furl = self.create_file(repo)
# TODO: create another repo here, and use it as dst_repo
data = {
'operation': 'move',
'dst_repo': repo.repo_id,
'dst_dir': '/',
}
res = self.post(furl, data=data)
self.assertEqual(res.text, '"success"')
def test_copy_file(self):
fname, _ = self.create_file()
# TODO: create another repo here, and use it as dst_repo
dpath, _ = self.create_dir()
fopurl = self.test_repo_url + u'fileops/copy/?p=/'
data = {
'file_names': fname,
'dst_repo': self.test_repo_id,
'dst_dir': dpath,
}
res = self.post(fopurl, data=data)
self.assertEqual(res.text, '"success"')
with self.get_tmp_repo() as repo:
fname, _ = self.create_file(repo)
# TODO: create another repo here, and use it as dst_repo
dpath, _ = self.create_dir(repo)
fopurl = urljoin(repo.repo_url, 'fileops/copy/') + '?p=/'
data = {
'file_names': fname,
'dst_repo': repo.repo_id,
'dst_dir': dpath,
}
res = self.post(fopurl, data=data)
self.assertEqual(res.text, '"success"')
def test_download_file(self):
fname, furl = self.create_file()
res = self.get(furl)
self.assertRegexpMatches(res.text, '"http(.*)/%s"' % quote(fname))
with self.get_tmp_repo() as repo:
fname, furl = self.create_file(repo)
res = self.get(furl)
self.assertRegexpMatches(res.text, '"http(.*)/%s"' % quote(fname))
def test_download_file_from_history(self):
fname, _ = self.create_file()
file_history_url = self.test_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.test_file_url + query)
self.assertEqual(res.status_code, 200)
self.assertRegexpMatches(res.text, r'"http(.*)/%s"' % quote(fname))
with self.get_tmp_repo() as repo:
fname, _ = self.create_file(repo)
file_history_url = urljoin(repo.repo_url, '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(repo.file_url + query)
self.assertRegexpMatches(res.text, r'"http(.*)/%s"' % quote(fname))
def test_get_file_detail(self):
fname, _ = self.create_file()
fdurl = self.test_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'])
with self.get_tmp_repo() as repo:
fname, _ = self.create_file(repo)
fdurl = repo.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_file_history(self):
fname, _ = self.create_file()
fhurl = self.test_file_url + u'history/?p=%s' % quote(fname)
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
with self.get_tmp_repo() as repo:
fname, _ = self.create_file(repo)
fhurl = repo.file_url + u'history/?p=%s' % quote(fname)
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_upload_link(self):
upload_url = self.test_repo_url + u'upload-link/'
res = self.get(upload_url)
self.assertRegexpMatches(res.text, r'"http(.*)/upload-api/\w{8,8}"')
with self.get_tmp_repo() as repo:
upload_url = urljoin(repo.repo_url, 'upload-link')
res = self.get(upload_url)
self.assertRegexpMatches(res.text, r'"http(.*)/upload-api/\w{8,8}"')
def test_get_update_link(self):
update_url = self.test_repo_url + u'update-link/'
res = self.get(update_url)
self.assertRegexpMatches(res.text, r'"http(.*)/update-api/\w{8,8}"')
with self.get_tmp_repo() as repo:
update_url = urljoin(repo.repo_url, 'update-link')
res = self.get(update_url)
self.assertRegexpMatches(res.text, r'"http(.*)/update-api/\w{8,8}"')
# def test_upload_file(self):
# # XXX: requests has problems when post a file whose name contains
@ -166,54 +151,57 @@ class FilesApiTest(ApiTestBase):
# self.assertRegexpMatches(res.text, r'\w{40,40}')
def test_get_upload_blocks_link(self):
upload_blks_url = self.test_repo_url + u'upload-blks-link/'
res = self.get(upload_blks_url)
self.assertRegexpMatches(res.text, r'"http(.*)/upload-blks-api/\w{8,8}"')
with self.get_tmp_repo() as repo:
upload_blks_url = urljoin(repo.repo_url, 'upload-blks-link')
res = self.get(upload_blks_url)
self.assertRegexpMatches(res.text, r'"http(.*)/upload-blks-api/\w{8,8}"')
def test_get_update_blocks_link(self):
update_blks_url = self.test_repo_url + u'update-blks-link/'
res = self.get(update_blks_url)
self.assertRegexpMatches(res.text, r'"http(.*)/update-blks-api/\w{8,8}"')
with self.get_tmp_repo() as repo:
update_blks_url = urljoin(repo.repo_url, 'update-blks-link')
res = self.get(update_blks_url)
self.assertRegexpMatches(res.text, r'"http(.*)/update-blks-api/\w{8,8}"')
def test_list_dir(self):
self.create_file()
self.create_dir()
dirents = self.get(self.test_dir_url).json()
self.assertHasLen(dirents, 2)
for dirent in dirents:
self.assertIsNotNone(dirent['id'])
self.assertIsNotNone(dirent['name'])
self.assertIn(dirent['type'], ('file', 'dir'))
if dirent['type'] == 'file':
self.assertIsNotNone(dirent['size'])
def test_create_dir(self):
self.create_dir()
with self.get_tmp_repo() as repo:
self.create_file(repo)
self.create_dir(repo)
dirents = self.get(repo.dir_url).json()
self.assertHasLen(dirents, 2)
for dirent in dirents:
self.assertIsNotNone(dirent['id'])
self.assertIsNotNone(dirent['name'])
self.assertIn(dirent['type'], ('file', 'dir'))
if dirent['type'] == 'file':
self.assertIsNotNone(dirent['size'])
def test_remove_dir(self):
_, durl = self.create_dir()
res = self.delete(durl)
self.assertEqual(res.text, u'"success"')
self.get(durl, expected=404)
with self.get_tmp_repo() as repo:
_, durl = self.create_dir(repo)
res = self.delete(durl)
self.assertEqual(res.text, u'"success"')
self.get(durl, expected=404)
def test_download_dir(self):
dpath, _ = self.create_dir()
query = urlencode({'p': dpath})
ddurl = self.test_dir_url + 'download/' + '?' + query
res = self.get(ddurl)
self.assertRegexpMatches(res.text,
r'"http(.*)/files/\w{8,8}/%s"' % quote(dpath[1:]))
with self.get_tmp_repo() as repo:
dpath, _ = self.create_dir(repo)
query = '?p=%s' % quote(dpath)
ddurl = urljoin(repo.dir_url, 'download') + query
res = self.get(ddurl)
self.assertRegexpMatches(res.text,
r'"http(.*)/files/\w{8,8}/%s"' % quote(dpath[1:]))
def test_share_dir(self):
dpath, _ = self.create_dir()
query = urlencode({'p': dpath})
share_dir_url = self.test_dir_url + u'share/' + '?' + query
# TODO: share to another user
data = {
'emails': USERNAME,
's_type': 'd',
'path': '/',
'perm': 'r'
}
res = self.post(share_dir_url, data=data)
self.assertEqual(res.text, u'{}')
with self.get_tmp_repo() as repo:
dpath, _ = self.create_dir(repo)
query = '?p=%s' % quote(dpath)
share_dir_url = urljoin(repo.dir_url, 'share/') + query
with self.get_tmp_user() as user:
data = {
'emails': user.user_name,
's_type': 'd',
'path': '/',
'perm': 'r'
}
res = self.post(share_dir_url, data=data)
self.assertEqual(res.text, u'{}')

View File

@ -1,74 +0,0 @@
from apitestbase import GROUPS_URL, GROUPMSGS_URL, GROUPMSGS_NREPLY_URL
from apitestbase import GROUP_URL, get_authed_instance
from common.utils import randomword
import unittest
class GroupMsgsApiTestCase(unittest.TestCase):
def setUp(self):
self.requests = get_authed_instance()
self.assertIsNotNone(self.requests)
self.gname = randomword(16)
data = { 'group_name': self.gname }
res = self.requests.put(GROUPS_URL, data=data)
self.gid = res.json()['group_id']
self.gmurl = GROUPMSGS_URL + str(self.gid) + u'/'
self.gmurl_ = GROUP_URL + str(self.gid) + u'/msg/'
def test_list_group_msgs_api(self):
res = self.requests.get(self.gmurl)
self.assertEqual(res.status_code, 200)
json = res.json()
self.assertIsNotNone(json)
self.assertIsNotNone(json['next_page'])
self.assertIsNotNone(json['msgs'])
def test_post_group_msg_api(self):
#repo_id and path is not tested
data = { 'message': 'test message' }
res = self.requests.post(self.gmurl, data=data)
self.assertEqual(res.status_code, 200)
self.assertIsNotNone(res.json()['msgid'])
def test_reply_group_msg_api(self):
data = { 'message': 'test message' }
res = self.requests.post(self.gmurl, data=data)
msgid = res.json()['msgid']
res = self.requests.post(self.gmurl_ + str(msgid) + u'/', data=data)
self.assertEqual(res.status_code, 200)
self.assertIsNotNone(res.json()['msgid'])
def test_get_group_msg_detail_api(self):
data = { 'message': 'test message' }
res = self.requests.post(self.gmurl, data=data)
msgid = res.json()['msgid']
res = self.requests.get(self.gmurl_ + str(msgid) + u'/')
self.assertEqual(res.status_code, 200)
json = res.json()
self.assertIsNotNone(json)
self.assertIsNotNone(json['reply_cnt'])
self.assertIsNotNone(json['timestamp'])
self.assertIsNotNone(json['replies'])
self.assertIsNotNone(json['from_email'])
self.assertIsNotNone(json['msgid'])
self.assertIsNotNone(json['msg'])
self.assertIsNotNone(json['nickname'])
def test_new_replies_group_msg_api(self):
data = { 'message': 'test message' }
res = self.requests.post(self.gmurl, data=data)
res = self.requests.get(GROUPMSGS_NREPLY_URL)
self.assertEqual(res.status_code, 200)
json = res.json()
self.assertIsNotNone(json)
for reply in json:
self.assertIsNotNone(reply['reply_cnt'])
self.assertIsNotNone(reply['timestamp'])
self.assertIsNotNone(reply['replies'])
self.assertIsNotNone(reply['from_email'])
self.assertIsNotNone(reply['msgid'])
self.assertIsNotNone(reply['msg'])
self.assertIsNotNone(reply['nickname'])
if __name__ == '__main__':
unittest.main(verbosity=2)

View File

@ -10,30 +10,30 @@ from tests.api.urls import GROUPS_URL
from tests.common.utils import apiurl, urljoin, randstring
class GroupsApiTest(ApiTestBase):
use_test_user = True
use_test_group = True
def test_add_remove_group_member(self):
test_group_members_url = urljoin(self.test_group_url, '/members/')
data = {'user_name': self.test_user_name}
res = self.put(test_group_members_url, data=data).json()
self.assertTrue(res['success'])
res = self.delete(test_group_members_url, data=data).json()
self.assertTrue(res['success'])
with self.get_tmp_user() as user:
with self.get_tmp_group() as group:
test_group_members_url = urljoin(group.group_url, '/members/')
data = {'user_name': user.user_name}
res = self.put(test_group_members_url, data=data).json()
self.assertTrue(res['success'])
res = self.delete(test_group_members_url, data=data).json()
self.assertTrue(res['success'])
def test_list_groups(self):
groups = self.get(GROUPS_URL).json()
self.assertGreaterEqual(groups['replynum'], 0)
self.assertNotEmpty(groups['groups'])
for group in groups['groups']:
self.assertIsNotNone(group['ctime'])
self.assertIsNotNone(group['creator'])
self.assertIsNotNone(group['msgnum'])
self.assertIsNotNone(group['mtime'])
self.assertIsNotNone(group['id'])
self.assertIsNotNone(group['name'])
with self.get_tmp_group() as group:
groups = self.get(GROUPS_URL).json()
self.assertGreaterEqual(groups['replynum'], 0)
self.assertNotEmpty(groups['groups'])
for group in groups['groups']:
self.assertIsNotNone(group['ctime'])
self.assertIsNotNone(group['creator'])
self.assertIsNotNone(group['msgnum'])
self.assertIsNotNone(group['mtime'])
self.assertIsNotNone(group['id'])
self.assertIsNotNone(group['name'])
def test_add_group(self):
def test_add_remove_group(self):
data = {'group_name': randstring(16)}
info = self.put(GROUPS_URL, data=data).json()
self.assertTrue(info['success'])

View File

@ -1,9 +1,9 @@
import unittest
from tests.common.utils import apiurl
from tests.api.apitestbase import ApiTestBase
from tests.api.urls import LIST_GROUP_AND_CONTACTS_URL
class MiscApiTest(ApiTestBase):
def test_list_group_and_contacts_api(self):
def test_list_group_and_contacts(self):
res = self.get(LIST_GROUP_AND_CONTACTS_URL).json()
self.assertIsNotNone(res)
self.assertIsInstance(res['contacts'], list)

View File

@ -5,17 +5,12 @@ Test repos api.
import unittest
from tests.api.apitestbase import ApiTestBase, USERNAME
from tests.api.apitestbase import ApiTestBase
from tests.api.urls import REPOS_URL, DEFAULT_REPO_URL, VIRTUAL_REPOS_URL
from tests.common.utils import apiurl, urljoin, randstring
# TODO: all tests should be run on an encrypted repo
class ReposApiTest(ApiTestBase):
use_test_repo = True
def remove_repo(cls, repo_id):
cls.delete(urljoin(REPOS_URL, repo_id))
def test_get_default_repo(self):
repo = self.get(DEFAULT_REPO_URL).json()
self.assertIsNotNone(repo['exists'])
@ -28,6 +23,7 @@ class ReposApiTest(ApiTestBase):
def test_list_repos(self):
repos = self.get(REPOS_URL).json()
self.assertHasLen(repos, 1)
for repo in repos:
self.assertIsNotNone(repo['permission'])
self.assertIsNotNone(repo['encrypted'])
@ -42,91 +38,89 @@ class ReposApiTest(ApiTestBase):
self.assertIsNotNone(repo['root'])
def test_get_repo_info(self):
repo = self.get(test_repo_url).json()
self.assertFalse(repo['encrypted'])
self.assertIsNotNone(repo['mtime'])
self.assertIsNotNone(repo['owner'])
self.assertIsNotNone(repo['id'])
self.assertIsNotNone(repo['size'])
self.assertIsNotNone(repo['name'])
self.assertIsNotNone(repo['root'])
self.assertIsNotNone(repo['desc'])
self.assertIsNotNone(repo['type'])
# self.assertIsNotNone(repo['password_need']) #allow null here
with self.get_tmp_repo() as repo:
rinfo = self.get(repo.repo_url).json()
self.assertFalse(rinfo['encrypted'])
self.assertIsNotNone(rinfo['mtime'])
self.assertIsNotNone(rinfo['owner'])
self.assertIsNotNone(rinfo['id'])
self.assertIsNotNone(rinfo['size'])
self.assertIsNotNone(rinfo['name'])
self.assertIsNotNone(rinfo['root'])
self.assertIsNotNone(rinfo['desc'])
self.assertIsNotNone(rinfo['type'])
# elf.assertIsNotNone(rinfo['password_need']) # allow null here
def test_get_repo_owner(self):
repo_owner_url = urljoin(self.test_repo_url, '/owner/')
info = self.get(repo_owner_url).json()
self.assertEqual(info['owner'], self.test_user_name)
with self.get_tmp_repo() as repo:
repo_owner_url = urljoin(repo.repo_url, '/owner/')
# XXX: why only admin can get the owner of a repo?
info = self.admin_get(repo_owner_url).json()
self.assertEqual(info['owner'], self.username)
def test_get_repo_history(self):
repo_history_url = urljoin(REPOS_URL, self.test_repo_id, '/history/')
history = self.get(repo_history_url).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
with self.get_tmp_repo() as repo:
self.create_file(repo)
self.create_dir(repo)
repo_history_url = urljoin(repo.repo_url, '/history/')
history = self.get(repo_history_url).json()
commits = history['commits']
self.assertHasLen(commits, 3)
for commit in 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_create_repo(self):
data = {'name': 'test'}
res = self.post(REPOS_URL, data=data)
repo = res.json()
self.assertIsNotNone(repo['encrypted'])
self.assertIsNotNone(repo['enc_version'])
self.assertIsNotNone(repo['repo_id'])
self.assertIsNotNone(repo['magic'])
self.assertIsNotNone(repo['relay_id'])
self.assertIsNotNone(repo['repo_version'])
self.assertIsNotNone(repo['relay_addr'])
self.assertIsNotNone(repo['token'])
self.assertIsNotNone(repo['relay_port'])
self.assertIsNotNone(repo['random_key'])
self.assertIsNotNone(repo['email'])
self.assertIsNotNone(repo['repo_name'])
repo_id = repo['repo_id']
self.remove_repo(repo_id)
# Check the repo is really removed
self.get(urljoin(REPOS_URL, repo_id), expected=404)
try:
self.assertIsNotNone(repo['encrypted'])
self.assertIsNotNone(repo['enc_version'])
self.assertIsNotNone(repo['repo_id'])
self.assertIsNotNone(repo['magic'])
self.assertIsNotNone(repo['relay_id'])
self.assertIsNotNone(repo['repo_version'])
self.assertIsNotNone(repo['relay_addr'])
self.assertIsNotNone(repo['token'])
self.assertIsNotNone(repo['relay_port'])
self.assertIsNotNone(repo['random_key'])
self.assertIsNotNone(repo['email'])
self.assertIsNotNone(repo['repo_name'])
finally:
self.remove_repo(repo_id)
# Check the repo is really removed
self.get(urljoin(REPOS_URL, repo_id), expected=404)
# TODO: create a sub folder and use it as a sub repo
# def test_check_or_create_sub_repo(self):
# sub_repo_url = urljoin(REPOS_URL, self.test_repo_id, '/dir/sub_repo/')
# params = {'p': '/', 'name': 'sub_lib'}
# info = self.get(sub_repo_url, params=params).json()
# self.assertHasLen(info['sub_repo_id'], 36)
# self.remove_repo(info['sub_repo_id'])
def test_encrpty_or_decrypy_repo(self):
# TODO: create a encrypted library
def test_check_or_create_sub_repo(self):
# TODO: create a sub folder and use it as a sub repo
pass
# repo_url = urljoin(REPOS_URL, repo_id)
# data = {'password': 'test'}
# res = self.post(repo_url, data)
# self.assertEqual(res.text, '"success"')
def test_fetch_repo_download_info(self):
download_info_repo_url = urljoin(REPOS_URL, self.test_repo_id, '/download-info/')
info = self.get(download_info_repo_url).json()
self.assertIsNotNone(info['relay_addr'])
self.assertIsNotNone(info['token'])
self.assertIsNotNone(info['repo_id'])
self.assertIsNotNone(info['relay_port'])
self.assertIsNotNone(info['encrypted'])
self.assertIsNotNone(info['repo_name'])
self.assertIsNotNone(info['relay_id'])
self.assertIsNotNone(info['email'])
with self.get_tmp_repo() as repo:
download_info_repo_url = urljoin(repo.repo_url, '/download-info/')
info = self.get(download_info_repo_url).json()
self.assertIsNotNone(info['relay_addr'])
self.assertIsNotNone(info['token'])
self.assertIsNotNone(info['repo_id'])
self.assertIsNotNone(info['relay_port'])
self.assertIsNotNone(info['encrypted'])
self.assertIsNotNone(info['repo_name'])
self.assertIsNotNone(info['relay_id'])
self.assertIsNotNone(info['email'])
def test_list_virtual_repos(self):
# TODO: we need to create at least on virtual repo first

View File

@ -1,232 +1,30 @@
#coding: UTF-8
import unittest
from urllib import urlencode, quote
from tests.common.utils import apiurl, randstring, urljoin
from tests.common.utils import urljoin
from tests.api.apitestbase import ApiTestBase
from tests.api.urls import SHARED_LINKS_URL, SHARED_LIBRARIES_URL, \
BESHARED_LIBRARIES_URL, SHARED_FILES_URL, F_URL, S_F_URL
class SharesApiTest(ApiTestBase):
use_test_group = True
use_test_repo = True
def create_file(self, fname=None):
data = {'operation': 'create'}
fname = fname or ('文件 %s.txt' % randstring(10))
fpath = '/' + fname
query = urlencode(dict(p=fpath))
furl = self.test_file_url + '?' + query
res = self.post(furl, data=data, expected=201)
self.assertEqual(res.text, '"success"')
return fname, furl
def test_create_file_shared_link(self):
fname, _ = self.create_file()
fsurl = urljoin(self.test_file_url, 'shared-link')
data = {
'type': 'f',
'p': '/' + fname,
}
res = self.put(fsurl, data=data, expected=201)
self.assertRegexpMatches(res.headers['Location'], \
r'http(.*)/f/(\w{10,10})/')
with self.get_tmp_repo() as repo:
fname, _ = self.create_file(repo)
fsurl = urljoin(repo.file_url, 'shared-link')
data = {
'type': 'f',
'p': '/' + fname,
}
res = self.put(fsurl, data=data, expected=201)
self.assertRegexpMatches(res.headers['Location'], \
r'http(.*)/f/(\w{10,10})/')
res = self.get(SHARED_LINKS_URL).json()
self.assertNotEmpty(res)
for fileshare in res['fileshares']:
self.assertIsNotNone(fileshare['username'])
self.assertIsNotNone(fileshare['repo_id'])
#self.assertIsNotNone(fileshare['ctime'])
self.assertIsNotNone(fileshare['s_type'])
self.assertIsNotNone(fileshare['token'])
self.assertIsNotNone(fileshare['view_cnt'])
self.assertIsNotNone(fileshare['path'])
# def test_create_directory_shared_link(self):
# data = { 'operation': 'mkdir' }
# durl = self.test_dir_url + u'?p=/test_create_shared_link_d'
# self.post(durl, data=data)
# self.post(durl, data=data)
# fsurl = self.test_file_url + u'shared-link/'
# data = { 'type': 'd', 'p': '/test_create_shared_link_d' }
# res = self.put(fsurl, data=data)
# self.assertEqual(res.status_code, 201)
# self.assertRegexpMatches(res.headers['Location'], \
# r'http(.*)/d/(\w{10,10})/')
# def test_remove_shared_link(self):
# data = { 'operation': 'create' }
# furl = self.test_file_url + u'?p=/test_remove_shared_link_f'
# self.post(furl, data=data)
# fsurl = self.test_file_url + u'shared-link/'
# data = { 'type': 'f', 'p': '/test_remove_shared_link_f' }
# res = self.put(fsurl, data=data)
# import re
# t = re.match(r'http(.*)/f/(\w{10,10})/', res.headers['Location']).group(2)
# fturl = SHARED_LINKS_URL + u'?t=' + t
# res = self.delete(fturl)
# self.assertEqual(res.status_code, 200)
# self.assertEqual(res.text, u'{}')
# def test_get_shared_file_url(self):
# data = { 'operation': 'create' }
# furl = self.test_file_url + u'?p=/test_visit_shared_link_f'
# self.post(furl, data=data)
# fsurl = self.test_file_url + u'shared-link/'
# data = { 'type': 'f', 'p': '/test_visit_shared_link_f' }
# res = self.put(fsurl, data=data)
# import re
# t = re.match(r'http(.*)/f/(\w{10,10})/', res.headers['Location']).group(2)
# fdurl = F_URL + t + u'/'
# res = self.get(fdurl)
# self.assertEqual(res.status_code, 200)
# self.assertRegexpMatches(res.text, r'"http(.*)/files/\w{8,8}/(.*)"')
# def test_get_shared_file_detail(self):
# data = { 'operation': 'create' }
# furl = self.test_file_url + u'?p=/test_visitd_shared_link_f'
# self.post(furl, data=data)
# fsurl = self.test_file_url + u'shared-link/'
# data = { 'type': 'f', 'p': '/test_visitd_shared_link_f' }
# res = self.put(fsurl, data=data)
# import re
# t = re.match(r'http(.*)/f/(\w{10,10})/', res.headers['Location']).group(2)
# fdurl = F_URL + t + u'/detail/'
# res = self.get(fdurl)
# self.assertEqual(res.status_code, 200)
# json = res.json()
# self.assertIsNotNone(json)
# self.assertIsNotNone(json['repo_id'])
# self.assertIsNotNone(json['name'])
# self.assertIsNotNone(json['size'])
# self.assertIsNotNone(json['path'])
# self.assertIsNotNone(json['type'])
# self.assertIsNotNone(json['mtime'])
# self.assertIsNotNone(json['id'])
# def test_get_private_shared_file_url(self):
# if True: #todo: override this
# return
# data = { 'operation': 'create' }
# furl = self.test_file_url + u'?p=/test_visit_shared_link_sf'
# self.post(furl, data=data)
# fsurl = self.test_file_url + u'shared-link/'
# data = { 'type': 'f', 'p': '/test_visit_shared_link_sf' }
# res = self.put(fsurl, data=data)
# import re
# t = re.match(r'http(.*)/f/(\w{10,10})/', res.headers['Location']).group(2)
# fdurl = S_F_URL + t + u'/'
# res = self.get(fdurl)
# self.assertEqual(res.status_code, 200)
# self.assertRegexpMatches(res.text, r'"http(.*)/files/\w{8,8}/(.*)"')
# def test_get_private_shared_file_detail(self):
# if True: #todo: override this
# return
# data = { 'operation': 'create' }
# furl = self.test_file_url + u'?p=/test_visitd_shared_link_sf'
# self.post(furl, data=data)
# fsurl = self.test_file_url + u'shared-link/'
# data = { 'type': 'f', 'p': '/test_visitd_shared_link_sf' }
# res = self.put(fsurl, data=data)
# import re
# t = re.match(r'http(.*)/f/(\w{10,10})/', res.headers['Location']).group(2)
# fdurl = S_F_URL + t + u'/detail/'
# res = self.get(fdurl)
# self.assertEqual(res.status_code, 200)
# json = res.json()
# self.assertIsNotNone(json)
# self.assertIsNotNone(json['repo_id'])
# self.assertIsNotNone(json['name'])
# self.assertIsNotNone(json['size'])
# self.assertIsNotNone(json['path'])
# self.assertIsNotNone(json['type'])
# self.assertIsNotNone(json['mtime'])
# self.assertIsNotNone(json['id'])
# def test_remove_shared_file(self):
# if True: #todo: override this
# return
# data = { 'operation': 'create' }
# furl = self.test_file_url + u'?p=/test_remove_shared_file'
# self.post(furl, data=data)
# fsurl = self.test_file_url + u'shared-link/'
# data = { 'type': 'f', 'p': '/test_remove_shared_file' }
# res = self.put(fsurl, data=data)
# import re
# t = re.match(r'http(.*)/f/(\w{10,10})/', res.headers['Location']).group(2)
# fturl = SHARED_FILES_URL + u'?t=' + t
# res = self.delete(fturl)
# self.assertEqual(res.status_code, 200)
# self.assertEqual(res.text, u'{}')
# def test_list_shared_libraries(self):
# res = self.get(SHARED_LIBRARIES_URL)
# self.assertEqual(res.status_code, 200)
# json = res.json()
# self.assertIsNotNone(json)
# for repo in json:
# self.assertIsNotNone(repo['repo_id'])
# self.assertIsNotNone(repo['share_type'])
# self.assertIsNotNone(repo['permission'])
# self.assertIsNotNone(repo['encrypted'])
# self.assertIsNotNone(repo['user'])
# self.assertIsNotNone(repo['last_modified'])
# self.assertIsNotNone(repo['repo_desc'])
# self.assertIsNotNone(repo['group_id'])
# self.assertIsNotNone(repo['repo_name'])
# def test_list_beshared_libraries(self):
# res = self.get(BESHARED_LIBRARIES_URL)
# self.assertEqual(res.status_code, 200)
# json = res.json()
# self.assertIsNotNone(json)
# for repo in json:
# self.assertIsNotNone(repo['user'])
# self.assertIsNotNone(repo['repo_id'])
# self.assertIsNotNone(repo['share_type'])
# self.assertIsNotNone(repo['permission'])
# self.assertIsNotNone(repo['encrypted'])
# self.assertIsNotNone(repo['last_modified'])
# self.assertIsNotNone(repo['repo_desc'])
# self.assertIsNotNone(repo['group_id'])
# self.assertIsNotNone(repo['repo_name'])
# self.assertIsNotNone(repo['is_virtual'])
# def test_share_library(self):
# data = { 'share_type': 'group', 'user': USERNAME, 'group_id': self.gid , \
# 'permission': 'rw' }
# slurl = SHARED_LIBRARIES_URL + str(self.test_repo_id) + u'/'
# res = self.put(slurl, params=data)
# self.assertEqual(res.status_code, 200)
# self.assertEqual(res.text, u'"success"')
# def test_un_share_library(self):
# data = { 'share_type': 'group', 'user': USERNAME, 'group_id': self.gid , \
# 'permission': 'rw' }
# slurl = SHARED_LIBRARIES_URL + str(self.test_repo_id) + u'/'
# data = { 'share_type': 'group', 'user': USERNAME, 'group_id': self.gid }
# self.put(slurl, params=data)
# res = self.delete(slurl, params=data)
# self.assertEqual(res.status_code, 200)
# self.assertEqual(res.text, u'"success"')
# def test_list_shared_files(self):
# res = self.get(SHARED_FILES_URL)
# self.assertEqual(res.status_code, 200)
# json = res.json()
# self.assertIsNotNone(json)
# self.assertIsNotNone(json['priv_share_in'])
# self.assertIsNotNone(json['priv_share_out'])
# for sfiles in zip(json['priv_share_in'], json['priv_share_out']):
# for sfile in sfiles:
# self.assertIsNotNone(sfile['s_type'])
# self.assertIsNotNone(sfile['repo_id'])
# self.assertIsNotNone(sfile['permission'])
# self.assertIsNotNone(sfile['to_user'])
# self.assertIsNotNone(sfile['token'])
# self.assertIsNotNone(sfile['from_user'])
# self.assertIsNotNone(sfile['path'])
res = self.get(SHARED_LINKS_URL).json()
self.assertNotEmpty(res)
for fileshare in res['fileshares']:
self.assertIsNotNone(fileshare['username'])
self.assertIsNotNone(fileshare['repo_id'])
#self.assertIsNotNone(fileshare['ctime'])
self.assertIsNotNone(fileshare['s_type'])
self.assertIsNotNone(fileshare['token'])
self.assertIsNotNone(fileshare['view_cnt'])
self.assertIsNotNone(fileshare['path'])

View File

@ -1,41 +0,0 @@
from apitestbase import STARREDFILES_URL, get_authed_instance
from apitestbase import DEFAULT_LIBRARY_URL, LIBRARIES_URL
import unittest
class StarredFilesApiTestCase(unittest.TestCase):
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/'
def test_list_starred_files_api(self):
res = self.requests.get(STARREDFILES_URL)
self.assertEqual(res.status_code, 200)
json = res.json()
self.assertIsNotNone(json)
def test_star_file_api(self):
data = { 'operation': 'create' }
furl = self.furl + '?p=/test.c'
self.requests.post(furl, data=data)
data = { 'repo_id': self.rid, 'p': '/test.c' }
res = self.requests.post(STARREDFILES_URL, data=data)
self.assertEqual(res.status_code, 201)
self.assertEqual(res.text, u'"success"')
def test_un_star_file_api(self):
data = { 'operation': 'create' }
furl = self.furl + '?p=/test.c'
self.requests.post(furl, data=data)
data = { 'repo_id': self.rid, 'p': '/test.c' }
res = self.requests.post(STARREDFILES_URL, data=data)
res = self.requests.delete(STARREDFILES_URL, params=data)
self.assertEqual(res.status_code, 200)
self.assertEqual(res.text, u'"success"')
if __name__ == '__main__':
unittest.main(verbosity=2)

View File

@ -1,38 +0,0 @@
from apitestbase import USERNAME, get_authed_instance
from apitestbase import USERMSGS_URL, USERMSGS_COUNT_URL
import unittest
class UserMsgsApiTestCase(unittest.TestCase):
def setUp(self):
self.requests = get_authed_instance()
self.assertIsNotNone(self.requests)
def test_list_user_msgs_api(self):
res = self.requests.get(USERMSGS_URL)
self.assertEqual(res.status_code, 200)
json = res.json()
self.assertIsNotNone(json)
self.assertEqual(json['to_email'], USERNAME)
self.assertIsNotNone(json['next_page'])
self.assertIsNotNone(json['msgs'])
def test_reply_user_msg_api(self):
data = { 'id': '0', 'message': 'test' }
res = self.requests.post(USERMSGS_URL, data=data)
self.assertEqual(res.status_code, 200)
json = res.json()
self.assertIsNotNone(json)
self.assertIsNotNone(json['msgid'])
def test_count_unseen_msgs_api(self):
data = { 'id': '0', 'message': 'test' }
self.requests.post(USERMSGS_URL, data=data)
res = self.requests.get(USERMSGS_COUNT_URL, data=data)
self.assertEqual(res.status_code, 200)
json = res.json()
self.assertIsNotNone(json)
self.assertGreater(json['count'], 0)
if __name__ == '__main__':
unittest.main(verbosity=2)

View File

@ -1,16 +1,12 @@
import os
BASE_URL = os.getenv('TEST_BASE_URL', u'http://127.0.0.1:8000')
USERNAME = os.getenv('TEST_USERNAME', u'test@seahubtest.com')
PASSWORD = os.getenv('TEST_PASSWORD', u'testtest')
BASE_URL = os.getenv('SEAHUB_TEST_BASE_URL', u'http://127.0.0.1:8000')
USERNAME = os.getenv('SEAHUB_TEST_USERNAME', u'test@seafiletest.com')
PASSWORD = os.getenv('SEAHUB_TEST_PASSWORD', u'testtest')
ADMIN_USERNAME = os.getenv('SEAHUB_TEST_ADMIN_USERNAME', u'admin@seafiletest.com')
ADMIN_PASSWORD = os.getenv('SEAHUB_TEST_ADMIN_PASSWORD', u'adminadmin')
ADMIN_USERNAME = os.getenv('TEST_ADMIN_USERNAME', u'admin@seahubtest.com')
ADMIN_PASSWORD = os.getenv('TEST_ADMIN_PASSWORD', u'adminadmin')
if BASE_URL[-1] != '/':
BASE_URL += '/'
if os.getenv('TEST_IS_PRO', u'') == u'':
if os.getenv('SEAHUB_TEST_IS_PRO', u'') == u'':
IS_PRO = False
else:
S_PRO = True

View File

@ -18,4 +18,4 @@ def urljoin(base, *args):
return url
def apiurl(*parts):
return urljoin(BASE_URL, *parts)
return urljoin(BASE_URL, *parts)

View File

@ -1,9 +1,15 @@
#!/bin/bash
: ${PYTHON=python}
export TEST_USERNAME="test@seahubtest.com"
export TEST_PASSWORD="testtest"
export TEST_ADMIN_USERNAME="admin@seahubtest.com"
export TEST_ADMIN_PASSWORD="adminadmin"
: ${SEAHUB_TEST_USERNAME="test@seafiletest.com"}
: ${SEAHUB_TEST_PASSWORD="testtest"}
: ${SEAHUB_TEST_ADMIN_USERNAME="admin@seafiletest.com"}
: ${SEAHUB_TEST_ADMIN_PASSWORD="adminadmin"}
export SEAHUB_TEST_USERNAME
export SEAHUB_TEST_PASSWORD
export SEAHUB_TEST_ADMIN_USERNAME
export SEAHUB_TEST_ADMIN_PASSWORD
# If you run this script on your local machine, you must set CCNET_CONF_DIR
# and SEAFILE_CONF_DIR like this:
@ -31,19 +37,20 @@ function init() {
$PYTHON ./manage.py syncdb
# create normal user
$PYTHON -c "import ccnet; pool = ccnet.ClientPool('${CCNET_CONF_DIR}'); ccnet_threaded_rpc = ccnet.CcnetThreadedRpcClient(pool, req_pool=True); ccnet_threaded_rpc.add_emailuser('${TEST_USERNAME}', '${TEST_PASSWORD}', 0, 1);"
$PYTHON -c "import ccnet; pool = ccnet.ClientPool('${CCNET_CONF_DIR}'); ccnet_threaded_rpc = ccnet.CcnetThreadedRpcClient(pool, req_pool=True); ccnet_threaded_rpc.add_emailuser('${SEAHUB_TEST_USERNAME}', '${SEAHUB_TEST_PASSWORD}', 0, 1);"
# create admin
$PYTHON -c "import ccnet; pool = ccnet.ClientPool('${CCNET_CONF_DIR}'); ccnet_threaded_rpc = ccnet.CcnetThreadedRpcClient(pool, req_pool=True); ccnet_threaded_rpc.add_emailuser('${TEST_ADMIN_USERNAME}', '${TEST_ADMIN_PASSWORD}', 1, 1);"
$PYTHON -c "import ccnet; pool = ccnet.ClientPool('${CCNET_CONF_DIR}'); ccnet_threaded_rpc = ccnet.CcnetThreadedRpcClient(pool, req_pool=True); ccnet_threaded_rpc.add_emailuser('${SEAHUB_TEST_ADMIN_USERNAME}', '${SEAHUB_TEST_ADMIN_PASSWORD}', 1, 1);"
}
function start_seahub() {
$PYTHON ./manage.py runserver 1>/dev/null 2>&1 &
# $PYTHON ./manage.py runserver 1>/dev/null 2>&1 &
$PYTHON ./manage.py runserver 2>&1 &
sleep 5
}
function run_tests() {
pushd tests
nosetests
nosetests "$nose_opts"
popd
}
@ -55,6 +62,8 @@ case $1 in
start_seahub
;;
"test")
shift
nose_opts=$@
run_tests
;;
*)

View File

@ -1,5 +1,5 @@
import unittest
from common.common import BASE_URL, USERNAME, PASSWORD
from tests.common.common import BASE_URL, USERNAME, PASSWORD
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
@ -8,31 +8,31 @@ HOME_URL = BASE_URL + u'/home/my/'
LOGOUT_URL = BASE_URL + u'/accounts/logout/'
def get_logged_instance():
browser = webdriver.PhantomJS()
browser.get(LOGIN_URL)
username_input = browser.find_element_by_name('username')
password_input = browser.find_element_by_name('password')
username_input.send_keys(USERNAME)
password_input.send_keys(PASSWORD)
password_input.send_keys(Keys.RETURN)
if (browser.current_url != HOME_URL):
browser.quit()
return None
return browser
browser = webdriver.PhantomJS()
browser.get(LOGIN_URL)
username_input = browser.find_element_by_name('username')
password_input = browser.find_element_by_name('password')
username_input.send_keys(USERNAME)
password_input.send_keys(PASSWORD)
password_input.send_keys(Keys.RETURN)
if browser.current_url != HOME_URL:
browser.quit()
return None
return browser
class LoginTestCase(unittest.TestCase):
def setUp(self):
self.browser = get_logged_instance()
self.assertIsNotNone(self.browser)
self.addCleanup(self.browser.quit)
def setUp(self):
self.browser = get_logged_instance()
self.assertIsNotNone(self.browser)
self.addCleanup(self.browser.quit)
def test_login(self):
self.assertRegexpMatches(self.browser.current_url, HOME_URL)
def test_login(self):
self.assertRegexpMatches(self.browser.current_url, HOME_URL)
def test_logout(self):
myinfo_bar = self.browser.find_element_by_css_selector('#my-info')
logout_input = self.browser.find_element_by_css_selector('a#logout')
myinfo_bar.click()
logout_input.click()
self.assertRegexpMatches(self.browser.current_url, LOGOUT_URL)
def test_logout(self):
myinfo_bar = self.browser.find_element_by_css_selector('#my-info')
logout_input = self.browser.find_element_by_css_selector('a#logout')
myinfo_bar.click()
logout_input.click()
self.assertRegexpMatches(self.browser.current_url, LOGOUT_URL)