1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-07-09 05:03:47 +00:00
seahub/tests/api/endpoints/test_dtable.py

194 lines
6.8 KiB
Python
Raw Normal View History

2019-06-04 15:49:14 +00:00
# -*- coding: utf-8 -*-
import json
from django.core.urlresolvers import reverse
from seaserv import seafile_api
from seahub.dtable.models import Workspaces
from seahub.test_utils import BaseTestCase
class WorkspacesViewTest(BaseTestCase):
def setUp(self):
2019-06-05 07:26:25 +00:00
self.workspace = Workspaces.objects.create_workspace(
self.user.username,
self.repo.id
)
2019-06-04 15:49:14 +00:00
self.url = reverse('api-v2.1-workspaces')
self.login_as(self.user)
2019-06-25 07:38:42 +00:00
def tearDown(self):
assert len(Workspaces.objects.all()) == 1
workspace = Workspaces.objects.get_workspace_by_owner(self.user.username)
workspace_id = workspace.id
Workspaces.objects.delete_workspace(workspace_id)
2019-06-26 07:59:18 +00:00
self.remove_repo()
2019-06-25 07:38:42 +00:00
2019-06-04 15:49:14 +00:00
def test_can_list(self):
assert len(Workspaces.objects.all()) == 1
resp = self.client.get(self.url)
self.assertEqual(200, resp.status_code)
json_resp = json.loads(resp.content)
self.assertIsNotNone(json_resp["workspace_list"])
def test_list_with_invalid_repo(self):
assert len(Workspaces.objects.all()) == 1
2019-06-05 07:26:25 +00:00
url = reverse('api2-repo', args=[self.workspace.repo_id])
2019-06-04 15:49:14 +00:00
resp = self.client.delete(url, {}, 'application/x-www-form-urlencoded')
self.assertEqual(200, resp.status_code)
resp = self.client.get(self.url)
self.assertEqual(200, resp.status_code)
json_resp = json.loads(resp.content)
assert json_resp["workspace_list"] == []
2019-06-05 07:26:25 +00:00
assert len(Workspaces.objects.all()) == 1
2019-06-04 15:49:14 +00:00
2019-06-25 07:38:42 +00:00
class DTableTest(BaseTestCase):
2019-06-04 15:49:14 +00:00
def setUp(self):
2019-06-05 07:26:25 +00:00
self.workspace = Workspaces.objects.create_workspace(
self.user.username,
self.repo.id
)
2019-06-25 07:38:42 +00:00
self.url1 = reverse('api-v2.1-dtables')
self.url2 = reverse('api-v2.1-workspace-dtable', args=[self.workspace.id])
2019-06-04 15:49:14 +00:00
self.login_as(self.user)
2019-06-25 07:38:42 +00:00
def tearDown(self):
2019-06-04 15:49:14 +00:00
assert len(Workspaces.objects.all()) == 1
2019-06-25 07:38:42 +00:00
workspace = Workspaces.objects.get_workspace_by_owner(self.user.username)
workspace_id = workspace.id
2019-06-04 15:49:14 +00:00
2019-06-25 07:38:42 +00:00
Workspaces.objects.delete_workspace(workspace_id)
2019-06-04 15:49:14 +00:00
2019-06-26 07:59:18 +00:00
self.remove_repo()
2019-06-04 15:49:14 +00:00
def test_can_create(self):
2019-06-25 07:38:42 +00:00
resp = self.client.post(self.url1, {'name': 'table1', 'owner': self.user.username})
2019-06-04 15:49:14 +00:00
self.assertEqual(201, resp.status_code)
json_resp = json.loads(resp.content)
assert json_resp["table"]["name"] == 'table1'
def test_create_with_invalid_repo(self):
url = reverse('api2-repo', args=[self.workspace.repo_id])
resp = self.client.delete(url, {}, 'application/x-www-form-urlencoded')
self.assertEqual(200, resp.status_code)
2019-06-26 07:59:18 +00:00
resp = self.client.post(self.url1, {'name': 'table2', 'owner': self.user.username})
2019-06-04 15:49:14 +00:00
self.assertEqual(404, resp.status_code)
def test_can_rename(self):
2019-06-26 07:59:18 +00:00
resp = self.client.post(self.url1, {'name': 'table3', 'owner': self.user.username})
2019-06-04 15:49:14 +00:00
self.assertEqual(201, resp.status_code)
json_resp = json.loads(resp.content)
2019-06-05 07:26:25 +00:00
assert json_resp["table"]["name"] == 'table3'
2019-06-04 15:49:14 +00:00
resp = self.client.put(
2019-06-25 07:38:42 +00:00
self.url2,
2019-06-05 07:26:25 +00:00
'old_name=table3&new_name=table4',
2019-06-04 15:49:14 +00:00
'application/x-www-form-urlencoded'
)
self.assertEqual(200, resp.status_code)
json_resp = json.loads(resp.content)
2019-06-05 07:26:25 +00:00
assert json_resp["table"]["name"] == 'table4'
2019-06-04 15:49:14 +00:00
2019-06-26 07:59:18 +00:00
def test_rename_with_invalid_repo(self):
resp = self.client.post(self.url1, {'name': 'table5', 'owner': self.user.username})
2019-06-04 15:49:14 +00:00
self.assertEqual(201, resp.status_code)
json_resp = json.loads(resp.content)
2019-06-05 07:26:25 +00:00
assert json_resp["table"]["name"] == 'table5'
2019-06-04 15:49:14 +00:00
2019-06-26 07:59:18 +00:00
url = reverse('api2-repo', args=[self.workspace.repo_id])
resp = self.client.delete(url, {}, 'application/x-www-form-urlencoded')
2019-06-04 15:49:14 +00:00
self.assertEqual(200, resp.status_code)
resp = self.client.put(
2019-06-25 07:38:42 +00:00
self.url2,
2019-06-05 07:26:25 +00:00
'old_name=table5&new_name=table6',
2019-06-04 15:49:14 +00:00
'application/x-www-form-urlencoded'
)
self.assertEqual(404, resp.status_code)
def test_can_delete(self):
2019-06-26 07:59:18 +00:00
resp = self.client.post(self.url1, {'name': 'table7', 'owner': self.user.username})
2019-06-04 15:49:14 +00:00
self.assertEqual(201, resp.status_code)
json_resp = json.loads(resp.content)
2019-06-05 07:26:25 +00:00
assert json_resp["table"]["name"] == 'table7'
2019-06-04 15:49:14 +00:00
2019-06-05 07:26:25 +00:00
data = 'name=%s' % 'table7'
2019-06-25 07:38:42 +00:00
resp = self.client.delete(self.url2, data, 'application/x-www-form-urlencoded')
2019-06-04 15:49:14 +00:00
self.assertEqual(200, resp.status_code)
def test_delete_with_invalid_permission(self):
2019-06-26 07:59:18 +00:00
resp = self.client.post(self.url1, {'name': 'table8', 'owner': self.user.username})
2019-06-04 15:49:14 +00:00
self.assertEqual(201, resp.status_code)
json_resp = json.loads(resp.content)
2019-06-05 07:26:25 +00:00
assert json_resp["table"]["name"] == 'table8'
2019-06-04 15:49:14 +00:00
self.logout()
self.login_as(self.admin)
2019-06-05 07:26:25 +00:00
data = 'name=%s' % 'table8'
2019-06-25 07:38:42 +00:00
resp = self.client.delete(self.url2, data, 'application/x-www-form-urlencoded')
2019-06-04 15:49:14 +00:00
self.assertEqual(403, resp.status_code)
def test_delete_with_repo_only_read(self):
2019-06-26 07:59:18 +00:00
resp = self.client.post(self.url1, {'name': 'table9', 'owner': self.user.username})
2019-06-04 15:49:14 +00:00
self.assertEqual(201, resp.status_code)
json_resp = json.loads(resp.content)
2019-06-05 07:26:25 +00:00
assert json_resp["table"]["name"] == 'table9'
2019-06-04 15:49:14 +00:00
seafile_api.set_repo_status(self.workspace.repo_id, 1)
2019-06-05 07:26:25 +00:00
data = 'name=%s' % 'table9'
2019-06-25 07:38:42 +00:00
resp = self.client.delete(self.url2, data, 'application/x-www-form-urlencoded')
2019-06-04 15:49:14 +00:00
self.assertEqual(403, resp.status_code)
def test_can_get_access_token(self):
resp = self.client.post(self.url1, {'name': 'table10', 'owner': self.user.username})
self.assertEqual(201, resp.status_code)
json_resp = json.loads(resp.content)
assert json_resp["table"]["name"] == 'table10'
url = reverse('api-v2.1-dtable-access-token', args=[self.workspace.id, 'table10'])
resp = self.client.get(url, {}, 'application/x-www-form-urlencoded')
self.assertEqual(200, resp.status_code)
json_resp = json.loads(resp.content)
self.assertIsNotNone(json_resp["access_token"])
def test_get_access_token_with_invalid_repo(self):
resp = self.client.post(self.url1, {'name': 'table11', 'owner': self.user.username})
self.assertEqual(201, resp.status_code)
json_resp = json.loads(resp.content)
assert json_resp["table"]["name"] == 'table11'
url3 = reverse('api2-repo', args=[self.workspace.repo_id])
resp = self.client.delete(url3, {}, 'application/x-www-form-urlencoded')
self.assertEqual(200, resp.status_code)
url4 = reverse('api-v2.1-dtable-access-token', args=[self.workspace.id, 'table11'])
resp = self.client.get(url4, {}, 'application/x-www-form-urlencoded')
self.assertEqual(404, resp.status_code)