/
test_launchers.py
169 lines (144 loc) · 6.55 KB
/
test_launchers.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
from mozregression import launchers
import unittest
import os
from mock import patch, Mock
from mozprofile import Profile
from mozregression.errors import LauncherNotRunnable
class MyLauncher(launchers.Launcher):
installed = None
started = False
stopped = False
def _install(self, dest):
self.installed = dest
def _start(self):
self.started = True
def _stop(self):
self.stopped = True
class TestLauncher(unittest.TestCase):
def test_start_stop(self):
launcher = MyLauncher('/foo/persist.zip')
self.assertFalse(launcher.started)
launcher.start()
# now it has been started
self.assertTrue(launcher.started)
# restarting won't do anything because it was not stopped
launcher.started = False
launcher.start()
self.assertFalse(launcher.started)
# stop it, then start it again, this time _start is called again
launcher.stop()
launcher.start()
self.assertTrue(launcher.started)
class TestMozRunnerLauncher(unittest.TestCase):
@patch('mozregression.launchers.mozinstall')
def setUp(self, mozinstall):
mozinstall.get_binary.return_value = '/binary'
self.launcher = launchers.MozRunnerLauncher('/binary')
# patch profile_class else we will have some temporary dirs not deleted
@patch('mozregression.launchers.MozRunnerLauncher.\
profile_class', spec=Profile)
def launcher_start(self, profile_class, *args, **kwargs):
self.profile_class = profile_class
self.launcher.start(*args, **kwargs)
def test_installed(self):
self.assertEqual(self.launcher.binary, '/binary')
@patch('mozregression.launchers.Runner')
def test_start_no_args(self, Runner):
self.launcher_start()
kwargs = Runner.call_args[1]
self.assertEqual(kwargs['cmdargs'], ())
self.assertEqual(kwargs['binary'], '/binary')
self.assertEqual(kwargs['process_args'],
{'processOutputLine': [self.launcher._logger.debug]})
self.assertIsInstance(kwargs['profile'], Profile)
# runner is started
self.launcher.runner.start.assert_called_once_with()
self.launcher.stop()
@patch('mozregression.launchers.Runner')
def test_start_with_addons(self, Runner):
self.launcher_start(addons=['my-addon'], preferences='my-prefs')
self.profile_class.assert_called_once_with(addons=['my-addon'],
preferences='my-prefs')
# runner is started
self.launcher.runner.start.assert_called_once_with()
self.launcher.stop()
@patch('mozregression.launchers.Runner')
def test_start_with_profile_and_addons(self, Runner):
self.launcher_start(profile='my-profile', addons=['my-addon'],
preferences='my-prefs')
self.profile_class.assert_called_once_with(profile='my-profile',
addons=['my-addon'],
preferences='my-prefs')
# runner is started
self.launcher.runner.start.assert_called_once_with()
self.launcher.stop()
@patch('mozregression.launchers.Runner')
@patch('mozregression.launchers.mozversion')
def test_get_app_infos(self, mozversion, Runner):
mozversion.get_version.return_value = {'some': 'infos'}
self.launcher_start()
self.assertEqual(self.launcher.get_app_info(), {'some': 'infos'})
mozversion.get_version.assert_called_once_with(binary='/binary')
self.launcher.stop()
def test_launcher_deleted_remove_tempdir(self):
tempdir = self.launcher.tempdir
self.assertTrue(os.path.isdir(tempdir))
del self.launcher
self.assertFalse(os.path.isdir(tempdir))
class TestFennecLauncher(unittest.TestCase):
@patch('mozregression.launchers.mozversion.get_version')
@patch('mozregression.launchers.ADBAndroid')
def create_launcher(self, ADBAndroid, get_version, **kwargs):
self.adb = Mock(test_root='/sdcard/tmp')
ADBAndroid.return_value = self.adb
get_version.return_value = kwargs.get('version_value', {})
return launchers.FennecLauncher('/binary')
def test_install(self):
self.create_launcher()
self.adb.uninstall_app.assert_called_with("org.mozilla.fennec")
self.adb.install_app.assert_called_with('/binary')
def test_start_stop(self):
launcher = self.create_launcher()
launcher.start(profile='my_profile')
self.adb.exists.assert_called_once_with('/sdcard/tmp/my_profile')
self.adb.rm.assert_called_once_with('/sdcard/tmp/my_profile',
recursive=True)
self.adb.push.assert_called_once_with(os.path.realpath('my_profile'),
'/sdcard/tmp/my_profile')
self.adb.launch_fennec.assert_called_once_with(
"org.mozilla.fennec",
extra_args=['-profile', '/sdcard/tmp/my_profile']
)
# ensure get_app_info returns something
self.assertIsNotNone(launcher.get_app_info())
launcher.stop()
self.adb.stop_application.assert_called_once_with("org.mozilla.fennec")
def test_adb_calls_with_custom_package_name(self):
pkg_name = 'org.mozilla.custom'
launcher = \
self.create_launcher(version_value={'package_name': pkg_name})
self.adb.uninstall_app.assert_called_once_with(pkg_name)
launcher.start(profile='my_profile')
self.adb.launch_fennec.assert_called_once_with(
pkg_name,
extra_args=['-profile', '/sdcard/tmp/my_profile']
)
launcher.stop()
self.adb.stop_application.assert_called_once_with(pkg_name)
@patch('mozregression.launchers.ADBHost')
@patch('__builtin__.raw_input')
def test_check_is_runnable(self, raw_input, ADBHost):
raw_input.return_value = 'y'
devices = Mock(return_value=True)
ADBHost.return_value = Mock(devices=devices)
# this won't raise errors
launchers.FennecLauncher.check_is_runnable()
# exception raised if there is no device
raw_input.return_value = 'y'
devices.return_value = False
self.assertRaises(LauncherNotRunnable,
launchers.FennecLauncher.check_is_runnable)
# or if ADBHost().devices() raise an unexpected IOError
devices.side_effect = OSError()
self.assertRaises(LauncherNotRunnable,
launchers.FennecLauncher.check_is_runnable)