mirror of
https://github.com/haiwen/seahub.git
synced 2025-07-05 11:17:36 +00:00
183 lines
6.1 KiB
Python
183 lines
6.1 KiB
Python
import json
|
|
from mock import patch
|
|
|
|
from seaserv import ccnet_api
|
|
from django.core.urlresolvers import reverse
|
|
from seahub.test_utils import BaseTestCase
|
|
from tests.common.utils import randstring
|
|
|
|
|
|
class LogsTest(BaseTestCase):
|
|
|
|
def setUp(self):
|
|
self.login_as(self.admin)
|
|
self.user_name = self.user.username
|
|
self.admin_name = self.admin.username
|
|
|
|
self.group_id = self.group.id
|
|
self.repo_id= self.repo.repo_id
|
|
self.new_user = '%s@%s.com' % (randstring(6), randstring(6))
|
|
self.library_url = reverse('api-v2.1-admin-library', args=[self.repo_id])
|
|
self.admin_log_url = reverse('api-v2.1-admin-admin-operation-logs')
|
|
|
|
def tearDown(self):
|
|
self.remove_group()
|
|
self.remove_repo()
|
|
|
|
@patch('seahub.api2.permissions.IsProVersion.has_permission')
|
|
def test_create_group(self, mock_has_permission):
|
|
|
|
mock_has_permission.return_value = True
|
|
|
|
# admin create group
|
|
url = reverse('api-v2.1-admin-groups')
|
|
group_name = randstring(10)
|
|
data = {
|
|
'group_name': group_name,
|
|
'group_owner': self.user.email
|
|
}
|
|
resp = self.client.post(url, data)
|
|
json_resp = json.loads(resp.content)
|
|
group_id = json_resp['id']
|
|
self.assertEqual(201, resp.status_code)
|
|
|
|
# get admin log
|
|
resp = self.client.get(self.admin_log_url)
|
|
self.assertEqual(200, resp.status_code)
|
|
json_resp = json.loads(resp.content)
|
|
|
|
assert json_resp['total_count'] == 1
|
|
assert json_resp['data'][0]['operation'] == 'group_create'
|
|
|
|
self.remove_group(group_id)
|
|
|
|
@patch('seahub.api2.permissions.IsProVersion.has_permission')
|
|
def test_transfer_group(self, mock_has_permission):
|
|
|
|
# admin transfer group
|
|
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
|
data = 'new_owner=%s' % self.admin_name
|
|
resp = self.client.put(url, data, 'application/x-www-form-urlencoded')
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
# get admin log
|
|
resp = self.client.get(self.admin_log_url)
|
|
self.assertEqual(200, resp.status_code)
|
|
json_resp = json.loads(resp.content)
|
|
|
|
assert json_resp['total_count'] == 1
|
|
assert json_resp['data'][0]['operation'] == 'group_transfer'
|
|
|
|
@patch('seahub.api2.permissions.IsProVersion.has_permission')
|
|
def test_delete_group(self, mock_has_permission):
|
|
|
|
# admin delete group
|
|
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
|
resp = self.client.delete(url)
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
# get admin log
|
|
resp = self.client.get(self.admin_log_url)
|
|
self.assertEqual(200, resp.status_code)
|
|
json_resp = json.loads(resp.content)
|
|
|
|
assert json_resp['total_count'] == 1
|
|
assert json_resp['data'][0]['operation'] == 'group_delete'
|
|
|
|
@patch('seahub.api2.permissions.IsProVersion.has_permission')
|
|
def test_create_user(self, mock_has_permission):
|
|
|
|
# admin create user
|
|
resp = self.client.post(
|
|
reverse('user_add',), {
|
|
'email': self.new_user,
|
|
'password1': '123',
|
|
'password2': '123',
|
|
}, HTTP_X_REQUESTED_WITH='XMLHttpRequest'
|
|
)
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
# get admin log
|
|
resp = self.client.get(self.admin_log_url)
|
|
self.assertEqual(200, resp.status_code)
|
|
json_resp = json.loads(resp.content)
|
|
|
|
assert json_resp['total_count'] == 1
|
|
assert json_resp['data'][0]['operation'] == 'user_add'
|
|
|
|
@patch('seahub.api2.permissions.IsProVersion.has_permission')
|
|
def test_delete_user(self, mock_has_permission):
|
|
|
|
# create a tmp user first
|
|
ccnet_api.add_emailuser(self.new_user, 'password', 0, 1)
|
|
|
|
# admin delete user
|
|
resp = self.client.post(
|
|
reverse('user_remove', args=[self.new_user])
|
|
)
|
|
self.assertEqual(302, resp.status_code)
|
|
|
|
# get admin log
|
|
resp = self.client.get(self.admin_log_url)
|
|
self.assertEqual(200, resp.status_code)
|
|
json_resp = json.loads(resp.content)
|
|
|
|
assert json_resp['total_count'] == 1
|
|
assert json_resp['data'][0]['operation'] == 'user_delete'
|
|
|
|
@patch('seahub.api2.permissions.IsProVersion.has_permission')
|
|
def test_transfer_library(self, mock_has_permission):
|
|
|
|
# admin transfer library
|
|
data = 'owner=%s' % self.admin_name
|
|
resp = self.client.put(self.library_url, data, 'application/x-www-form-urlencoded')
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
# get admin log
|
|
resp = self.client.get(self.admin_log_url)
|
|
self.assertEqual(200, resp.status_code)
|
|
json_resp = json.loads(resp.content)
|
|
|
|
assert json_resp['total_count'] == 1
|
|
assert json_resp['data'][0]['operation'] == 'repo_transfer'
|
|
|
|
@patch('seahub.api2.permissions.IsProVersion.has_permission')
|
|
def test_create_library(self, mock_has_permission):
|
|
|
|
# admin create library
|
|
url = reverse('api-v2.1-admin-libraries')
|
|
repo_name = randstring(10)
|
|
data = {
|
|
'name': repo_name,
|
|
'owner': self.user.email
|
|
}
|
|
resp = self.client.post(url, data)
|
|
json_resp = json.loads(resp.content)
|
|
repo_id = json_resp['id']
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
# get admin log
|
|
resp = self.client.get(self.admin_log_url)
|
|
self.assertEqual(200, resp.status_code)
|
|
json_resp = json.loads(resp.content)
|
|
|
|
assert json_resp['total_count'] == 1
|
|
assert json_resp['data'][0]['operation'] == 'repo_create'
|
|
|
|
self.remove_repo(repo_id)
|
|
|
|
@patch('seahub.api2.permissions.IsProVersion.has_permission')
|
|
def test_delete_library(self, mock_has_permission):
|
|
|
|
# admin delete library
|
|
resp = self.client.delete(self.library_url)
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
# get admin log
|
|
resp = self.client.get(self.admin_log_url)
|
|
self.assertEqual(200, resp.status_code)
|
|
json_resp = json.loads(resp.content)
|
|
|
|
assert json_resp['total_count'] == 1
|
|
assert json_resp['data'][0]['operation'] == 'repo_delete'
|