1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-07-05 11:17:36 +00:00
seahub/tests/api/endpoints/admin/test_logs.py
2017-09-09 15:27:04 +08:00

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'