2018-10-11 20:28:47 -04:00
|
|
|
import json
|
2018-09-23 20:41:48 -04:00
|
|
|
import os
|
|
|
|
import requests
|
2018-10-11 20:28:47 -04:00
|
|
|
import shutil
|
2018-09-23 20:41:48 -04:00
|
|
|
import socket
|
|
|
|
import socks
|
|
|
|
|
|
|
|
from PyQt5 import QtCore, QtTest
|
2018-09-30 21:19:25 -04:00
|
|
|
|
2018-09-23 20:41:48 -04:00
|
|
|
from onionshare import strings
|
2018-09-30 21:19:25 -04:00
|
|
|
from onionshare.common import Common
|
|
|
|
from onionshare.settings import Settings
|
|
|
|
from onionshare.onion import Onion
|
|
|
|
from onionshare.web import Web
|
|
|
|
from onionshare_gui import Application, OnionShare, OnionShareGui
|
2018-10-10 21:45:55 -04:00
|
|
|
from onionshare_gui.mode.share_mode import ShareMode
|
|
|
|
from onionshare_gui.mode.receive_mode import ReceiveMode
|
2018-09-30 21:19:25 -04:00
|
|
|
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2018-10-11 00:09:27 -04:00
|
|
|
class GuiBaseTest(object):
|
2018-09-30 21:19:25 -04:00
|
|
|
@staticmethod
|
2018-10-17 01:31:51 -04:00
|
|
|
def set_up(test_settings):
|
2018-09-30 21:19:25 -04:00
|
|
|
'''Create GUI with given settings'''
|
|
|
|
# Create our test file
|
|
|
|
testfile = open('/tmp/test.txt', 'w')
|
|
|
|
testfile.write('onionshare')
|
|
|
|
testfile.close()
|
|
|
|
|
2018-10-15 22:01:44 -04:00
|
|
|
# Create a test dir and files
|
|
|
|
if not os.path.exists('/tmp/testdir'):
|
|
|
|
testdir = os.mkdir('/tmp/testdir')
|
2018-10-17 00:21:04 -04:00
|
|
|
testfile = open('/tmp/testdir/test', 'w')
|
2018-10-15 22:01:44 -04:00
|
|
|
testfile.write('onionshare')
|
|
|
|
testfile.close()
|
|
|
|
|
2018-09-30 21:19:25 -04:00
|
|
|
common = Common()
|
|
|
|
common.settings = Settings(common)
|
|
|
|
common.define_css()
|
|
|
|
strings.load_strings(common)
|
|
|
|
|
|
|
|
# Get all of the settings in test_settings
|
2019-01-20 15:01:51 -05:00
|
|
|
test_settings['data_dir'] = '/tmp/OnionShare'
|
2018-09-30 21:19:25 -04:00
|
|
|
for key, val in common.settings.default_settings.items():
|
|
|
|
if key not in test_settings:
|
|
|
|
test_settings[key] = val
|
|
|
|
|
|
|
|
# Start the Onion
|
|
|
|
testonion = Onion(common)
|
|
|
|
global qtapp
|
|
|
|
qtapp = Application(common)
|
|
|
|
app = OnionShare(common, testonion, True, 0)
|
|
|
|
|
|
|
|
web = Web(common, False, True)
|
2018-10-17 01:31:51 -04:00
|
|
|
open('/tmp/settings.json', 'w').write(json.dumps(test_settings))
|
2018-09-30 21:19:25 -04:00
|
|
|
|
2018-10-17 01:31:51 -04:00
|
|
|
gui = OnionShareGui(common, testonion, qtapp, app, ['/tmp/test.txt', '/tmp/testdir'], '/tmp/settings.json', True)
|
2018-09-30 21:19:25 -04:00
|
|
|
return gui
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def tear_down():
|
2018-10-15 22:01:44 -04:00
|
|
|
'''Clean up after tests'''
|
2018-09-30 21:19:25 -04:00
|
|
|
try:
|
|
|
|
os.remove('/tmp/test.txt')
|
2018-10-17 01:31:51 -04:00
|
|
|
os.remove('/tmp/settings.json')
|
2018-10-17 02:23:25 -04:00
|
|
|
os.remove('/tmp/large_file')
|
2018-10-17 02:29:44 -04:00
|
|
|
os.remove('/tmp/download.zip')
|
|
|
|
os.remove('/tmp/webpage')
|
2018-10-15 22:01:44 -04:00
|
|
|
shutil.rmtree('/tmp/testdir')
|
2018-10-17 02:29:44 -04:00
|
|
|
shutil.rmtree('/tmp/OnionShare')
|
2018-09-30 21:19:25 -04:00
|
|
|
except:
|
|
|
|
pass
|
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def gui_loaded(self):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the GUI actually is shown'''
|
|
|
|
self.assertTrue(self.gui.show)
|
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def windowTitle_seen(self):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the window title is OnionShare'''
|
|
|
|
self.assertEqual(self.gui.windowTitle(), 'OnionShare')
|
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def settings_button_is_visible(self):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the settings button is visible'''
|
|
|
|
self.assertTrue(self.gui.settings_button.isVisible())
|
|
|
|
|
2018-10-15 22:01:44 -04:00
|
|
|
|
|
|
|
def settings_button_is_hidden(self):
|
|
|
|
'''Test that the settings button is hidden when the server starts'''
|
|
|
|
self.assertFalse(self.gui.settings_button.isVisible())
|
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def server_status_bar_is_visible(self):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the status bar is visible'''
|
|
|
|
self.assertTrue(self.gui.status_bar.isVisible())
|
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def click_mode(self, mode):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that we can switch Mode by clicking the button'''
|
2018-10-07 21:49:09 -04:00
|
|
|
if type(mode) == ReceiveMode:
|
2018-09-23 20:41:48 -04:00
|
|
|
QtTest.QTest.mouseClick(self.gui.receive_mode_button, QtCore.Qt.LeftButton)
|
|
|
|
self.assertTrue(self.gui.mode, self.gui.MODE_RECEIVE)
|
2018-10-07 21:49:09 -04:00
|
|
|
if type(mode) == ShareMode:
|
2018-09-23 20:41:48 -04:00
|
|
|
QtTest.QTest.mouseClick(self.gui.share_mode_button, QtCore.Qt.LeftButton)
|
|
|
|
self.assertTrue(self.gui.mode, self.gui.MODE_SHARE)
|
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def click_toggle_history(self, mode):
|
2018-09-29 21:24:11 -04:00
|
|
|
'''Test that we can toggle Download or Upload history by clicking the toggle button'''
|
2018-10-07 21:49:09 -04:00
|
|
|
currently_visible = mode.history.isVisible()
|
|
|
|
QtTest.QTest.mouseClick(mode.toggle_history, QtCore.Qt.LeftButton)
|
|
|
|
self.assertEqual(mode.history.isVisible(), not currently_visible)
|
2018-09-29 21:24:11 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def history_indicator(self, mode, public_mode):
|
2018-09-30 14:41:07 -04:00
|
|
|
'''Test that we can make sure the history is toggled off, do an action, and the indiciator works'''
|
2018-10-07 21:49:09 -04:00
|
|
|
# Make sure history is toggled off
|
|
|
|
if mode.history.isVisible():
|
|
|
|
QtTest.QTest.mouseClick(mode.toggle_history, QtCore.Qt.LeftButton)
|
|
|
|
self.assertFalse(mode.history.isVisible())
|
2018-09-30 14:41:07 -04:00
|
|
|
|
2018-10-07 21:49:09 -04:00
|
|
|
# Indicator should not be visible yet
|
|
|
|
self.assertFalse(mode.toggle_history.indicator_label.isVisible())
|
2018-09-30 14:41:07 -04:00
|
|
|
|
2018-10-07 21:49:09 -04:00
|
|
|
if type(mode) == ReceiveMode:
|
2018-09-30 14:41:07 -04:00
|
|
|
# Upload a file
|
|
|
|
files = {'file[]': open('/tmp/test.txt', 'rb')}
|
|
|
|
if not public_mode:
|
2018-10-07 21:49:09 -04:00
|
|
|
path = 'http://127.0.0.1:{}/{}/upload'.format(self.gui.app.port, mode.web.slug)
|
2018-09-30 14:41:07 -04:00
|
|
|
else:
|
|
|
|
path = 'http://127.0.0.1:{}/upload'.format(self.gui.app.port)
|
|
|
|
response = requests.post(path, files=files)
|
|
|
|
QtTest.QTest.qWait(2000)
|
|
|
|
|
2018-10-07 21:49:09 -04:00
|
|
|
if type(mode) == ShareMode:
|
2018-09-30 14:41:07 -04:00
|
|
|
# Download files
|
|
|
|
if public_mode:
|
|
|
|
url = "http://127.0.0.1:{}/download".format(self.gui.app.port)
|
|
|
|
else:
|
2018-10-12 03:53:03 -04:00
|
|
|
url = "http://127.0.0.1:{}/{}/download".format(self.gui.app.port, mode.web.slug)
|
2018-09-30 14:41:07 -04:00
|
|
|
r = requests.get(url)
|
|
|
|
QtTest.QTest.qWait(2000)
|
|
|
|
|
2018-10-07 21:49:09 -04:00
|
|
|
# Indicator should be visible, have a value of "1"
|
|
|
|
self.assertTrue(mode.toggle_history.indicator_label.isVisible())
|
|
|
|
self.assertEqual(mode.toggle_history.indicator_label.text(), "1")
|
2018-09-30 14:41:07 -04:00
|
|
|
|
2018-10-07 21:49:09 -04:00
|
|
|
# Toggle history back on, indicator should be hidden again
|
|
|
|
QtTest.QTest.mouseClick(mode.toggle_history, QtCore.Qt.LeftButton)
|
|
|
|
self.assertFalse(mode.toggle_history.indicator_label.isVisible())
|
2018-09-30 14:41:07 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def history_is_not_visible(self, mode):
|
2018-09-29 21:24:11 -04:00
|
|
|
'''Test that the History section is not visible'''
|
2018-10-07 21:49:09 -04:00
|
|
|
self.assertFalse(mode.history.isVisible())
|
2018-09-29 21:24:11 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def history_is_visible(self, mode):
|
2018-09-29 21:24:11 -04:00
|
|
|
'''Test that the History section is visible'''
|
2018-10-07 21:49:09 -04:00
|
|
|
self.assertTrue(mode.history.isVisible())
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def server_working_on_start_button_pressed(self, mode):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test we can start the service'''
|
|
|
|
# Should be in SERVER_WORKING state
|
2018-10-07 21:49:09 -04:00
|
|
|
QtTest.QTest.mouseClick(mode.server_status.server_button, QtCore.Qt.LeftButton)
|
|
|
|
self.assertEqual(mode.server_status.status, 1)
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def server_status_indicator_says_starting(self, mode):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the Server Status indicator shows we are Starting'''
|
2018-10-15 22:01:44 -04:00
|
|
|
self.assertEqual(mode.server_status_label.text(), strings._('gui_status_indicator_share_working'))
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-15 22:01:44 -04:00
|
|
|
def server_is_started(self, mode, startup_time=2000):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the server has started'''
|
2018-10-15 22:01:44 -04:00
|
|
|
QtTest.QTest.qWait(startup_time)
|
2018-09-23 20:41:48 -04:00
|
|
|
# Should now be in SERVER_STARTED state
|
2018-10-07 21:49:09 -04:00
|
|
|
self.assertEqual(mode.server_status.status, 2)
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-15 22:01:44 -04:00
|
|
|
def web_server_is_running(self):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the web server has started'''
|
|
|
|
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
|
|
|
|
|
|
|
self.assertEqual(sock.connect_ex(('127.0.0.1',self.gui.app.port)), 0)
|
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def have_a_slug(self, mode, public_mode):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that we have a valid slug'''
|
2018-10-07 21:49:09 -04:00
|
|
|
if not public_mode:
|
|
|
|
self.assertRegex(mode.server_status.web.slug, r'(\w+)-(\w+)')
|
|
|
|
else:
|
|
|
|
self.assertIsNone(mode.server_status.web.slug, r'(\w+)-(\w+)')
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def url_description_shown(self, mode):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the URL label is showing'''
|
2018-10-07 21:49:09 -04:00
|
|
|
self.assertTrue(mode.server_status.url_description.isVisible())
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-15 22:01:44 -04:00
|
|
|
def have_copy_url_button(self, mode, public_mode):
|
|
|
|
'''Test that the Copy URL button is shown and that the clipboard is correct'''
|
2018-10-07 21:49:09 -04:00
|
|
|
self.assertTrue(mode.server_status.copy_url_button.isVisible())
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2018-10-15 22:01:44 -04:00
|
|
|
QtTest.QTest.mouseClick(mode.server_status.copy_url_button, QtCore.Qt.LeftButton)
|
|
|
|
clipboard = self.gui.qtapp.clipboard()
|
|
|
|
if public_mode:
|
|
|
|
self.assertEqual(clipboard.text(), 'http://127.0.0.1:{}'.format(self.gui.app.port))
|
|
|
|
else:
|
|
|
|
self.assertEqual(clipboard.text(), 'http://127.0.0.1:{}/{}'.format(self.gui.app.port, mode.server_status.web.slug))
|
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def server_status_indicator_says_started(self, mode):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the Server Status indicator shows we are started'''
|
2018-10-07 21:49:09 -04:00
|
|
|
if type(mode) == ReceiveMode:
|
2018-10-15 22:01:44 -04:00
|
|
|
self.assertEqual(mode.server_status_label.text(), strings._('gui_status_indicator_receive_started'))
|
2018-10-07 21:49:09 -04:00
|
|
|
if type(mode) == ShareMode:
|
2018-10-15 22:01:44 -04:00
|
|
|
self.assertEqual(mode.server_status_label.text(), strings._('gui_status_indicator_share_started'))
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def web_page(self, mode, string, public_mode):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the web page contains a string'''
|
|
|
|
s = socks.socksocket()
|
|
|
|
s.settimeout(60)
|
|
|
|
s.connect(('127.0.0.1', self.gui.app.port))
|
|
|
|
|
|
|
|
if not public_mode:
|
2018-10-07 21:49:09 -04:00
|
|
|
path = '/{}'.format(mode.server_status.web.slug)
|
2018-09-23 20:41:48 -04:00
|
|
|
else:
|
|
|
|
path = '/'
|
|
|
|
|
|
|
|
http_request = 'GET {} HTTP/1.0\r\n'.format(path)
|
|
|
|
http_request += 'Host: 127.0.0.1\r\n'
|
|
|
|
http_request += '\r\n'
|
|
|
|
s.sendall(http_request.encode('utf-8'))
|
|
|
|
|
|
|
|
with open('/tmp/webpage', 'wb') as file_to_write:
|
|
|
|
while True:
|
|
|
|
data = s.recv(1024)
|
|
|
|
if not data:
|
|
|
|
break
|
|
|
|
file_to_write.write(data)
|
|
|
|
file_to_write.close()
|
|
|
|
|
|
|
|
f = open('/tmp/webpage')
|
|
|
|
self.assertTrue(string in f.read())
|
|
|
|
f.close()
|
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def history_widgets_present(self, mode):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the relevant widgets are present in the history view after activity has taken place'''
|
2018-10-07 21:49:09 -04:00
|
|
|
self.assertFalse(mode.history.empty.isVisible())
|
|
|
|
self.assertTrue(mode.history.not_empty.isVisible())
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def counter_incremented(self, mode, count):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the counter has incremented'''
|
2018-10-15 22:01:44 -04:00
|
|
|
self.assertEqual(mode.history.completed_count, count)
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def server_is_stopped(self, mode, stay_open):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the server stops when we click Stop'''
|
2018-10-07 21:49:09 -04:00
|
|
|
if type(mode) == ReceiveMode or (type(mode) == ShareMode and stay_open):
|
|
|
|
QtTest.QTest.mouseClick(mode.server_status.server_button, QtCore.Qt.LeftButton)
|
2018-10-15 22:01:44 -04:00
|
|
|
self.assertEqual(mode.server_status.status, 0)
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-15 22:01:44 -04:00
|
|
|
def web_server_is_stopped(self):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the web server also stopped'''
|
|
|
|
QtTest.QTest.qWait(2000)
|
|
|
|
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
|
|
|
|
|
|
|
# We should be closed by now. Fail if not!
|
|
|
|
self.assertNotEqual(sock.connect_ex(('127.0.0.1',self.gui.app.port)), 0)
|
|
|
|
|
2019-01-20 15:01:51 -05:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def server_status_indicator_says_closed(self, mode, stay_open):
|
2018-09-23 20:41:48 -04:00
|
|
|
'''Test that the Server Status indicator shows we closed'''
|
2018-10-07 21:49:09 -04:00
|
|
|
if type(mode) == ReceiveMode:
|
2018-10-15 22:01:44 -04:00
|
|
|
self.assertEqual(self.gui.receive_mode.server_status_label.text(), strings._('gui_status_indicator_receive_stopped'))
|
2018-10-07 21:49:09 -04:00
|
|
|
if type(mode) == ShareMode:
|
2018-09-23 20:41:48 -04:00
|
|
|
if stay_open:
|
2018-10-15 22:01:44 -04:00
|
|
|
self.assertEqual(self.gui.share_mode.server_status_label.text(), strings._('gui_status_indicator_share_stopped'))
|
2018-09-23 20:41:48 -04:00
|
|
|
else:
|
2018-10-15 22:01:44 -04:00
|
|
|
self.assertEqual(self.gui.share_mode.server_status_label.text(), strings._('closing_automatically'))
|
|
|
|
|
|
|
|
|
|
|
|
# Auto-stop timer tests
|
|
|
|
def set_timeout(self, mode, timeout):
|
|
|
|
'''Test that the timeout can be set'''
|
|
|
|
timer = QtCore.QDateTime.currentDateTime().addSecs(timeout)
|
|
|
|
mode.server_status.shutdown_timeout.setDateTime(timer)
|
|
|
|
self.assertTrue(mode.server_status.shutdown_timeout.dateTime(), timer)
|
|
|
|
|
|
|
|
|
|
|
|
def timeout_widget_hidden(self, mode):
|
|
|
|
'''Test that the timeout widget is hidden when share has started'''
|
|
|
|
self.assertFalse(mode.server_status.shutdown_timeout_container.isVisible())
|
|
|
|
|
|
|
|
|
|
|
|
def server_timed_out(self, mode, wait):
|
|
|
|
'''Test that the server has timed out after the timer ran out'''
|
|
|
|
QtTest.QTest.qWait(wait)
|
|
|
|
# We should have timed out now
|
|
|
|
self.assertEqual(mode.server_status.status, 0)
|
|
|
|
|
2018-10-16 20:57:21 -04:00
|
|
|
# Hack to close an Alert dialog that would otherwise block tests
|
|
|
|
def accept_dialog(self):
|
|
|
|
window = self.gui.qtapp.activeWindow()
|
|
|
|
if window:
|
|
|
|
window.close()
|
2018-10-15 22:01:44 -04:00
|
|
|
|
|
|
|
# 'Grouped' tests follow from here
|
2018-09-23 20:41:48 -04:00
|
|
|
|
2018-10-11 20:28:47 -04:00
|
|
|
def run_all_common_setup_tests(self):
|
|
|
|
self.gui_loaded()
|
|
|
|
self.windowTitle_seen()
|
|
|
|
self.settings_button_is_visible()
|
|
|
|
self.server_status_bar_is_visible()
|