mirror of
https://github.com/onionshare/onionshare.git
synced 2025-01-28 15:27:11 -05:00
Fix a minor corner case related to server status button when canceling a scheduled share. Leverage scheduled shares in order to test 'cancel' action in local mode for better test coverage
This commit is contained in:
parent
00a8b88264
commit
dc0fe4f7b1
@ -115,9 +115,9 @@ class StartupTimer(QtCore.QThread):
|
|||||||
now = QtCore.QDateTime.currentDateTime()
|
now = QtCore.QDateTime.currentDateTime()
|
||||||
scheduled_start = now.secsTo(self.mode.server_status.scheduled_start)
|
scheduled_start = now.secsTo(self.mode.server_status.scheduled_start)
|
||||||
# Timer has now finished
|
# Timer has now finished
|
||||||
|
if self.canceled == False:
|
||||||
self.mode.server_status.server_button.setText(strings._('gui_please_wait'))
|
self.mode.server_status.server_button.setText(strings._('gui_please_wait'))
|
||||||
self.mode.server_status_label.setText(strings._('gui_status_indicator_share_working'))
|
self.mode.server_status_label.setText(strings._('gui_status_indicator_share_working'))
|
||||||
if self.canceled == False:
|
|
||||||
self.success.emit()
|
self.success.emit()
|
||||||
except ValueError as e:
|
except ValueError as e:
|
||||||
self.error.emit(e.args[0])
|
self.error.emit(e.args[0])
|
||||||
|
@ -325,6 +325,20 @@ class GuiBaseTest(object):
|
|||||||
# We should have started now
|
# We should have started now
|
||||||
self.assertEqual(mode.server_status.status, 2)
|
self.assertEqual(mode.server_status.status, 2)
|
||||||
|
|
||||||
|
def cancel_the_share(self, mode):
|
||||||
|
'''Test that we can cancel a share before it's started up '''
|
||||||
|
self.server_working_on_start_button_pressed(mode)
|
||||||
|
self.server_status_indicator_says_scheduled(mode)
|
||||||
|
self.add_delete_buttons_hidden()
|
||||||
|
self.settings_button_is_hidden()
|
||||||
|
self.set_startup_timer(mode, 10)
|
||||||
|
QtTest.QTest.mousePress(mode.server_status.server_button, QtCore.Qt.LeftButton)
|
||||||
|
QtTest.QTest.qWait(2000)
|
||||||
|
QtTest.QTest.mouseRelease(mode.server_status.server_button, QtCore.Qt.LeftButton)
|
||||||
|
self.assertEqual(mode.server_status.status, 0)
|
||||||
|
self.server_is_stopped(mode, False)
|
||||||
|
self.web_server_is_stopped()
|
||||||
|
|
||||||
# Hack to close an Alert dialog that would otherwise block tests
|
# Hack to close an Alert dialog that would otherwise block tests
|
||||||
def accept_dialog(self):
|
def accept_dialog(self):
|
||||||
window = self.gui.qtapp.activeWindow()
|
window = self.gui.qtapp.activeWindow()
|
||||||
|
@ -140,19 +140,6 @@ class TorGuiBaseTest(GuiBaseTest):
|
|||||||
else:
|
else:
|
||||||
self.assertEqual(clipboard.text(), 'http://{}/{}'.format(self.gui.app.onion_host, mode.server_status.web.slug))
|
self.assertEqual(clipboard.text(), 'http://{}/{}'.format(self.gui.app.onion_host, mode.server_status.web.slug))
|
||||||
|
|
||||||
def cancel_the_share(self, mode):
|
|
||||||
'''Test that we can cancel this share before it's started up '''
|
|
||||||
self.server_working_on_start_button_pressed(self.gui.share_mode)
|
|
||||||
self.server_status_indicator_says_starting(self.gui.share_mode)
|
|
||||||
self.add_delete_buttons_hidden()
|
|
||||||
self.settings_button_is_hidden()
|
|
||||||
QtTest.QTest.mousePress(mode.server_status.server_button, QtCore.Qt.LeftButton)
|
|
||||||
QtTest.QTest.qWait(1000)
|
|
||||||
QtTest.QTest.mouseRelease(mode.server_status.server_button, QtCore.Qt.LeftButton)
|
|
||||||
self.assertEqual(mode.server_status.status, 0)
|
|
||||||
self.server_is_stopped(self.gui.share_mode, False)
|
|
||||||
self.web_server_is_stopped()
|
|
||||||
|
|
||||||
|
|
||||||
# Stealth tests
|
# Stealth tests
|
||||||
def copy_have_hidserv_auth_button(self, mode):
|
def copy_have_hidserv_auth_button(self, mode):
|
||||||
|
26
tests/local_onionshare_share_mode_cancel_share_test.py
Normal file
26
tests/local_onionshare_share_mode_cancel_share_test.py
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
import pytest
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
from .GuiShareTest import GuiShareTest
|
||||||
|
|
||||||
|
class LocalShareModeCancelTest(unittest.TestCase, GuiShareTest):
|
||||||
|
@classmethod
|
||||||
|
def setUpClass(cls):
|
||||||
|
test_settings = {
|
||||||
|
"startup_timer": True,
|
||||||
|
}
|
||||||
|
cls.gui = GuiShareTest.set_up(test_settings)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def tearDownClass(cls):
|
||||||
|
GuiShareTest.tear_down()
|
||||||
|
|
||||||
|
@pytest.mark.gui
|
||||||
|
def test_gui(self):
|
||||||
|
self.run_all_common_setup_tests()
|
||||||
|
self.run_all_share_mode_setup_tests()
|
||||||
|
self.cancel_the_share(self.gui.share_mode)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
unittest.main()
|
@ -8,6 +8,7 @@ class ShareModeCancelTest(unittest.TestCase, TorGuiShareTest):
|
|||||||
@classmethod
|
@classmethod
|
||||||
def setUpClass(cls):
|
def setUpClass(cls):
|
||||||
test_settings = {
|
test_settings = {
|
||||||
|
"startup_timer": True,
|
||||||
}
|
}
|
||||||
cls.gui = TorGuiShareTest.set_up(test_settings)
|
cls.gui = TorGuiShareTest.set_up(test_settings)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user