diff options
Diffstat (limited to 'service/test')
-rw-r--r-- | service/test/functional/features/environment.py | 4 | ||||
-rw-r--r-- | service/test/support/integration/app_test_client.py | 3 | ||||
-rw-r--r-- | service/test/unit/config/test_app_factory.py | 13 | ||||
-rw-r--r-- | service/test/unit/config/test_dispatcher.py | 59 | ||||
-rw-r--r-- | service/test/unit/test_runserver.py | 88 |
5 files changed, 72 insertions, 95 deletions
diff --git a/service/test/functional/features/environment.py b/service/test/functional/features/environment.py index 5e93c840..d78083d0 100644 --- a/service/test/functional/features/environment.py +++ b/service/test/functional/features/environment.py @@ -38,8 +38,8 @@ def after_all(context): def before_feature(context, feature): - # context.browser = webdriver.Firefox() - context.browser = webdriver.PhantomJS() + context.browser = webdriver.Firefox() + # context.browser = webdriver.PhantomJS() context.browser.set_window_size(1280, 1024) context.browser.implicitly_wait(5) context.browser.set_page_load_timeout(60) # wait for data diff --git a/service/test/support/integration/app_test_client.py b/service/test/support/integration/app_test_client.py index e8f79d2b..fba9ba9c 100644 --- a/service/test/support/integration/app_test_client.py +++ b/service/test/support/integration/app_test_client.py @@ -27,6 +27,7 @@ from pixelated.adapter.services.mail_service import MailService from pixelated.adapter.services.mailboxes import Mailboxes from pixelated.adapter.soledad.soledad_querier import SoledadQuerier from pixelated.adapter.services.tag_service import TagService +from pixelated.config import App from pixelated.resources.root_resource import RootResource import pixelated.runserver from pixelated.adapter.model.mail import PixelatedMail @@ -53,7 +54,7 @@ class AppTestClient: SearchEngine.DEFAULT_INDEX_HOME = soledad_test_folder - self.app = pixelated.runserver.app + self.app = App() self.soledad_querier = SoledadQuerier(self.soledad) self.soledad_querier.get_index_masterkey = lambda: self.INDEX_KEY diff --git a/service/test/unit/config/test_app_factory.py b/service/test/unit/config/test_app_factory.py index a42c7c83..b09ffd4c 100644 --- a/service/test/unit/config/test_app_factory.py +++ b/service/test/unit/config/test_app_factory.py @@ -13,20 +13,25 @@ class AppFactoryTest(unittest.TestCase): self.host = host self.sslkey = sslkey self.sslcert = sslcert + self.home = 'leap_home' + @patch('pixelated.config.app_factory.init_app') @patch('pixelated.config.app_factory.reactor') - def test_that_create_app_binds_to_tcp_port_if_no_ssl_options(self, reactor_mock): + def test_that_create_app_binds_to_tcp_port_if_no_ssl_options(self, reactor_mock, init_app_mock): app_mock = MagicMock() + leap_session = MagicMock() - create_app(app_mock, AppFactoryTest.MockConfig(12345, '127.0.0.1')) + create_app(app_mock, AppFactoryTest.MockConfig(12345, '127.0.0.1'), leap_session) reactor_mock.listenTCP.assert_called_once_with(12345, ANY, interface='127.0.0.1') + @patch('pixelated.config.app_factory.init_app') @patch('pixelated.config.app_factory.reactor') - def test_that_create_app_binds_to_ssl_if_ssl_options(self, reactor_mock): + def test_that_create_app_binds_to_ssl_if_ssl_options(self, reactor_mock, init_app_mock): app_mock = MagicMock() + leap_session = MagicMock() pixelated.config.app_factory._ssl_options = lambda _: 'options' - create_app(app_mock, AppFactoryTest.MockConfig(12345, '127.0.0.1', sslkey="sslkey", sslcert="sslcert")) + create_app(app_mock, AppFactoryTest.MockConfig(12345, '127.0.0.1', sslkey="sslkey", sslcert="sslcert"), leap_session) reactor_mock.listenSSL.assert_called_once_with(12345, ANY, 'options', interface='127.0.0.1') diff --git a/service/test/unit/config/test_dispatcher.py b/service/test/unit/config/test_dispatcher.py new file mode 100644 index 00000000..ad85a63c --- /dev/null +++ b/service/test/unit/config/test_dispatcher.py @@ -0,0 +1,59 @@ +import json +import unittest +import thread +import sys +from mockito import mock, when +import os +from pixelated.config import App +from pixelated.config.args import parse as parse_args + +from pixelated.config.dispatcher import config_dispatcher + + +class TestConfigDispatcher(unittest.TestCase): + + def setUp(self): + self.app = App() + self.test_data = {'leap_provider_hostname': 'test_provider', 'user': 'test_user', 'password': 'test_password'} + + def test_that_organization_switch_reads_the_credentials_from_pipe(self): + fifo_path = '/tmp/credentials-pipe' + + sys.argv = ['tmp/does_not_exist', '--dispatcher', fifo_path] + args = parse_args() + + self._mkfifo(fifo_path) + + config_dispatcher(self.app, args) + + self.assertEquals('test_provider', self.app['LEAP_SERVER_NAME']) + self.assertEquals('test_user', self.app['LEAP_USERNAME']) + self.assertEquals('test_password', self.app['LEAP_PASSWORD']) + + def test_that_organization_switch_reads_the_credentials_from_stdin(self): + data = json.dumps({'leap_provider_hostname': 'test_provider', 'user': 'test_user', 'password': 'test_password'}) + orig_stdin = sys.stdin + sys.stdin = mock() + when(sys.stdin).read().thenReturn(data) + + try: + sys.argv = ['tmp/does_not_exist', '--dispatcher-stdin'] + args = parse_args() + + config_dispatcher(self.app, args) + + self.assertEquals('test_provider', self.app['LEAP_SERVER_NAME']) + self.assertEquals('test_user', self.app['LEAP_USERNAME']) + self.assertEquals('test_password', self.app['LEAP_PASSWORD']) + finally: + sys.stdin = orig_stdin + + def _spin_up_fifo(self, test_fifo): + with open(test_fifo, 'w') as fifo: + fifo.write(json.dumps(self.test_data)) + + def _mkfifo(self, fifo_path): + if os.path.exists(fifo_path): + os.remove(fifo_path) + os.mkfifo('/tmp/credentials-pipe') + thread.start_new_thread(self._spin_up_fifo, (fifo_path,)) diff --git a/service/test/unit/test_runserver.py b/service/test/unit/test_runserver.py deleted file mode 100644 index 99b502f1..00000000 --- a/service/test/unit/test_runserver.py +++ /dev/null @@ -1,88 +0,0 @@ -# -# Copyright (c) 2014 ThoughtWorks, Inc. -# -# Pixelated is free software: you can redistribute it and/or modify -# it under the terms of the GNU Affero General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. -# -# Pixelated 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 Affero General Public License for more details. -# -# You should have received a copy of the GNU Affero General Public License -# along with Pixelated. If not, see <http://www.gnu.org/licenses/>. - -import unittest -import sys -import thread -import json - -import os -import pixelated.config.app_factory -import pixelated.runserver -from mockito import * -import pixelated.config.app_factory as app_factory -from leap.common.events import server as events_server - - -class RunserverTest(unittest.TestCase): - - def setUp(self): - events_server.ensure_server = lambda port=None: None - when(app_factory).create_app().thenReturn(None) - - def tearDown(self): - unstub() - - def test_that_config_file_can_be_specified_on_command_line(self): - self.config_file_loaded = None - - def _mock_parse_config_from_file(config_file): - self.config_file_loaded = config_file - return 1, 2, 3 - - pixelated.runserver.parse_config_from_file = _mock_parse_config_from_file - sys.argv = ['pixelated-user-agent', '--config', 'pixelated.cfg'] - - pixelated.runserver.setup() - - self.assertEquals('pixelated.cfg', self.config_file_loaded) - - def test_that_organization_switch_reads_the_credentials_from_pipe(self): - fifo_path = '/tmp/credentials-pipe' - if os.path.exists(fifo_path): - os.remove(fifo_path) - test_fifo = os.mkfifo('/tmp/credentials-pipe') - thread.start_new_thread(self.spin_up_fifo, (fifo_path,)) - sys.argv = ['tmp/does_not_exist', '--dispatcher', fifo_path] - pixelated.runserver.setup() - - def test_that_organization_switch_reads_the_credentials_from_stdin(self): - data = json.dumps({'leap_provider_hostname': 'test_provider', 'user': 'test_user', 'password': 'test_password'}) - orig_stdin = sys.stdin - try: - sys.stdin = Mock() - when(sys.stdin).read().thenReturn(data) - - sys.argv = ['tmp/does_not_exist', '--dispatcher-stdin'] - pixelated.runserver.setup() - - self.assertEquals('test_provider', pixelated.runserver.app.config['LEAP_SERVER_NAME']) - self.assertEquals('test_user', pixelated.runserver.app.config['LEAP_USERNAME']) - self.assertEquals('test_password', pixelated.runserver.app.config['LEAP_PASSWORD']) - finally: - sys.stdin = orig_stdin - - def test_start_services_pass_args_through(self): - args = {} - when(app_factory).create_app(any(), args).thenReturn(None) - - pixelated.runserver.start_services(args) - - verify(app_factory).create_app(any(), args) - - def spin_up_fifo(self, test_fifo): - with open(test_fifo, 'w') as fifo: - fifo.write(json.dumps({'leap_provider_hostname': 'test_provider', 'user': 'test_user', 'password': 'test_password'})) |