2017-09-26 20:34:08 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
2019-04-13 13:00:22 +00:00
|
|
|
##########################################################################
|
|
|
|
# OpenLP - Open Source Lyrics Projection #
|
|
|
|
# ---------------------------------------------------------------------- #
|
2022-02-06 09:10:17 +00:00
|
|
|
# Copyright (c) 2008-2022 OpenLP Developers #
|
2019-04-13 13:00:22 +00:00
|
|
|
# ---------------------------------------------------------------------- #
|
|
|
|
# This program is free software: you can redistribute it and/or modify #
|
|
|
|
# it under the terms of the GNU General Public License as published by #
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or #
|
|
|
|
# (at your option) any later version. #
|
|
|
|
# #
|
|
|
|
# This program is distributed in the hope that it will be useful, #
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
|
|
|
|
# GNU General Public License for more details. #
|
|
|
|
# #
|
|
|
|
# You should have received a copy of the GNU General Public License #
|
|
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>. #
|
|
|
|
##########################################################################
|
2020-02-27 22:23:40 +00:00
|
|
|
import json
|
2019-05-22 06:47:00 +00:00
|
|
|
from pathlib import Path
|
2018-01-12 23:45:06 +00:00
|
|
|
from unittest.mock import MagicMock, patch
|
2017-09-26 20:34:08 +00:00
|
|
|
|
2022-02-18 16:24:21 +00:00
|
|
|
from openlp.core.api.deploy import REMOTE_URL, deploy_zipfile, download_version_info, download_and_install, \
|
|
|
|
get_installed_version
|
2017-09-26 20:34:08 +00:00
|
|
|
|
2018-10-02 04:39:42 +00:00
|
|
|
|
2020-02-27 22:23:40 +00:00
|
|
|
CONFIG_FILE = '{"latest": {"version": "0.1", "filename": "remote-0.1.zip", "sha256": "", "size": 854039}}'
|
|
|
|
CONFIG_DICT = json.loads(CONFIG_FILE)
|
2017-09-26 20:34:08 +00:00
|
|
|
|
|
|
|
|
2020-02-27 22:23:40 +00:00
|
|
|
@patch('openlp.core.api.deploy.ZipFile')
|
|
|
|
def test_deploy_zipfile(MockZipFile):
|
2017-09-26 20:34:08 +00:00
|
|
|
"""
|
2020-02-27 22:23:40 +00:00
|
|
|
Remote Deploy tests - test the dummy zip file is processed correctly
|
2017-09-26 20:34:08 +00:00
|
|
|
"""
|
2020-02-27 22:23:40 +00:00
|
|
|
# GIVEN: A new downloaded zip file
|
|
|
|
mocked_zipfile = MagicMock()
|
|
|
|
MockZipFile.return_value = mocked_zipfile
|
|
|
|
root_path = Path('/') / 'tmp' / 'remotes'
|
2017-09-26 20:34:08 +00:00
|
|
|
|
2020-02-27 22:23:40 +00:00
|
|
|
# WHEN: deploy_zipfile() is called
|
|
|
|
deploy_zipfile(root_path, 'site.zip')
|
|
|
|
|
|
|
|
# THEN: the zip file should have been extracted to the right location
|
|
|
|
MockZipFile.assert_called_once_with(Path('/tmp/remotes/site.zip'))
|
|
|
|
mocked_zipfile.extractall.assert_called_once_with(Path('/tmp/remotes'))
|
|
|
|
|
|
|
|
|
|
|
|
@patch('openlp.core.api.deploy.get_openlp_user_agent')
|
|
|
|
@patch('openlp.core.api.deploy.get_web_page')
|
|
|
|
def test_download_version_info_connection_error(mocked_get_web_page, mocked_get_openlp_user_agent):
|
|
|
|
"""
|
|
|
|
Test that if a ConnectionError occurs while downloading a sha256 False is returned
|
|
|
|
"""
|
|
|
|
# GIVEN: A bunch of mocks
|
|
|
|
mocked_get_web_page.side_effect = ConnectionError()
|
|
|
|
mocked_get_openlp_user_agent.return_value = 'OpenLP'
|
|
|
|
|
|
|
|
# WHEN: download_sha256() is called
|
|
|
|
result = download_version_info()
|
|
|
|
|
|
|
|
# THEN: The result should be False
|
|
|
|
assert result is False, 'download_version_info() should return False when encountering ConnectionError'
|
|
|
|
|
|
|
|
|
|
|
|
@patch('openlp.core.api.deploy.get_openlp_user_agent')
|
|
|
|
@patch('openlp.core.api.deploy.get_web_page')
|
|
|
|
def test_download_version_info_empty_file(mocked_get_web_page, mocked_get_openlp_user_agent):
|
|
|
|
"""
|
|
|
|
Test that if there's no config when downloading a sha256 None is returned
|
|
|
|
"""
|
|
|
|
# GIVEN: A bunch of mocks
|
|
|
|
mocked_get_web_page.return_value = None
|
|
|
|
mocked_get_openlp_user_agent.return_value = 'OpenLP'
|
|
|
|
|
|
|
|
# WHEN: download_sha256() is called
|
|
|
|
result = download_version_info()
|
|
|
|
|
|
|
|
# THEN: The result should be Nonw
|
|
|
|
assert result is None, 'download_version_info() should return None when there is a problem downloading the page'
|
|
|
|
|
|
|
|
|
|
|
|
@patch('openlp.core.api.deploy.get_openlp_user_agent')
|
|
|
|
@patch('openlp.core.api.deploy.get_web_page')
|
|
|
|
def test_download_version_info(mocked_get_web_page, mocked_get_openlp_user_agent):
|
|
|
|
"""
|
|
|
|
Test that the sha256 and the version are returned
|
|
|
|
"""
|
|
|
|
# GIVEN: A bunch of mocks
|
|
|
|
mocked_get_web_page.return_value = CONFIG_FILE
|
|
|
|
mocked_get_openlp_user_agent.return_value = 'OpenLP'
|
|
|
|
|
|
|
|
# WHEN: download_sha256() is called
|
|
|
|
result = download_version_info()
|
|
|
|
|
|
|
|
# THEN: The result should be Nonw
|
|
|
|
assert result == CONFIG_DICT, 'download_version_info() should return a dictionary of version information'
|
|
|
|
|
|
|
|
|
|
|
|
@patch('openlp.core.api.deploy.log.warning')
|
|
|
|
@patch('openlp.core.api.deploy.download_version_info')
|
2022-02-18 16:24:21 +00:00
|
|
|
def test_download_and_install_log_warning(mocked_download_version_info, mocked_warning):
|
2020-02-27 22:23:40 +00:00
|
|
|
"""
|
|
|
|
Test that when the version info fails, a warning is logged
|
|
|
|
"""
|
|
|
|
# GIVEN: A few mocks, and a version info of None
|
|
|
|
mocked_download_version_info.return_value = None
|
|
|
|
|
2022-02-18 16:24:21 +00:00
|
|
|
# WHEN: download_and_install is run
|
|
|
|
result = download_and_install(None)
|
2020-02-27 22:23:40 +00:00
|
|
|
|
|
|
|
# THEN: None is returned and a warning is logged
|
|
|
|
assert result is None, 'The result should be None'
|
|
|
|
mocked_warning.assert_called_once_with('Unable to access the version information, abandoning download')
|
|
|
|
|
|
|
|
|
|
|
|
@patch('openlp.core.api.deploy.AppLocation.get_section_data_path')
|
|
|
|
@patch('openlp.core.api.deploy.download_file')
|
|
|
|
@patch('openlp.core.api.deploy.download_version_info')
|
2022-02-18 16:24:21 +00:00
|
|
|
def test_download_and_install_download_fails(mocked_download_version_info, mocked_download_file,
|
|
|
|
mocked_get_section_data_path):
|
2020-02-27 22:23:40 +00:00
|
|
|
"""
|
|
|
|
Test that when the version info fails, a warning is logged
|
|
|
|
"""
|
|
|
|
# GIVEN: A few mocks
|
|
|
|
mocked_callback = MagicMock()
|
|
|
|
mocked_download_version_info.return_value = CONFIG_DICT
|
|
|
|
mocked_download_file.return_value = False
|
|
|
|
mocked_get_section_data_path.return_value = Path('.')
|
|
|
|
|
2022-02-18 16:24:21 +00:00
|
|
|
# WHEN: download_and_install is run
|
|
|
|
result = download_and_install(mocked_callback)
|
2020-02-27 22:23:40 +00:00
|
|
|
|
|
|
|
# THEN: None is returned and a warning is logged
|
|
|
|
assert result is None, 'The result should be None'
|
|
|
|
|
|
|
|
|
|
|
|
@patch('openlp.core.api.deploy.AppLocation.get_section_data_path')
|
|
|
|
@patch('openlp.core.api.deploy.deploy_zipfile')
|
|
|
|
@patch('openlp.core.api.deploy.download_file')
|
|
|
|
@patch('openlp.core.api.deploy.download_version_info')
|
2022-02-18 16:24:21 +00:00
|
|
|
def test_download_and_install(mocked_download_version_info, mocked_download_file, mocked_deploy_zipfile,
|
|
|
|
mocked_get_section_data_path):
|
2020-02-27 22:23:40 +00:00
|
|
|
# GIVEN: A bunch of mocks
|
|
|
|
mocked_callback = MagicMock()
|
|
|
|
mocked_download_version_info.return_value = CONFIG_DICT
|
|
|
|
mocked_download_file.return_value = True
|
|
|
|
mocked_remote_path = Path('/') / 'tmp' / 'remotes'
|
|
|
|
mocked_remote_zip = mocked_remote_path / 'remote.zip'
|
|
|
|
mocked_get_section_data_path.return_value = mocked_remote_path
|
|
|
|
|
2022-02-18 16:24:21 +00:00
|
|
|
# WHEN: download_and_install() is called
|
|
|
|
result = download_and_install(mocked_callback)
|
2020-02-27 22:23:40 +00:00
|
|
|
|
|
|
|
# THEN: The correct things should have been done
|
|
|
|
assert result == CONFIG_DICT['latest']['version'], 'The correct version is returned'
|
|
|
|
mocked_download_file.assert_called_once_with(mocked_callback, REMOTE_URL + '0.1/remote-0.1.zip', mocked_remote_zip)
|
|
|
|
mocked_deploy_zipfile.assert_called_once_with(mocked_remote_path, 'remote.zip')
|
2022-02-18 16:24:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
@patch('openlp.core.api.deploy.AppLocation.get_section_data_path')
|
|
|
|
def test_get_installed_version_not_installed(mocked_get_section_data_path):
|
|
|
|
"""Test that if there is no remote installed, None is returned"""
|
|
|
|
# GIVEN: A mocked AppLocation and no file installed
|
|
|
|
mocked_version_file = MagicMock()
|
|
|
|
mocked_version_file.__truediv__.return_value = mocked_version_file
|
|
|
|
mocked_version_file.exists.return_value = False
|
|
|
|
mocked_get_section_data_path.return_value = mocked_version_file
|
|
|
|
|
|
|
|
# WHEN: get_installed_version() is called but there is no version file
|
|
|
|
result = get_installed_version()
|
|
|
|
|
|
|
|
# THEN: The result should be None
|
|
|
|
assert result is None
|
|
|
|
|
|
|
|
|
|
|
|
@patch('openlp.core.api.deploy.AppLocation.get_section_data_path')
|
|
|
|
def test_get_installed_version_no_version(mocked_get_section_data_path):
|
|
|
|
"""Test that if there is no matching version number, None is returned"""
|
|
|
|
# GIVEN: A mocked AppLocation and no file installed
|
|
|
|
mocked_version_file = MagicMock()
|
|
|
|
mocked_version_file.__truediv__.return_value = mocked_version_file
|
|
|
|
mocked_version_file.exists.return_value = True
|
|
|
|
mocked_version_file.read.return_value = 'let app_version = 0.9.7;'
|
|
|
|
mocked_get_section_data_path.return_value = mocked_version_file
|
|
|
|
|
|
|
|
# WHEN: get_installed_version() is called but there is no version in the file
|
|
|
|
result = get_installed_version()
|
|
|
|
|
|
|
|
# THEN: The result should be None
|
|
|
|
assert result is None
|
|
|
|
|
|
|
|
|
|
|
|
@patch('openlp.core.api.deploy.AppLocation.get_section_data_path')
|
|
|
|
def test_get_installed_version(mocked_get_section_data_path):
|
|
|
|
"""Test that get_installed_version returns the version number"""
|
|
|
|
# GIVEN: A mocked AppLocation and no file installed
|
|
|
|
mocked_version_file = MagicMock()
|
|
|
|
mocked_version_file.__truediv__.return_value = mocked_version_file
|
|
|
|
mocked_version_file.exists.return_value = True
|
|
|
|
mocked_version_file.read.return_value = 'let appVersion = \'0.9.7\';'
|
|
|
|
mocked_get_section_data_path.return_value = mocked_version_file
|
|
|
|
|
|
|
|
# WHEN: get_installed_version() is called but there is no version file
|
|
|
|
result = get_installed_version()
|
|
|
|
|
|
|
|
# THEN: The result should be None
|
|
|
|
assert result == '0.9.7'
|