mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-04-22 05:39:37 +08:00
142 lines
5.1 KiB
Python
142 lines
5.1 KiB
Python
# Copyright (c) 2022 Ultimaker B.V.
|
|
# Cura is released under the terms of the LGPLv3 or higher.
|
|
|
|
from unittest.mock import MagicMock, patch
|
|
|
|
import pytest
|
|
|
|
from cura.API import Account
|
|
from cura.API.Account import SyncState
|
|
from cura.OAuth2.Models import UserProfile
|
|
|
|
|
|
@pytest.fixture()
|
|
def user_profile():
|
|
result = UserProfile()
|
|
result.username = "username!"
|
|
result.profile_image_url = "profile_image_url!"
|
|
result.user_id = "user_id!"
|
|
return result
|
|
|
|
|
|
def test_login():
|
|
account = Account(MagicMock())
|
|
mocked_auth_service = MagicMock()
|
|
account._authorization_service = mocked_auth_service
|
|
account.logout = MagicMock()
|
|
|
|
account.login()
|
|
mocked_auth_service.startAuthorizationFlow.assert_called_once_with(False)
|
|
|
|
# Fake a successful login
|
|
with patch("UM.TaskManagement.HttpRequestManager.HttpRequestManager.getInstance"): # Don't want triggers for account information to actually make HTTP requests.
|
|
account._onLoginStateChanged(True)
|
|
|
|
# Attempting to log in again shouldn't change anything.
|
|
account.login()
|
|
mocked_auth_service.startAuthorizationFlow.assert_called_once_with(False)
|
|
|
|
# Attempting to log in with force_logout_before_login as True should call the logout before calling the
|
|
# startAuthorizationFlow(True).
|
|
account.login(force_logout_before_login=True)
|
|
account.logout.assert_called_once_with()
|
|
mocked_auth_service.startAuthorizationFlow.assert_called_with(True)
|
|
assert mocked_auth_service.startAuthorizationFlow.call_count == 2
|
|
|
|
|
|
def test_initialize():
|
|
account = Account(MagicMock())
|
|
mocked_auth_service = MagicMock()
|
|
account._authorization_service = mocked_auth_service
|
|
|
|
account.initialize()
|
|
mocked_auth_service.loadAuthDataFromPreferences.assert_called_once_with()
|
|
|
|
|
|
def test_logout():
|
|
account = Account(MagicMock())
|
|
mocked_auth_service = MagicMock()
|
|
account._authorization_service = mocked_auth_service
|
|
|
|
account.logout()
|
|
mocked_auth_service.deleteAuthData.assert_not_called() # We weren't logged in, so nothing should happen
|
|
assert not account.isLoggedIn
|
|
|
|
# Pretend the stage changed
|
|
with patch("UM.TaskManagement.HttpRequestManager.HttpRequestManager.getInstance"): # Don't want triggers for account information to actually make HTTP requests.
|
|
account._onLoginStateChanged(True)
|
|
assert account.isLoggedIn
|
|
|
|
account.logout()
|
|
mocked_auth_service.deleteAuthData.assert_called_once_with()
|
|
|
|
@patch("UM.Application.Application.getInstance")
|
|
def test_errorLoginState(application):
|
|
account = Account(MagicMock())
|
|
mocked_auth_service = MagicMock()
|
|
account._authorization_service = mocked_auth_service
|
|
account.loginStateChanged = MagicMock()
|
|
|
|
with patch("UM.TaskManagement.HttpRequestManager.HttpRequestManager.getInstance"): # Don't want triggers for account information to actually make HTTP requests.
|
|
account._onLoginStateChanged(True, "BLARG!")
|
|
# Even though we said that the login worked, it had an error message, so the login failed.
|
|
account.loginStateChanged.emit.assert_called_with(False)
|
|
|
|
with patch("UM.TaskManagement.HttpRequestManager.HttpRequestManager.getInstance"):
|
|
account._onLoginStateChanged(True)
|
|
account._onLoginStateChanged(False, "OMGZOMG!")
|
|
account.loginStateChanged.emit.assert_called_with(False)
|
|
|
|
def test_sync_success():
|
|
account = Account(MagicMock())
|
|
|
|
service1 = "test_service1"
|
|
service2 = "test_service2"
|
|
|
|
with patch("UM.TaskManagement.HttpRequestManager.HttpRequestManager.getInstance"): # Don't want triggers for account information to actually make HTTP requests.
|
|
account.setSyncState(service1, SyncState.SYNCING)
|
|
assert account.syncState == SyncState.SYNCING
|
|
|
|
account.setSyncState(service2, SyncState.SYNCING)
|
|
assert account.syncState == SyncState.SYNCING
|
|
|
|
account.setSyncState(service1, SyncState.SUCCESS)
|
|
# service2 still syncing
|
|
assert account.syncState == SyncState.SYNCING
|
|
|
|
account.setSyncState(service2, SyncState.SUCCESS)
|
|
assert account.syncState == SyncState.SUCCESS
|
|
|
|
|
|
def test_sync_update_action():
|
|
account = Account(MagicMock())
|
|
|
|
service1 = "test_service1"
|
|
|
|
mockUpdateCallback = MagicMock()
|
|
|
|
with patch("UM.TaskManagement.HttpRequestManager.HttpRequestManager.getInstance"): # Don't want triggers for account information to actually make HTTP requests.
|
|
account.setSyncState(service1, SyncState.SYNCING)
|
|
assert account.syncState == SyncState.SYNCING
|
|
|
|
account.setUpdatePackagesAction(mockUpdateCallback)
|
|
account.onUpdatePackagesClicked()
|
|
mockUpdateCallback.assert_called_once_with()
|
|
account.setSyncState(service1, SyncState.SUCCESS)
|
|
|
|
account.sync() # starting a new sync resets the update action to None
|
|
|
|
account.setSyncState(service1, SyncState.SYNCING)
|
|
assert account.syncState == SyncState.SYNCING
|
|
|
|
account.onUpdatePackagesClicked() # Should not be connected to an action anymore
|
|
mockUpdateCallback.assert_called_once_with() # No additional calls
|
|
assert account.updatePackagesEnabled is False
|
|
account.setSyncState(service1, SyncState.SUCCESS)
|
|
|
|
|
|
|
|
|
|
|
|
|