#coding: UTF-8 """ Test repos api. """ import pytest import uuid import unittest from tests.api.apitestbase import ApiTestBase from tests.api.urls import ( REPOS_URL, DEFAULT_REPO_URL, VIRTUAL_REPOS_URL, GET_REPO_TOKENS_URL ) from tests.common.utils import apiurl, urljoin, randstring from tests.common.common import USERNAME, PASSWORD, SEAFILE_BASE_URL # TODO: all tests should be run on an encrypted repo class ReposApiTest(ApiTestBase): def test_get_default_repo(self): repo = self.get(DEFAULT_REPO_URL).json() self.assertIsNotNone(repo['exists']) def test_create_default_repo(self): repo = self.post(DEFAULT_REPO_URL).json() self.assertEqual(len(repo['repo_id']), 36) self.assertEqual(repo['exists'], True) def test_list_repos(self): repos = self.get(REPOS_URL).json() # self.assertHasLen(repos, 1) for repo in repos: self.assertIsNotNone(repo['permission']) self.assertIsNotNone(repo['encrypted']) self.assertGreater(repo['mtime'], 0) self.assertIsNotNone(repo['mtime_relative']) self.assertIsNotNone(repo['owner']) self.assertIsNotNone(repo['id']) self.assertIsNotNone(repo['size']) self.assertIsNotNone(repo['name']) self.assertIsNotNone(repo['type']) # self.assertIsNotNone(repo['virtual']) #allow null for pub-repo self.assertIsNotNone(repo['desc']) self.assertIsNotNone(repo['root']) def test_get_repo_info(self): with self.get_tmp_repo() as repo: rinfo = self.get(repo.repo_url).json() self.assertFalse(rinfo['encrypted']) self.assertIsNotNone(rinfo['mtime']) self.assertIsNotNone(rinfo['owner']) self.assertIsNotNone(rinfo['id']) self.assertIsNotNone(rinfo['size']) self.assertIsNotNone(rinfo['name']) self.assertIsNotNone(rinfo['root']) self.assertIsNotNone(rinfo['desc']) self.assertIsNotNone(rinfo['type']) # elf.assertIsNotNone(rinfo['password_need']) # allow null here def test_get_repo_owner(self): with self.get_tmp_repo() as repo: repo_owner_url = urljoin(repo.repo_url, '/owner/') # XXX: why only admin can get the owner of a repo? info = self.admin_get(repo_owner_url).json() self.assertEqual(info['owner'], self.username) def test_get_repo_history(self): with self.get_tmp_repo() as repo: self.create_file(repo) self.create_dir(repo) repo_history_url = urljoin(repo.repo_url, '/history/') history = self.get(repo_history_url).json() commits = history['commits'] self.assertHasLen(commits, 3) for commit in commits: self.assertIsNotNone(commit['rev_file_size']) #self.assertIsNotNone(commit['rev_file_id']) #allow null self.assertIsNotNone(commit['ctime']) self.assertIsNotNone(commit['creator_name']) self.assertIsNotNone(commit['creator']) self.assertIsNotNone(commit['root_id']) #self.assertIsNotNone(commit['rev_renamed_old_path']) #allow null #self.assertIsNotNone(commit['parent_id']) #allow null self.assertIsNotNone(commit['new_merge']) self.assertIsNotNone(commit['repo_id']) self.assertIsNotNone(commit['desc']) self.assertIsNotNone(commit['id']) self.assertIsNotNone(commit['conflict']) #self.assertIsNotNone(commit['second_parent_id']) #allow null def test_create_repo(self): data = {'name': 'test'} res = self.post(REPOS_URL, data=data) repo = res.json() repo_id = repo['repo_id'] try: self.assertIsNotNone(repo['encrypted']) self.assertIsNotNone(repo['enc_version']) self.assertIsNotNone(repo['repo_id']) self.assertIsNotNone(repo['magic']) self.assertIsNotNone(repo['relay_id']) self.assertIsNotNone(repo['repo_version']) self.assertIsNotNone(repo['relay_addr']) self.assertIsNotNone(repo['token']) self.assertIsNotNone(repo['relay_port']) self.assertIsNotNone(repo['random_key']) self.assertIsNotNone(repo['email']) self.assertIsNotNone(repo['repo_name']) finally: self.remove_repo(repo_id) # Check the repo is really removed self.get(urljoin(REPOS_URL, repo_id), expected=404) def test_check_or_create_sub_repo(self): # TODO: create a sub folder and use it as a sub repo pass def test_fetch_repo_download_info(self): with self.get_tmp_repo() as repo: download_info_repo_url = urljoin(repo.repo_url, '/download-info/') info = self.get(download_info_repo_url).json() self.assertIsNotNone(info['relay_addr']) self.assertIsNotNone(info['token']) self.assertIsNotNone(info['repo_id']) self.assertIsNotNone(info['relay_port']) self.assertIsNotNone(info['encrypted']) self.assertIsNotNone(info['repo_name']) self.assertIsNotNone(info['relay_id']) self.assertIsNotNone(info['email']) def test_list_virtual_repos(self): # TODO: we need to create at least on virtual repo first vrepos = self.get(VIRTUAL_REPOS_URL).json()['virtual-repos'] for repo in vrepos: self.assertIsNotNone(repo['virtual_perm']) #self.assertIsNotNone(repo['store_id']) self.assertIsNotNone(repo['worktree_invalid']) self.assertIsNotNone(repo['encrypted']) self.assertIsNotNone(repo['origin_repo_name']) self.assertIsNotNone(repo['last_modify']) self.assertIsNotNone(repo['no_local_history']) #self.assertIsNotNone(repo['head_branch']) self.assertIsNotNone(repo['last_sync_time']) self.assertIsNotNone(repo['id']) self.assertIsNotNone(repo['size']) #self.assertIsNotNone(repo['share_permission']) self.assertIsNotNone(repo['worktree_changed']) self.assertIsNotNone(repo['worktree_checktime']) self.assertIsNotNone(repo['origin_path']) self.assertEqual(repo['is_virtual'], True) self.assertIsNotNone(repo['origin_repo_id']) self.assertIsNotNone(repo['version']) #self.assertIsNotNone(repo['random_key']) self.assertIsNotNone(repo['is_original_owner']) #self.assertIsNotNone(repo['shared_email']) self.assertIsNotNone(repo['enc_version']) self.assertIsNotNone(repo['head_cmmt_id']) #self.assertIsNotNone(repo['desc']) self.assertIsNotNone(repo['index_corrupted']) #self.assertIsNotNone(repo['magic']) self.assertIsNotNone(repo['name']) #self.assertIsNotNone(repo['worktree']) self.assertIsNotNone(repo['auto_sync']) #self.assertIsNotNone(repo['relay_id']) @pytest.mark.xfail def test_generate_repo_tokens(self): with self.get_tmp_repo() as ra: with self.get_tmp_repo() as rb: fake_repo_id = str(uuid.uuid4()) repo_ids = ','.join([ra.repo_id, rb.repo_id, fake_repo_id]) tokens = self.get(GET_REPO_TOKENS_URL + '?repos=%s' % repo_ids).json() assert ra.repo_id in tokens assert rb.repo_id in tokens assert fake_repo_id not in tokens for repo_id, token in tokens.iteritems(): self._get_repo_info(token, repo_id) def test_generate_repo_tokens_reject_invalid_params(self): self.get(GET_REPO_TOKENS_URL, expected=400) self.get(GET_REPO_TOKENS_URL + '?repos=badxxx', expected=400) def _get_repo_info(self, sync_token, repo_id, **kwargs): headers = { 'Seafile-Repo-Token': sync_token } url = urljoin(SEAFILE_BASE_URL, 'repo/%s/permission-check/?op=upload' % repo_id) self.get(url, use_token=False, headers=headers, **kwargs)