mirror of
https://github.com/freedombox/FreedomBox.git
synced 2026-04-08 09:41:35 +00:00
- Since we are going to be an OpenID Provider, we need to fix the URLs that
other apps will be configured with for authentication. So change now from
/plinth to /freedombox. If done later, it will be harder since all the
configuration files for all dependent apps will need to be updated.
Tests:
- App availability checking works. Request goes to /freedombox URL
- Favicon is served properly and through /favicon.ico URL
- Redirection happens from / to /freedombox directly
- UI is available on /freedombox and on /plinth
- Manual page show /freedombox as the URL in two places
- Static files are successfully served from /freedombox URLs. URLs inside page
start with /freedombox
- backup, bepasty, calibre, config, dynamicdns, ejabberd, featherwiki, gitweb,
ikiwiki, kiwix, miniflux, names, openvpn, shadowsocks, shadowsocksserver,
sharing, shapshot, tiddlywiki, users, wireguard, jsxc, matrixsynapse, first
wizard, storage, samba, tags functional tests work. Backup/restore test for
matrixsynapse fails due to an unrelated bug (server not restarted after
restore).
- Setting the home page works:
- Having /plinth in the home page configuration works. Shows selection
correctly.
- Setting to app works. Shows selection correctly.
- Setting to user home page (sets /freedombox). Shows selection correctly.
- Setting to apache default works. Shows selection correctly.
- Changing back to FreedomBox service works. Shows selection correctly.
- Unit tests work
- Configuration page shows /freedombox in description but not /plinth
- Diagnostics show /freedombox in tests
- Roundcube URL link in email app has /freedombox
- email loads the page /.well-known/autoconfig/mail/config-v1.1.xml correctly
- email app shows /freedombox/apps/roundcube for /roundcube if roundcube is not
installed.
- networks: router configuration page shows URL starting with /freedombox.
- snapshot: Shows URL starting with /freedombox on the app page
- js licenses page uses /freedombox prefix for JSXC.
Signed-off-by: Sunil Mohan Adapa <sunil@medhas.org>
Reviewed-by: James Valleroy <jvalleroy@mailbox.org>
119 lines
3.8 KiB
Python
119 lines
3.8 KiB
Python
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
"""
|
|
Functional, browser based tests for bepasty app.
|
|
"""
|
|
|
|
import pytest
|
|
|
|
from plinth.tests import functional
|
|
|
|
pytestmark = [pytest.mark.apps, pytest.mark.bepasty]
|
|
|
|
|
|
class TestBepastyApp(functional.BaseAppTests):
|
|
app_name = 'bepasty'
|
|
has_service = False
|
|
has_web = True
|
|
|
|
def test_set_default_permissions_list_and_read_all(self, session_browser):
|
|
functional.app_enable(session_browser, 'bepasty')
|
|
_logout(session_browser)
|
|
_set_default_permissions(session_browser, 'read list')
|
|
|
|
assert _can_list_all(session_browser)
|
|
|
|
def test_set_default_permissions_read_files(self, session_browser):
|
|
functional.app_enable(session_browser, 'bepasty')
|
|
_logout(session_browser)
|
|
_set_default_permissions(session_browser, 'read')
|
|
|
|
assert _cannot_list_all(session_browser)
|
|
|
|
def test_add_password(self, session_browser):
|
|
functional.app_enable(session_browser, 'bepasty')
|
|
password_added = _add_and_save_password(session_browser)
|
|
|
|
assert _can_login(session_browser, password_added)
|
|
|
|
def test_remove_password(self, session_browser):
|
|
functional.app_enable(session_browser, 'bepasty')
|
|
password_added = _add_and_save_password(session_browser)
|
|
_remove_all_passwords(session_browser)
|
|
|
|
assert not _can_login(session_browser, password_added)
|
|
|
|
@pytest.mark.backups
|
|
def test_backup_restore(self, session_browser):
|
|
functional.app_enable(session_browser, 'bepasty')
|
|
password_added = _add_and_save_password(session_browser)
|
|
functional.backup_create(session_browser, 'bepasty', 'test_bepasty')
|
|
|
|
_remove_all_passwords(session_browser)
|
|
functional.backup_restore(session_browser, 'bepasty', 'test_bepasty')
|
|
|
|
assert functional.is_available(session_browser, 'bepasty')
|
|
assert _can_login(session_browser, password_added)
|
|
|
|
|
|
def _add_and_save_password(session_browser):
|
|
_remove_all_passwords(session_browser)
|
|
_add_password(session_browser)
|
|
return _get_password(session_browser)
|
|
|
|
|
|
def _set_default_permissions(browser, permissions=''):
|
|
functional.nav_to_module(browser, 'bepasty')
|
|
browser.choose('default_permissions', permissions)
|
|
functional.submit(browser, form_class='form-configuration')
|
|
|
|
|
|
def _add_password(browser):
|
|
functional.visit(browser, '/freedombox/apps/bepasty/add/')
|
|
for permission in ['read', 'create', 'list', 'delete', 'admin']:
|
|
browser.find_by_css('#id_bepasty-permissions input[value="{}"]'.format(
|
|
permission)).check()
|
|
browser.fill('bepasty-comment', 'bepasty functional test')
|
|
functional.submit(browser, form_class='form-bepasty')
|
|
|
|
|
|
def _remove_all_passwords(browser):
|
|
functional.nav_to_module(browser, 'bepasty')
|
|
while True:
|
|
remove_button = browser.find_by_css('.password-remove')
|
|
if remove_button:
|
|
functional.submit(browser, element=remove_button)
|
|
else:
|
|
break
|
|
|
|
|
|
def _get_password(browser):
|
|
functional.nav_to_module(browser, 'bepasty')
|
|
return browser.find_by_css('.password-password').first.text
|
|
|
|
|
|
def _can_login(browser, password):
|
|
_logout(browser)
|
|
browser.fill('token', password)
|
|
login = browser.find_by_xpath('//form//button')
|
|
functional.submit(browser, element=login)
|
|
|
|
return bool(browser.find_by_value('Logout'))
|
|
|
|
|
|
def _logout(browser):
|
|
functional.visit(browser, '/bepasty')
|
|
logout = browser.find_by_value('Logout')
|
|
if logout:
|
|
logout.click()
|
|
|
|
|
|
def _can_list_all(browser):
|
|
functional.visit(browser, '/bepasty')
|
|
return functional.eventually(browser.links.find_by_href,
|
|
['/bepasty/+list'], 5)
|
|
|
|
|
|
def _cannot_list_all(browser):
|
|
functional.visit(browser, '/bepasty/+list')
|
|
return functional.eventually(browser.is_text_present, ['Forbidden'], 5)
|