mirror of
https://github.com/haiwen/seahub.git
synced 2025-07-12 06:29:23 +00:00
* delete thridpart/social_django * delete social_django in seahub/urls.py * delete social_django in seahub/settings.py * delete seahub/notifications/management/commands/send_wxwork_notices.py * delete social_django in code annotation * delete seahub/social_core * delete tests/seahub/social_core * delete social_core in seahub/urls.py * delete social_core in seahub/settings.py * change app_label to auth in SocialAuthUser model * 2to3 asserts * 2to3 basestring * 2to3 dict * 2to3 except * 2to3 filter * 2to3 future * 2to3 has_key * 2to3 idioms * 2to3 import * 2to3 imports * 2to3 long * 2to3 map * 2to3 next * 2to3 numliterals * 2to3 print * 2to3 raise * 2to3 raw_input * 2to3 reduce * 2to3 reload * 2to3 set_literal * 2to3 unicode * 2to3 urllib * 2to3 ws_comma * 2to3 xrange * 2to3 zip * add pymysql in __init__.py * fix encode and decode in seahub/cconvert.py * fix seafserv_rpc.is_passwd_set in seahub/views/__init__.py * fix smart_unicode to smart_text * fix force_unicode to force_text * delete seaserv.get_session_info * delete seaserv.ccnet_rpc * fix indent error in seahub/auth/middleware.py * update dev-requirements * update test-requirements * update requirements * fix StringIO to BytesIO in thumbnail * fix seaserv.list_inner_pub_repos to seafile_api.get_inner_pub_repo_list * fix seaserv.list_org_inner_pub_repos to seafile_api.list_org_inner_pub_repos * add logger in seahub/utils/__init__.py * fix sort cmp in seahub/views/__init__.py * fix sort cmp in seahub/base/management/commands/export_file_access_log.py * fix sort cmp in seahub/api2/endpoints/repo_trash.py * fix sort cmp in seahub/api2/endpoints/shared_repos.py * fix sort cmp in seahub/api2/endpoints/shared_folders.py * fix sort cmp in seahub/wiki/views.py * fix sort cmp in seahub/api2/endpoints/wiki_pages.py * fix sort cmp in seahub/api2/endpoints/group_libraries.py * fix sort cmp in seahub/base/models.py * fix sort cmp in seahub/api2/endpoints/upload_links.py * fix sort cmp in seahub/views/ajax.py * fix sort cmp in seahub/api2/views.py * fix sort cmp in seahub/views/wiki.py * fix sort cmp in seahub/api2/endpoints/repos.py * fix sort cmp in seahub/api2/endpoints/starred_items.py * fix sort cmp in seahub/views/file.py * fix sort cmp in seahub/api2/endpoints/dir.py * fix sort cmp in seahub/api2/endpoints/share_links.py * fix cmp to cmp_to_key in seahub/api2/endpoints/admin/device_trusted_ip.py * fix cmp to cmp_to_key in tests/api/endpoints/admin/test_device_trusted_ip.py * delete encode('utf-8') in seafile_api.list_dir_by_commit_and_path * delete encode('utf-8') in is_file_starred * delete encode('utf-8') in seafile_api.list_dir_by_path * delete path.encode('utf-8') in seahub/views/file.py * fix os.write to add encode('utf-8') * add encode('utf-8') for hashlib * add encode('utf-8') for hmac * fix with open(file, 'wb') for binary file * fix encode and decode in seahub/utils/hasher.py * fix next in thirdpart/shibboleth/views.py * fix next in seahub/profile/views.py * fix next in seahub/notifications/views.py * fix next in seahub/institutions/views.py * fix next in seahub/options/views.py * fix next in seahub/share/views.py * fix next in seahub/avatar/views.py * fix next in seahub/views/__init__.py * fix next in seahub/group/views.py * fix next in seahub/views/wiki.py * fix next in seahub/views/sysadmin.py * fix next in seahub/views/file.py * fix string.lowercase to string.ascii_lowercase in test * fix open file add 'rb' in test * fix self.user.username in test * add migrations in file_participants * fix list_org_inner_pub_repos to list_org_inner_pub_repos_by_owner * fix from seaserv import is_passwd_set to seafile_api.is_password_set * fix assert bytes resp.content in test * fix seafile_api.get_inner_pub_repo_list to seafile_api.list_inner_pub_repos_by_owner * fix seafile_api.is_passwd_set to seafile_api.is_password_set * fix AccountsApiTest assert length * rewrite sort_devices cmp to operator.lt * fix bytes + str in seahub/api2/views.py * fix assert bytes resp.content in test * fix hashlib encode in seahub/thirdpart/registration/models.py * change app_label to base in SocialAuthUser * fix base64 encode in seahub/base/database_storage/database_storage.py * fix assert bytes resp.content * remove path.decode in def mkstemp() * remove path.decode in FpathToLinkTest * remove str decode in FileTagTest * remove mock_write_xls.assert_called_once() in SysUserAdminExportExcelTest * fix urllib assert in FilesApiTest * fix link fields in FileCommentsTest * fix get_related_users_by_repo() * fix assert list in GetRepoSharedUsersTest * fix create user in AccountTest * fix repeated key in dict seahub/api2/views.py * add drone.yml * update nginx conf in test * update test conf in test * update dist and push after test success * update drone conf to dist and push * fix assert in BeSharedReposTest * fix seafile_api.list_org_inner_pub_repos_by_owner(org_id, username) to seafile_api.list_org_inner_pub_repos(org_id) * fix seafile_api.list_inner_pub_repos_by_owner(username) to seafile_api.get_inner_pub_repo_list() * update pyjwt requirement * update dist branch in drone * add SKIP in dist and push * fix StringIO to BytesIO in seahub/avatar/models.py * fix if org_id > 0 to if org_id and org_id > 0 * remove payment * fix StringIO to BytesIO in seahub/base/database_storage/database_storage.py * fix send_message to seafile_api.publish_event in seahub/drafts/utils.py * fix send_message to seafile_api.publish_event in seahub/api2/views.py * fix send_message to seafile_api.publish_event in seahub/api2/endpoints/repos.py * fix send_message to seafile_api.publish_event in seahub/views/file.py * fix send_message to seafile_api.publish_event in seahub/utils/__init__.py * fix image_file.read encode in seahub/base/database_storage/database_storage.py * fix DatabaseStorageTest * remove .travis.yml * drone branch include master
277 lines
10 KiB
Python
277 lines
10 KiB
Python
import json
|
|
|
|
from django.core.urlresolvers import reverse
|
|
import seaserv
|
|
from seaserv import seafile_api
|
|
|
|
from seahub.base.accounts import User
|
|
from seahub.base.templatetags.seahub_tags import email2nickname
|
|
from seahub.profile.models import Profile
|
|
from seahub.test_utils import BaseTestCase
|
|
from tests.common.utils import randstring
|
|
|
|
class AccountTest(BaseTestCase):
|
|
def setUp(self):
|
|
self.clear_cache()
|
|
self.user1 = self.create_user('user_%s@test.com' % randstring(4),
|
|
is_staff=False)
|
|
self.user2 = self.create_user('user_%s@test.com' % randstring(4),
|
|
is_staff=False)
|
|
|
|
def tearDown(self):
|
|
self.remove_user(self.user1.username)
|
|
self.remove_user(self.user2.username)
|
|
|
|
def _do_create(self):
|
|
resp = self.client.put(
|
|
reverse('api2-account', args=['new_user_put_create@test.com']),
|
|
'password=123456&is_staff=1&is_active=1',
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
# manually remove this account
|
|
self.remove_user(email='new_user_put_create@test.com')
|
|
return resp
|
|
|
|
def _do_get_info(self):
|
|
return self.client.get(reverse('api2-account', args=[self.user1.email]))
|
|
|
|
def _do_migrate(self):
|
|
return self.client.post(
|
|
reverse('api2-account', args=[self.user1.username]), {
|
|
'op': 'migrate',
|
|
'to_user': self.user2.username,
|
|
}
|
|
)
|
|
|
|
def _do_update(self):
|
|
return self.client.put(
|
|
reverse('api2-account', args=[self.user1.username]),
|
|
'password=654321&is_staff=1&is_active=0&name=user1&storage=102400&login_id=hello',
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
|
|
def _do_update_name(self):
|
|
return self.client.put(
|
|
reverse('api2-account', args=[self.user1.username]),
|
|
'name=user1',
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
|
|
def _do_update_loginid(self):
|
|
return self.client.put(
|
|
reverse('api2-account', args=[self.user1.username]),
|
|
'login_id=hello',
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
|
|
def _do_update_loginid_useemptystring(self):
|
|
return self.client.put(
|
|
reverse('api2-account', args=[self.user1.username]),
|
|
'login_id=',
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
|
|
def _do_update_loginid_sendagain(self):
|
|
self.client.put(
|
|
reverse('api2-account', args=[self.user1.username]),
|
|
'login_id=test',
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
return self.client.put(
|
|
reverse('api2-account', args=[self.user1.username]),
|
|
'login_id=test',
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
|
|
def _do_delete(self):
|
|
return self.client.delete(
|
|
reverse('api2-account', args=[self.user1.username])
|
|
)
|
|
|
|
def test_permission_error(self):
|
|
self.login_as(self.user)
|
|
|
|
resp = self._do_create()
|
|
self.assertEqual(403, resp.status_code)
|
|
|
|
resp = self._do_get_info()
|
|
self.assertEqual(403, resp.status_code)
|
|
|
|
resp = self._do_update()
|
|
self.assertEqual(403, resp.status_code)
|
|
|
|
resp = self._do_migrate()
|
|
self.assertEqual(403, resp.status_code)
|
|
|
|
resp = self._do_delete()
|
|
self.assertEqual(403, resp.status_code)
|
|
|
|
def test_get_info(self):
|
|
self.login_as(self.admin)
|
|
|
|
resp = self._do_get_info()
|
|
json_resp = json.loads(resp.content)
|
|
assert len(json_resp) == 12
|
|
assert json_resp['email'] == self.user1.username
|
|
assert json_resp['is_staff'] is False
|
|
assert json_resp['is_active'] is True
|
|
assert json_resp['usage'] == 0
|
|
|
|
def test_create(self):
|
|
self.login_as(self.admin)
|
|
|
|
resp = self._do_create()
|
|
self.assertEqual(201, resp.status_code)
|
|
|
|
def test_update(self):
|
|
self.login_as(self.admin)
|
|
|
|
resp = self._do_update()
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
self.assertTrue(User.objects.get(self.user1.username).check_password(
|
|
'654321'))
|
|
self.assertTrue(User.objects.get(self.user1.username).is_staff)
|
|
self.assertFalse(User.objects.get(self.user1.username).is_active)
|
|
self.assertEqual(Profile.objects.get_profile_by_user(
|
|
self.user1.username).login_id, 'hello')
|
|
self.assertEqual(Profile.objects.get_profile_by_user(
|
|
self.user1.username).nickname, 'user1')
|
|
self.assertEqual(seafile_api.get_user_quota(
|
|
self.user1.username), 102400000000)
|
|
|
|
def test_update_name(self):
|
|
"""only test name"""
|
|
self.login_as(self.admin)
|
|
resp = self._do_update_name()
|
|
self.assertEqual(Profile.objects.get_profile_by_user(
|
|
self.user1.username).nickname, 'user1')
|
|
|
|
def test_update_loginid(self):
|
|
"""only test loginid"""
|
|
self.login_as(self.admin)
|
|
resp = self._do_update_loginid()
|
|
self.assertEqual(Profile.objects.get_profile_by_user(
|
|
self.user1.username).login_id, 'hello')
|
|
|
|
def test_update_loginid_useemptystring(self):
|
|
"""test loginid, longid send the empty"""
|
|
self.login_as(self.admin)
|
|
resp = self._do_update_loginid_useemptystring()
|
|
self.assertEqual(400, resp.status_code)
|
|
|
|
def test_update_loginid_sendagain(self):
|
|
"""test loginid,sent twice"""
|
|
self.login_as(self.admin)
|
|
resp = self._do_update_loginid_sendagain()
|
|
self.assertEqual(400, resp.status_code)
|
|
|
|
def test_refresh_profile_cache_after_update(self):
|
|
self.login_as(self.admin)
|
|
self.assertEqual(email2nickname(self.user1.username),
|
|
self.user1.username.split('@')[0])
|
|
|
|
resp = self._do_update()
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
self.assertEqual(email2nickname(self.user1.username), 'user1')
|
|
|
|
def test_migrate(self):
|
|
self.login_as(self.admin)
|
|
|
|
# user1 created a repo
|
|
user1_repo = self.create_repo(name='user1-repo', desc='',
|
|
username=self.user1.username,
|
|
passwd=None)
|
|
user1_repos = seafile_api.get_owned_repo_list(self.user1.username)
|
|
self.assertEqual(len(user1_repos), 1)
|
|
self.assertEqual(user1_repos[0].id, user1_repo)
|
|
|
|
# user1 created a group and joined a group created by the other
|
|
user1_group = self.create_group(group_name='test_group',
|
|
username=self.user1.username)
|
|
other_group = self.create_group(group_name='other_group',
|
|
username=self.user.username)
|
|
seaserv.ccnet_threaded_rpc.group_add_member(other_group.id,
|
|
self.user.username,
|
|
self.user1.username)
|
|
|
|
user1_groups = seaserv.get_personal_groups_by_user(self.user1.username)
|
|
self.assertEqual(len(user1_groups), 2)
|
|
|
|
real_creator = sorted([self.user1.username, self.user.username])
|
|
test_creator = sorted([x.creator_name for x in user1_groups])
|
|
self.assertEqual(real_creator, test_creator)
|
|
|
|
real_id = sorted([user1_group.id, other_group.id])
|
|
test_id = sorted([x.id for x in user1_groups])
|
|
self.assertEqual(real_id, test_id)
|
|
|
|
# user2 had no repos
|
|
user2_repos = seafile_api.get_owned_repo_list(self.user2.username)
|
|
self.assertEqual(len(user2_repos), 0)
|
|
# user2 had no groups
|
|
user2_groups = seaserv.get_personal_groups_by_user(self.user2.username)
|
|
self.assertEqual(len(user2_groups), 0)
|
|
|
|
# admin migrate account user1 to account user2
|
|
resp = self._do_migrate()
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
### Verify ###
|
|
# user1 should have no repos
|
|
new_user1_repos = seafile_api.get_owned_repo_list(self.user1.username)
|
|
self.assertEqual(len(new_user1_repos), 0)
|
|
# user1 should still in two groups, except not the creator anymore in
|
|
# the first group, but second group should remain the same
|
|
user1_groups = seaserv.get_personal_groups_by_user(self.user1.username)
|
|
self.assertEqual(len(user1_groups), 2)
|
|
|
|
real_creator = sorted([self.user1.username, self.user.username])
|
|
test_creator = sorted([x.creator_name for x in user1_groups])
|
|
self.assertNotEqual(real_creator, test_creator)
|
|
|
|
real_id = sorted([user1_group.id, other_group.id])
|
|
test_id = sorted([x.id for x in user1_groups])
|
|
self.assertEqual(real_id, test_id)
|
|
|
|
# user2 should have the repo used to be user1's
|
|
new_user2_repos = seafile_api.get_owned_repo_list(self.user2.username)
|
|
self.assertEqual(len(new_user2_repos), 1)
|
|
self.assertEqual(new_user2_repos[0].id, user1_repo)
|
|
# user2 should be in two groups, and is the creator of first group,
|
|
# but second group should remain the same
|
|
user2_groups = seaserv.get_personal_groups_by_user(self.user2.username)
|
|
self.assertEqual(len(user2_groups), 2)
|
|
|
|
real_creator = sorted([self.user2.username, self.user.username])
|
|
test_creator = sorted([x.creator_name for x in user2_groups])
|
|
self.assertEqual(real_creator, test_creator)
|
|
|
|
real_id = sorted([user1_group.id, other_group.id])
|
|
test_id = sorted([x.id for x in user2_groups])
|
|
self.assertEqual(real_id, test_id)
|
|
|
|
def test_delete(self):
|
|
self.login_as(self.admin)
|
|
|
|
resp = self._do_delete()
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
def test_new_user_get_info_after_edit_profile(self):
|
|
new_user = self.create_user("test@new.user", is_staff=True)
|
|
self.login_as(new_user)
|
|
resp = self.client.post(reverse('edit_profile'), {
|
|
'nickname': 'new nickname'
|
|
})
|
|
|
|
resp = self.client.get(reverse('api2-account', args=[new_user.username]))
|
|
json_resp = json.loads(resp.content)
|
|
assert len(json_resp) == 12
|
|
assert json_resp['email'] == new_user.username
|
|
assert json_resp['is_staff'] is True
|
|
assert json_resp['is_active'] is True
|
|
assert json_resp['usage'] == 0
|
|
assert json_resp['institution'] == ''
|
|
self.remove_user(new_user.username)
|