2018-10-30 17:46:37 +00:00
|
|
|
|
|
|
|
import pytest
|
|
|
|
import io
|
|
|
|
import peewee
|
|
|
|
from PyQt5 import QtCore
|
2018-10-31 11:14:12 +00:00
|
|
|
from PyQt5.QtWidgets import QMenu, QApplication, QSystemTrayIcon
|
2018-10-30 17:46:37 +00:00
|
|
|
|
|
|
|
import vorta.borg_runner
|
|
|
|
import vorta.models
|
2018-10-31 11:14:12 +00:00
|
|
|
from vorta.application import VortaApp
|
2018-10-30 17:46:37 +00:00
|
|
|
from vorta.views.repo_add import AddRepoWindow
|
2018-10-31 11:14:12 +00:00
|
|
|
from vorta.models import EventLogModel, RepoModel
|
2018-10-30 17:46:37 +00:00
|
|
|
from vorta.tray_menu import TrayMenu
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture()
|
2018-10-31 11:14:12 +00:00
|
|
|
def app(tmpdir):
|
2018-10-30 17:46:37 +00:00
|
|
|
tmp_db = tmpdir.join('settings.sqlite')
|
|
|
|
mock_db = peewee.SqliteDatabase(str(tmp_db))
|
|
|
|
vorta.models.init_db(mock_db)
|
2018-10-31 11:14:12 +00:00
|
|
|
return VortaApp([])
|
2018-10-30 17:46:37 +00:00
|
|
|
|
|
|
|
|
2018-10-31 11:14:12 +00:00
|
|
|
@pytest.fixture()
|
|
|
|
def main(app, qtbot):
|
|
|
|
main = app.main_window
|
2018-10-30 17:46:37 +00:00
|
|
|
qtbot.addWidget(main)
|
|
|
|
return main
|
|
|
|
|
2018-10-31 11:14:12 +00:00
|
|
|
# def test_tray(app, qtbot):
|
|
|
|
# # app.tray.activated.emit(QSystemTrayIcon.Context)
|
|
|
|
# menu = app.tray.contextMenu()
|
|
|
|
# qtbot.addWidget(menu)
|
|
|
|
# menu.popup(QtCore.QPoint())
|
2018-10-30 17:46:37 +00:00
|
|
|
|
|
|
|
|
2018-10-31 11:14:12 +00:00
|
|
|
def test_repo_tab(main, qtbot):
|
2018-10-30 17:46:37 +00:00
|
|
|
qtbot.mouseClick(main.createStartBtn, QtCore.Qt.LeftButton)
|
2018-10-31 11:14:12 +00:00
|
|
|
assert main.createProgressText.text() == 'Add a remote backup repository first.'
|
2018-10-30 17:46:37 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_repo_add(main, qtbot, mocker):
|
|
|
|
# Add new repo window
|
|
|
|
add_repo_window = AddRepoWindow(main)
|
|
|
|
qtbot.addWidget(add_repo_window)
|
|
|
|
add_repo_window.show()
|
|
|
|
qtbot.keyClicks(add_repo_window.repoURL, 'aaa')
|
|
|
|
qtbot.mouseClick(add_repo_window.saveButton, QtCore.Qt.LeftButton)
|
|
|
|
assert add_repo_window.errorText.text() == 'Please enter a valid repo URL including hostname and path.'
|
|
|
|
|
|
|
|
qtbot.keyClicks(add_repo_window.repoURL, 'bbb.com:repo')
|
|
|
|
qtbot.mouseClick(add_repo_window.saveButton, QtCore.Qt.LeftButton)
|
|
|
|
assert add_repo_window.errorText.text() == 'Please use a longer password.'
|
|
|
|
|
|
|
|
qtbot.keyClicks(add_repo_window.passwordLineEdit, 'long-password-long')
|
|
|
|
|
|
|
|
popen_result =mocker.MagicMock(stdout=io.StringIO("some initial binary data"),
|
|
|
|
stderr=io.StringIO("some initial binary data"),
|
|
|
|
returncode=0)
|
|
|
|
mocker.patch.object(vorta.borg_runner, 'Popen', return_value=popen_result)
|
|
|
|
|
|
|
|
qtbot.mouseClick(add_repo_window.saveButton, QtCore.Qt.LeftButton)
|
|
|
|
|
|
|
|
with qtbot.waitSignal(add_repo_window.thread.result, timeout=1000) as blocker:
|
|
|
|
pass
|
|
|
|
|
|
|
|
main.repoTab.process_new_repo(blocker.args[0])
|
|
|
|
|
|
|
|
assert EventLogModel.select().count() == 1
|
|
|
|
assert RepoModel.get(id=1).url == 'aaabbb.com:repo'
|