2018-10-11 20:28:47 -04:00
|
|
|
import os
|
|
|
|
import requests
|
2018-10-26 18:08:55 -04:00
|
|
|
from datetime import datetime, timedelta
|
2018-10-16 20:57:21 -04:00
|
|
|
from PyQt5 import QtCore, QtTest
|
2018-10-11 20:28:47 -04:00
|
|
|
from .GuiBaseTest import GuiBaseTest
|
|
|
|
|
|
|
|
class GuiReceiveTest(GuiBaseTest):
|
2019-03-07 20:54:10 -05:00
|
|
|
def upload_file(self, public_mode, file_to_upload, expected_basename, identical_files_at_once=False):
|
2018-10-11 20:28:47 -04:00
|
|
|
'''Test that we can upload the file'''
|
2018-10-17 00:21:04 -04:00
|
|
|
files = {'file[]': open(file_to_upload, 'rb')}
|
2019-05-24 16:38:41 -04:00
|
|
|
url = 'http://127.0.0.1:{}/upload'.format(self.gui.app.port)
|
2018-10-11 20:28:47 -04:00
|
|
|
if not public_mode:
|
2019-05-24 16:38:41 -04:00
|
|
|
r = requests.post(url, files=files)
|
2018-10-11 20:28:47 -04:00
|
|
|
else:
|
2019-05-24 16:38:41 -04:00
|
|
|
r = requests.post(url, files=files, auth=requests.auth.HTTPBasicAuth('onionshare', mode.web.password))
|
2019-03-07 20:54:10 -05:00
|
|
|
if identical_files_at_once:
|
|
|
|
# Send a duplicate upload to test for collisions
|
2019-05-24 16:38:41 -04:00
|
|
|
r = requests.post(path, files=files)
|
2018-10-11 20:28:47 -04:00
|
|
|
QtTest.QTest.qWait(2000)
|
|
|
|
|
2018-10-26 18:08:55 -04:00
|
|
|
# Make sure the file is within the last 10 seconds worth of filenames
|
|
|
|
exists = False
|
|
|
|
now = datetime.now()
|
|
|
|
for i in range(10):
|
|
|
|
date_dir = now.strftime("%Y-%m-%d")
|
2019-03-07 20:54:10 -05:00
|
|
|
if identical_files_at_once:
|
|
|
|
time_dir = now.strftime("%H.%M.%S-1")
|
|
|
|
else:
|
|
|
|
time_dir = now.strftime("%H.%M.%S")
|
2019-01-20 15:01:51 -05:00
|
|
|
receive_mode_dir = os.path.join(self.gui.common.settings.get('data_dir'), date_dir, time_dir)
|
2018-10-26 18:08:55 -04:00
|
|
|
expected_filename = os.path.join(receive_mode_dir, expected_basename)
|
|
|
|
if os.path.exists(expected_filename):
|
|
|
|
exists = True
|
|
|
|
break
|
|
|
|
now = now - timedelta(seconds=1)
|
|
|
|
|
|
|
|
self.assertTrue(exists)
|
|
|
|
|
|
|
|
def upload_file_should_fail(self, public_mode):
|
2018-10-15 22:01:44 -04:00
|
|
|
'''Test that we can't upload the file when permissions are wrong, and expected content is shown'''
|
|
|
|
files = {'file[]': open('/tmp/test.txt', 'rb')}
|
2019-05-24 16:38:41 -04:00
|
|
|
url = 'http://127.0.0.1:{}/upload'.format(self.gui.app.port)
|
2018-10-15 22:01:44 -04:00
|
|
|
if not public_mode:
|
2019-05-24 16:38:41 -04:00
|
|
|
r = requests.post(url, files=files)
|
2018-10-15 22:01:44 -04:00
|
|
|
else:
|
2019-05-24 16:38:41 -04:00
|
|
|
r = requests.post(url, files=files, auth=requests.auth.HTTPBasicAuth('onionshare', mode.web.password))
|
2018-10-15 22:01:44 -04:00
|
|
|
|
2018-10-16 20:57:21 -04:00
|
|
|
QtCore.QTimer.singleShot(1000, self.accept_dialog)
|
2018-10-15 22:01:44 -04:00
|
|
|
self.assertTrue('Error uploading, please inform the OnionShare user' in response.text)
|
|
|
|
|
|
|
|
def upload_dir_permissions(self, mode=0o755):
|
|
|
|
'''Manipulate the permissions on the upload dir in between tests'''
|
|
|
|
os.chmod('/tmp/OnionShare', mode)
|
|
|
|
|
2018-10-17 00:21:04 -04:00
|
|
|
def try_public_paths_in_non_public_mode(self):
|
2019-05-24 16:38:41 -04:00
|
|
|
r = requests.post('http://127.0.0.1:{}/upload'.format(self.gui.app.port))
|
2018-10-17 00:21:04 -04:00
|
|
|
self.assertEqual(response.status_code, 404)
|
2019-05-24 16:38:41 -04:00
|
|
|
r = requests.get('http://127.0.0.1:{}/close'.format(self.gui.app.port))
|
2018-10-17 00:21:04 -04:00
|
|
|
self.assertEqual(response.status_code, 404)
|
|
|
|
|
2019-01-21 20:11:58 -05:00
|
|
|
def uploading_zero_files_shouldnt_change_ui(self, mode, public_mode):
|
|
|
|
'''If you submit the receive mode form without selecting any files, the UI shouldn't get updated'''
|
2019-05-24 16:38:41 -04:00
|
|
|
url = 'http://127.0.0.1:{}/upload'.format(self.gui.app.port)
|
2019-01-21 20:11:58 -05:00
|
|
|
|
|
|
|
# What were the counts before submitting the form?
|
|
|
|
before_in_progress_count = mode.history.in_progress_count
|
|
|
|
before_completed_count = mode.history.completed_count
|
|
|
|
before_number_of_history_items = len(mode.history.item_list.items)
|
|
|
|
|
|
|
|
# Click submit without including any files a few times
|
2019-05-24 16:38:41 -04:00
|
|
|
if not public_mode:
|
|
|
|
r = requests.post(url, files={})
|
|
|
|
r = requests.post(url, files={})
|
|
|
|
r = requests.post(url, files={})
|
|
|
|
else:
|
|
|
|
auth = requests.auth.HTTPBasicAuth('onionshare', mode.web.password)
|
|
|
|
r = requests.post(url, files={}, auth=auth)
|
|
|
|
r = requests.post(url, files={}, auth=auth)
|
|
|
|
r = requests.post(url, files={}, auth=auth)
|
2019-01-21 20:11:58 -05:00
|
|
|
|
|
|
|
# The counts shouldn't change
|
|
|
|
self.assertEqual(mode.history.in_progress_count, before_in_progress_count)
|
|
|
|
self.assertEqual(mode.history.completed_count, before_completed_count)
|
|
|
|
self.assertEqual(len(mode.history.item_list.items), before_number_of_history_items)
|
|
|
|
|
2018-10-15 22:01:44 -04:00
|
|
|
# 'Grouped' tests follow from here
|
|
|
|
|
|
|
|
def run_all_receive_mode_setup_tests(self, public_mode):
|
|
|
|
'''Set up a share in Receive mode and start it'''
|
2018-10-11 20:28:47 -04:00
|
|
|
self.click_mode(self.gui.receive_mode)
|
|
|
|
self.history_is_not_visible(self.gui.receive_mode)
|
|
|
|
self.click_toggle_history(self.gui.receive_mode)
|
|
|
|
self.history_is_visible(self.gui.receive_mode)
|
|
|
|
self.server_working_on_start_button_pressed(self.gui.receive_mode)
|
|
|
|
self.server_status_indicator_says_starting(self.gui.receive_mode)
|
|
|
|
self.settings_button_is_hidden()
|
2018-10-15 22:01:44 -04:00
|
|
|
self.server_is_started(self.gui.receive_mode)
|
|
|
|
self.web_server_is_running()
|
2019-05-22 23:55:31 -04:00
|
|
|
self.have_a_password(self.gui.receive_mode, public_mode)
|
2018-10-11 20:28:47 -04:00
|
|
|
self.url_description_shown(self.gui.receive_mode)
|
2018-10-15 22:01:44 -04:00
|
|
|
self.have_copy_url_button(self.gui.receive_mode, public_mode)
|
2018-10-11 20:28:47 -04:00
|
|
|
self.server_status_indicator_says_started(self.gui.receive_mode)
|
|
|
|
self.web_page(self.gui.receive_mode, 'Select the files you want to send, then click', public_mode)
|
2018-10-15 22:01:44 -04:00
|
|
|
|
|
|
|
def run_all_receive_mode_tests(self, public_mode, receive_allow_receiver_shutdown):
|
|
|
|
'''Upload files in receive mode and stop the share'''
|
|
|
|
self.run_all_receive_mode_setup_tests(public_mode)
|
2018-10-17 00:21:04 -04:00
|
|
|
if not public_mode:
|
|
|
|
self.try_public_paths_in_non_public_mode()
|
2018-10-26 18:08:55 -04:00
|
|
|
self.upload_file(public_mode, '/tmp/test.txt', 'test.txt')
|
2018-10-11 20:28:47 -04:00
|
|
|
self.history_widgets_present(self.gui.receive_mode)
|
|
|
|
self.counter_incremented(self.gui.receive_mode, 1)
|
2018-10-26 18:08:55 -04:00
|
|
|
self.upload_file(public_mode, '/tmp/test.txt', 'test.txt')
|
2018-10-11 20:28:47 -04:00
|
|
|
self.counter_incremented(self.gui.receive_mode, 2)
|
2018-10-26 18:08:55 -04:00
|
|
|
self.upload_file(public_mode, '/tmp/testdir/test', 'test')
|
2018-10-17 00:21:04 -04:00
|
|
|
self.counter_incremented(self.gui.receive_mode, 3)
|
2018-10-26 18:08:55 -04:00
|
|
|
self.upload_file(public_mode, '/tmp/testdir/test', 'test')
|
2018-10-17 00:21:04 -04:00
|
|
|
self.counter_incremented(self.gui.receive_mode, 4)
|
2019-03-07 20:54:10 -05:00
|
|
|
# Test uploading the same file twice at the same time, and make sure no collisions
|
|
|
|
self.upload_file(public_mode, '/tmp/test.txt', 'test.txt', True)
|
|
|
|
self.counter_incremented(self.gui.receive_mode, 6)
|
2019-01-21 20:11:58 -05:00
|
|
|
self.uploading_zero_files_shouldnt_change_ui(self.gui.receive_mode, public_mode)
|
2018-10-11 20:28:47 -04:00
|
|
|
self.history_indicator(self.gui.receive_mode, public_mode)
|
|
|
|
self.server_is_stopped(self.gui.receive_mode, False)
|
2018-10-15 22:01:44 -04:00
|
|
|
self.web_server_is_stopped()
|
2018-10-11 20:28:47 -04:00
|
|
|
self.server_status_indicator_says_closed(self.gui.receive_mode, False)
|
|
|
|
self.server_working_on_start_button_pressed(self.gui.receive_mode)
|
2018-10-15 22:01:44 -04:00
|
|
|
self.server_is_started(self.gui.receive_mode)
|
2018-10-11 20:28:47 -04:00
|
|
|
self.history_indicator(self.gui.receive_mode, public_mode)
|
|
|
|
|
2018-10-15 22:01:44 -04:00
|
|
|
def run_all_receive_mode_unwritable_dir_tests(self, public_mode, receive_allow_receiver_shutdown):
|
|
|
|
'''Attempt to upload (unwritable) files in receive mode and stop the share'''
|
|
|
|
self.run_all_receive_mode_setup_tests(public_mode)
|
|
|
|
self.upload_dir_permissions(0o400)
|
2018-10-26 18:08:55 -04:00
|
|
|
self.upload_file_should_fail(public_mode)
|
2018-10-15 22:01:44 -04:00
|
|
|
self.server_is_stopped(self.gui.receive_mode, True)
|
|
|
|
self.web_server_is_stopped()
|
|
|
|
self.server_status_indicator_says_closed(self.gui.receive_mode, False)
|
|
|
|
self.upload_dir_permissions(0o755)
|
|
|
|
|
|
|
|
def run_all_receive_mode_timer_tests(self, public_mode):
|
|
|
|
"""Auto-stop timer tests in receive mode"""
|
|
|
|
self.run_all_receive_mode_setup_tests(public_mode)
|
|
|
|
self.set_timeout(self.gui.receive_mode, 5)
|
2019-03-25 00:05:54 -04:00
|
|
|
self.autostop_timer_widget_hidden(self.gui.receive_mode)
|
2018-10-15 22:01:44 -04:00
|
|
|
self.server_timed_out(self.gui.receive_mode, 15000)
|
|
|
|
self.web_server_is_stopped()
|