2018-11-30 08:40:18 +08:00
|
|
|
import os
|
2018-12-04 10:58:12 +08:00
|
|
|
import uuid
|
2023-05-01 10:28:11 +02:00
|
|
|
|
2021-02-17 10:14:58 +08:00
|
|
|
import pytest
|
2021-10-04 13:31:41 +02:00
|
|
|
import vorta.borg.borg_job
|
2023-04-17 15:47:01 +05:30
|
|
|
from PyQt6 import QtCore
|
|
|
|
from PyQt6.QtWidgets import QMessageBox
|
2021-01-18 01:52:07 -06:00
|
|
|
from vorta.keyring.abc import VortaKeyring
|
2022-03-24 06:27:07 +00:00
|
|
|
from vorta.store.models import ArchiveModel, EventLogModel, RepoModel
|
2018-10-31 01:46:37 +08:00
|
|
|
|
2021-01-18 01:52:07 -06:00
|
|
|
LONG_PASSWORD = 'long-password-long'
|
|
|
|
SHORT_PASSWORD = 'hunter2'
|
|
|
|
|
2018-11-05 18:30:59 +08:00
|
|
|
|
2020-03-03 13:19:36 +08:00
|
|
|
def test_repo_add_failures(qapp, qtbot, mocker, borg_json_output):
|
2018-10-31 01:46:37 +08:00
|
|
|
# Add new repo window
|
2020-03-03 13:19:36 +08:00
|
|
|
main = qapp.main_window
|
2022-03-24 06:27:07 +00:00
|
|
|
main.repoTab.new_repo()
|
2020-11-19 18:46:09 -06:00
|
|
|
add_repo_window = main.repoTab._window
|
2018-12-04 10:58:12 +08:00
|
|
|
qtbot.addWidget(add_repo_window)
|
|
|
|
|
2021-01-18 01:52:07 -06:00
|
|
|
qtbot.keyClicks(add_repo_window.passwordLineEdit, LONG_PASSWORD)
|
|
|
|
qtbot.keyClicks(add_repo_window.confirmLineEdit, LONG_PASSWORD)
|
2018-10-31 01:46:37 +08:00
|
|
|
qtbot.keyClicks(add_repo_window.repoURL, 'aaa')
|
2023-04-17 15:47:01 +05:30
|
|
|
qtbot.mouseClick(add_repo_window.saveButton, QtCore.Qt.MouseButton.LeftButton)
|
2018-11-17 19:36:44 +08:00
|
|
|
assert add_repo_window.errorText.text().startswith('Please enter a valid')
|
2018-10-31 01:46:37 +08:00
|
|
|
|
2021-01-18 01:52:07 -06:00
|
|
|
add_repo_window.passwordLineEdit.clear()
|
|
|
|
add_repo_window.confirmLineEdit.clear()
|
|
|
|
qtbot.keyClicks(add_repo_window.passwordLineEdit, SHORT_PASSWORD)
|
|
|
|
qtbot.keyClicks(add_repo_window.confirmLineEdit, SHORT_PASSWORD)
|
2018-10-31 01:46:37 +08:00
|
|
|
qtbot.keyClicks(add_repo_window.repoURL, 'bbb.com:repo')
|
2023-04-17 15:47:01 +05:30
|
|
|
qtbot.mouseClick(add_repo_window.saveButton, QtCore.Qt.MouseButton.LeftButton)
|
2021-01-18 01:52:07 -06:00
|
|
|
assert add_repo_window.passwordLabel.text() == 'Passwords must be greater than 8 characters long.'
|
|
|
|
|
|
|
|
add_repo_window.passwordLineEdit.clear()
|
|
|
|
add_repo_window.confirmLineEdit.clear()
|
|
|
|
qtbot.keyClicks(add_repo_window.passwordLineEdit, SHORT_PASSWORD + "1")
|
|
|
|
qtbot.keyClicks(add_repo_window.confirmLineEdit, SHORT_PASSWORD)
|
2023-04-17 15:47:01 +05:30
|
|
|
qtbot.mouseClick(add_repo_window.saveButton, QtCore.Qt.MouseButton.LeftButton)
|
2021-01-18 01:52:07 -06:00
|
|
|
assert add_repo_window.passwordLabel.text() == 'Passwords must be identical and greater than 8 characters long.'
|
|
|
|
|
|
|
|
add_repo_window.passwordLineEdit.clear()
|
|
|
|
add_repo_window.confirmLineEdit.clear()
|
|
|
|
qtbot.keyClicks(add_repo_window.passwordLineEdit, LONG_PASSWORD)
|
|
|
|
qtbot.keyClicks(add_repo_window.confirmLineEdit, SHORT_PASSWORD)
|
2023-04-17 15:47:01 +05:30
|
|
|
qtbot.mouseClick(add_repo_window.saveButton, QtCore.Qt.MouseButton.LeftButton)
|
2021-01-18 01:52:07 -06:00
|
|
|
assert add_repo_window.passwordLabel.text() == 'Passwords must be identical.'
|
2018-10-31 01:46:37 +08:00
|
|
|
|
2018-12-04 10:58:12 +08:00
|
|
|
|
2023-04-17 15:47:01 +05:30
|
|
|
def test_repo_unlink(qapp, qtbot, monkeypatch):
|
2020-03-03 13:19:36 +08:00
|
|
|
main = qapp.main_window
|
|
|
|
tab = main.repoTab
|
2023-04-17 15:47:01 +05:30
|
|
|
monkeypatch.setattr(QMessageBox, "show", lambda *args: True)
|
2020-03-03 13:19:36 +08:00
|
|
|
|
2022-11-03 10:22:11 +01:00
|
|
|
main.tabWidget.setCurrentIndex(0)
|
2023-04-17 15:47:01 +05:30
|
|
|
qtbot.mouseClick(tab.repoRemoveToolbutton, QtCore.Qt.MouseButton.LeftButton)
|
2022-10-13 11:12:20 +00:00
|
|
|
qtbot.waitUntil(lambda: tab.repoSelector.count() == 1, **pytest._wait_defaults)
|
2020-03-03 13:19:36 +08:00
|
|
|
assert RepoModel.select().count() == 0
|
|
|
|
|
2023-04-17 15:47:01 +05:30
|
|
|
qtbot.mouseClick(main.createStartBtn, QtCore.Qt.MouseButton.LeftButton)
|
2021-10-04 13:31:41 +02:00
|
|
|
# -1 is the repo id in this test
|
2023-03-22 16:46:46 +05:30
|
|
|
qtbot.waitUntil(lambda: 'Select a backup repository first.' in main.progressText.text(), **pytest._wait_defaults)
|
|
|
|
assert 'Select a backup repository first.' in main.progressText.text()
|
2020-03-03 13:19:36 +08:00
|
|
|
|
|
|
|
|
2021-01-18 01:52:07 -06:00
|
|
|
def test_password_autofill(qapp, qtbot):
|
|
|
|
main = qapp.main_window
|
2022-03-24 06:27:07 +00:00
|
|
|
main.repoTab.new_repo() # couldn't click menu
|
2021-01-18 01:52:07 -06:00
|
|
|
add_repo_window = main.repoTab._window
|
|
|
|
test_repo_url = f'vorta-test-repo.{uuid.uuid4()}.com:repo' # Random repo URL to avoid macOS keychain
|
2020-03-03 13:19:36 +08:00
|
|
|
|
2021-01-18 01:52:07 -06:00
|
|
|
keyring = VortaKeyring.get_keyring()
|
|
|
|
password = str(uuid.uuid4())
|
|
|
|
keyring.set_password('vorta-repo', test_repo_url, password)
|
|
|
|
|
|
|
|
qtbot.keyClicks(add_repo_window.repoURL, test_repo_url)
|
|
|
|
|
2022-08-15 19:02:40 +02:00
|
|
|
assert add_repo_window.passwordLineEdit.text() == password
|
2021-01-18 01:52:07 -06:00
|
|
|
|
|
|
|
|
|
|
|
def test_repo_add_success(qapp, qtbot, mocker, borg_json_output):
|
2018-12-04 10:58:12 +08:00
|
|
|
# Add new repo window
|
2020-03-03 13:19:36 +08:00
|
|
|
main = qapp.main_window
|
2022-03-24 06:27:07 +00:00
|
|
|
main.repoTab.new_repo() # couldn't click menu
|
2020-11-19 18:46:09 -06:00
|
|
|
add_repo_window = main.repoTab._window
|
2018-12-04 10:58:12 +08:00
|
|
|
test_repo_url = f'vorta-test-repo.{uuid.uuid4()}.com:repo' # Random repo URL to avoid macOS keychain
|
|
|
|
|
|
|
|
qtbot.keyClicks(add_repo_window.repoURL, test_repo_url)
|
2018-12-14 16:03:26 +08:00
|
|
|
qtbot.keyClicks(add_repo_window.passwordLineEdit, LONG_PASSWORD)
|
2021-01-18 01:52:07 -06:00
|
|
|
qtbot.keyClicks(add_repo_window.confirmLineEdit, LONG_PASSWORD)
|
2018-10-31 01:46:37 +08:00
|
|
|
|
2018-11-06 14:47:04 +08:00
|
|
|
stdout, stderr = borg_json_output('info')
|
2018-11-22 01:43:37 +01:00
|
|
|
popen_result = mocker.MagicMock(stdout=stdout, stderr=stderr, returncode=0)
|
2021-10-04 13:31:41 +02:00
|
|
|
mocker.patch.object(vorta.borg.borg_job, 'Popen', return_value=popen_result)
|
2018-10-31 01:46:37 +08:00
|
|
|
|
2021-02-18 01:01:32 -06:00
|
|
|
add_repo_window.run()
|
2022-08-15 19:02:40 +02:00
|
|
|
qtbot.waitUntil(
|
|
|
|
lambda: EventLogModel.select().where(EventLogModel.returncode == 0).count() == 2, **pytest._wait_defaults
|
|
|
|
)
|
2018-10-31 01:46:37 +08:00
|
|
|
|
2018-12-04 10:58:12 +08:00
|
|
|
assert RepoModel.get(id=2).url == test_repo_url
|
2018-11-03 16:55:38 +08:00
|
|
|
|
2021-01-18 01:52:07 -06:00
|
|
|
keyring = VortaKeyring.get_keyring()
|
2018-12-14 16:03:26 +08:00
|
|
|
assert keyring.get_password("vorta-repo", RepoModel.get(id=2).url) == LONG_PASSWORD
|
2020-11-19 18:46:09 -06:00
|
|
|
assert main.repoTab.repoSelector.currentText() == test_repo_url
|
|
|
|
|
2018-12-14 16:03:26 +08:00
|
|
|
|
2020-11-19 18:46:09 -06:00
|
|
|
def test_ssh_dialog(qapp, qtbot, tmpdir):
|
|
|
|
main = qapp.main_window
|
2023-04-17 15:47:01 +05:30
|
|
|
qtbot.mouseClick(main.repoTab.bAddSSHKey, QtCore.Qt.MouseButton.LeftButton)
|
2020-11-19 18:46:09 -06:00
|
|
|
ssh_dialog = main.repoTab._window
|
2018-11-22 01:43:37 +01:00
|
|
|
|
2018-11-30 08:40:18 +08:00
|
|
|
ssh_dir = tmpdir
|
|
|
|
key_tmpfile = ssh_dir.join("id_rsa-test")
|
|
|
|
pub_tmpfile = ssh_dir.join("id_rsa-test.pub")
|
|
|
|
key_tmpfile_full = os.path.join(key_tmpfile.dirname, key_tmpfile.basename)
|
|
|
|
ssh_dialog.outputFileTextBox.setText(key_tmpfile_full)
|
2021-02-18 09:44:10 +08:00
|
|
|
ssh_dialog.generate_key()
|
2018-11-30 08:40:18 +08:00
|
|
|
|
2021-12-24 14:26:21 +04:00
|
|
|
# Ensure new key files exist
|
|
|
|
qtbot.waitUntil(lambda: ssh_dialog.errors.text().startswith('New key was copied'), **pytest._wait_defaults)
|
|
|
|
assert len(ssh_dir.listdir()) == 2
|
2018-11-30 08:40:18 +08:00
|
|
|
|
2021-12-24 14:26:21 +04:00
|
|
|
# Ensure valid keys were created
|
2018-11-30 08:40:18 +08:00
|
|
|
key_tmpfile_content = key_tmpfile.read()
|
|
|
|
assert key_tmpfile_content.startswith('-----BEGIN OPENSSH PRIVATE KEY-----')
|
2021-12-24 14:26:21 +04:00
|
|
|
pub_tmpfile_content = pub_tmpfile.read()
|
2018-11-30 08:40:18 +08:00
|
|
|
assert pub_tmpfile_content.startswith('ssh-ed25519')
|
|
|
|
|
2021-02-18 09:44:10 +08:00
|
|
|
ssh_dialog.generate_key()
|
|
|
|
qtbot.waitUntil(lambda: ssh_dialog.errors.text().startswith('Key file already'), **pytest._wait_defaults)
|
2018-11-30 08:40:18 +08:00
|
|
|
|
|
|
|
|
2020-03-03 13:19:36 +08:00
|
|
|
def test_create(qapp, borg_json_output, mocker, qtbot):
|
|
|
|
main = qapp.main_window
|
2018-11-06 14:47:04 +08:00
|
|
|
stdout, stderr = borg_json_output('create')
|
2018-11-22 01:43:37 +01:00
|
|
|
popen_result = mocker.MagicMock(stdout=stdout, stderr=stderr, returncode=0)
|
2021-10-04 13:31:41 +02:00
|
|
|
mocker.patch.object(vorta.borg.borg_job, 'Popen', return_value=popen_result)
|
2018-11-06 14:47:04 +08:00
|
|
|
|
2023-04-17 15:47:01 +05:30
|
|
|
qtbot.mouseClick(main.createStartBtn, QtCore.Qt.MouseButton.LeftButton)
|
2023-03-22 16:46:46 +05:30
|
|
|
qtbot.waitUntil(lambda: 'Backup finished.' in main.progressText.text(), **pytest._wait_defaults)
|
2021-02-17 10:14:58 +08:00
|
|
|
qtbot.waitUntil(lambda: main.createStartBtn.isEnabled(), **pytest._wait_defaults)
|
2018-11-06 14:47:04 +08:00
|
|
|
assert EventLogModel.select().count() == 1
|
2020-03-23 07:20:09 +01:00
|
|
|
assert ArchiveModel.select().count() == 3
|
2018-11-06 14:47:04 +08:00
|
|
|
assert RepoModel.get(id=1).unique_size == 15520474
|
|
|
|
assert main.createStartBtn.isEnabled()
|
2020-03-23 07:20:09 +01:00
|
|
|
assert main.archiveTab.archiveTable.rowCount() == 3
|
2018-11-06 14:47:04 +08:00
|
|
|
assert main.scheduleTab.logTableWidget.rowCount() == 1
|