gitweb: Use BaseAppTests for functional tests

Signed-off-by: James Valleroy <jvalleroy@mailbox.org>
Reviewed-by: Sunil Mohan Adapa <sunil@medhas.org>
This commit is contained in:
James Valleroy 2021-10-31 20:23:38 -04:00 committed by Sunil Mohan Adapa
parent 05ae605cf9
commit 55fd53a18c
No known key found for this signature in database
GPG Key ID: 43EA1CFF0AA7C5F2

View File

@ -17,28 +17,15 @@ pytestmark = [pytest.mark.apps, pytest.mark.gitweb]
_default_url = functional.config['DEFAULT']['url']
@pytest.fixture(scope='module', autouse=True)
def fixture_background(session_browser):
"""Login and install the app."""
functional.login(session_browser)
functional.install(session_browser, 'gitweb')
functional.app_enable(session_browser, 'gitweb')
yield
functional.login(session_browser)
functional.app_disable(session_browser, 'gitweb')
class TestGitwebApp(functional.BaseAppTests):
app_name = 'gitweb'
has_service = False
has_web = True
@pytest.fixture(autouse=True)
def fixture_login(session_browser):
"""Login fixture."""
functional.login(session_browser)
functional.app_enable(session_browser, 'gitweb')
yield
def test_all_repos_private(session_browser):
def test_all_repos_private(self, session_browser):
"""Test repo accessability when all repos are private."""
_create_repo(session_browser, 'Test-repo', 'private', ok_if_exists=True)
_create_repo(session_browser, 'Test-repo', 'private',
ok_if_exists=True)
_set_all_repos_private(session_browser)
if not functional.user_exists(session_browser, 'gitweb_user'):
functional.create_user(session_browser, 'gitweb_user',
@ -49,21 +36,23 @@ def test_all_repos_private(session_browser):
functional.login_with_account(session_browser, functional.base_url,
'gitweb_user')
assert functional.is_available(session_browser, 'gitweb')
assert len(functional.find_on_front_page(session_browser, 'gitweb')) == 1
assert len(functional.find_on_front_page(session_browser,
'gitweb')) == 1
functional.login_with_account(session_browser, functional.base_url,
'nogroupuser')
assert not functional.is_available(session_browser, 'gitweb')
assert len(functional.find_on_front_page(session_browser, 'gitweb')) == 0
assert len(functional.find_on_front_page(session_browser,
'gitweb')) == 0
functional.logout(session_browser)
functional.access_url(session_browser, 'gitweb')
assert functional.is_login_prompt(session_browser)
assert len(functional.find_on_front_page(session_browser, 'gitweb')) == 0
assert len(functional.find_on_front_page(session_browser,
'gitweb')) == 0
@pytest.mark.backups
def test_backup(session_browser):
def test_backup_restore(self, session_browser):
"""Test backing up and restoring."""
_create_repo(session_browser, 'Test-repo', ok_if_exists=True)
functional.backup_create(session_browser, 'gitweb', 'test_gitweb')
@ -72,11 +61,11 @@ def test_backup(session_browser):
assert _repo_exists(session_browser, 'Test-repo')
assert functional.is_available(session_browser, 'gitweb')
@pytest.mark.parametrize('access', ['public', 'private'])
@pytest.mark.parametrize('repo_name', ['Test-repo', 'Test-repo.git'])
def test_create_delete_repo(session_browser, access, repo_name):
"""Test creating and deleting a repo and accessing with a git client."""
def test_create_delete_repo(self, session_browser, access, repo_name):
"""Test creating and deleting a repo and accessing with a git
client."""
_delete_repo(session_browser, repo_name, ignore_missing=True)
_create_repo(session_browser, repo_name, access)
@ -95,8 +84,7 @@ def test_create_delete_repo(session_browser, access, repo_name):
_delete_repo(session_browser, repo_name)
assert not _repo_exists(session_browser, repo_name)
def test_both_private_and_public_repo_exist(session_browser):
def test_both_private_and_public_repo_exist(self, session_browser):
"""Tests when both private and public repo exist."""
_create_repo(session_browser, 'Test-repo', 'public', True)
_create_repo(session_browser, 'Test-repo-private', 'private', True)
@ -105,10 +93,10 @@ def test_both_private_and_public_repo_exist(session_browser):
assert _site_repo_exists(session_browser, 'Test-repo')
assert not _site_repo_exists(session_browser, 'Test-repo-private')
def test_edit_repo_metadata(session_browser):
def test_edit_repo_metadata(self, session_browser):
"""Test edit repo metadata."""
_create_repo(session_browser, 'Test-repo2', 'public', ok_if_exists=True)
_create_repo(session_browser, 'Test-repo2', 'public',
ok_if_exists=True)
_delete_repo(session_browser, 'Test-repo', ignore_missing=True)
repo_metadata = {
'name': 'Test-repo',
@ -117,7 +105,8 @@ def test_edit_repo_metadata(session_browser):
'access': 'private',
}
_edit_repo_metadata(session_browser, 'Test-repo2', repo_metadata)
assert _get_repo_metadata(session_browser, "Test-repo") == repo_metadata
assert _get_repo_metadata(session_browser,
"Test-repo") == repo_metadata
_create_branch('Test-repo', 'branch1')
_set_default_branch(session_browser, 'Test-repo', 'branch1')
@ -125,15 +114,6 @@ def test_edit_repo_metadata(session_browser):
'Test-repo') == 'branch1'
def test_enable_disable(session_browser):
"""Test enabling and disabling the app."""
functional.app_disable(session_browser, 'gitweb')
assert not functional.is_available(session_browser, 'gitweb')
functional.app_enable(session_browser, 'gitweb')
assert functional.is_available(session_browser, 'gitweb')
def _create_local_repo(path):
"""Create a local repository."""
shutil.rmtree(path, ignore_errors=True)