1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-09-01 15:09:14 +00:00

client create enc library with disable enable_enc_library test

This commit is contained in:
zming
2017-09-27 14:47:29 +08:00
parent 829ee2d9da
commit 0f97c18558
2 changed files with 65 additions and 7 deletions

View File

@@ -6,6 +6,7 @@ import json
import time
import pytest
import uuid
from constance import config
from django.core.urlresolvers import reverse
from seaserv import seafile_api
@@ -156,7 +157,14 @@ class ReposApiTest(ApiTestBase):
'repo/%s/permission-check/?op=upload' % repo_id)
self.get(url, use_token=False, headers=headers, **kwargs)
class NewReposApiTest(BaseTestCase):
# @pytest.mark.xfail
def setUp(self):
self.clear_cache()
self.login_as(self.admin)
config.ENABLE_ENCRYPTED_LIBRARY = True
def test_create_encrypted_repo(self):
"""Test create an encrypted repo with the secure keys generated on client
side.
@@ -172,8 +180,8 @@ class ReposApiTest(ApiTestBase):
'magic': enc_info.magic,
'random_key': enc_info.random_key,
}
res = self.post(REPOS_URL, data=data)
repo = res.json()
repo = self.client.post(REPOS_URL, data=data)
repo = json.loads(repo.content)
assert repo['repo_id'] == repo_id
assert repo['encrypted']
assert repo['magic'] == enc_info.magic
@@ -181,10 +189,60 @@ class ReposApiTest(ApiTestBase):
# validate the password on server
set_password_url = apiurl('/api2/repos/{}/'.format(repo['repo_id']))
self.post(set_password_url, data={'password': password})
self.client.post(set_password_url, data={'password': password})
# do some file operation
self.create_file(repo['repo_id'])
self.create_file(repo_id=repo['repo_id'], parent_dir='/', filename='repo-test', username=self.admin.username)
def test_create_encrypted_repo_with_disable_create_enc_library(self):
"""Test create an encrypted repo with the secure keys generated on client
side.
"""
config.ENABLE_ENCRYPTED_LIBRARY = False
repo_id = str(uuid.uuid4())
password = randstring(16)
enc_version = 2
enc_info = seafile_api.generate_magic_and_random_key(enc_version, repo_id, password)
data = {
'name': 'enc-test-with-disable-encry',
'repo_id': repo_id,
'enc_version': enc_version,
'magic': enc_info.magic,
'random_key': enc_info.random_key,
}
res = self.client.post(REPOS_URL, data=data)
assert res.status_code == 403
def test_create_encrypted_repo_with_invalid_repoid(self):
"""Test create an encrypted repo with the secure keys generated on client
side.
"""
repo_id = 'qwer'
password = randstring(16)
enc_version = 2
enc_info = seafile_api.generate_magic_and_random_key(enc_version, repo_id, password)
data = {
'name': 'enc-test-with-disable-encry',
'repo_id': repo_id,
'enc_version': enc_version,
'magic': enc_info.magic,
'random_key': enc_info.random_key,
}
res = self.client.post(REPOS_URL, data=data)
print res
assert res.status_code == 400
# repo = res.json()
# assert repo['repo_id'] == repo_id
# assert repo['encrypted']
# assert repo['magic'] == enc_info.magic
# assert repo['random_key'] == enc_info.random_key
#
# # validate the password on server
# set_password_url = apiurl('/api2/repos/{}/'.format(repo['repo_id']))
# self.post(set_password_url, data={'password': password})
#
# do some file operation
# Uncomment following to test api performance.