summaryrefslogtreecommitdiffstats
path: root/mobile/android/tests/browser/robocop/README.rst
blob: 7ace7cdeb1bc9ef86b80c273c2ecfd455b862ec1 (plain)
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
Robocop Mochitest
=================

*Robocop Mochitest* is a Mozilla project which uses Robotium to test
 Firefox on Android devices.

*Robocop Mochitest* tests run on Native Android builds marked with an
'rc' on treeherder.  These are Java based tests which run from the mochitest
harness and generate similar log files.  These are designed for
testing the native UI of Android devices by sending events to the
front end.

See the documentation at
https://wiki.mozilla.org/Auto-tools/Projects/Robocop/WritingTests for
details.

Development cycle
-----------------

To deploy the robocop APK to your device and start the robocop test
suite, use::

    mach robocop

To run a specific test case, such as ``testLoad``::

    mach robocop testLoad

The Java files in ``mobile/android/tests/browser/robocop`` are dependencies of the
robocop APK built by ``build/mobile/robocop``.  If you modify Java files
in ``mobile/android/tests/browser/robocop``, you need to rebuild the robocop APK
with::

    mach build build/mobile/robocop

Changes to ``.html``, ``.css``, ``.sjs``, and ``.js`` files in
``mobile/android/tests/browser/robocop`` do not require rebuilding the robocop
APK -- these changes are always 'live', since they are served by the
mochitest HTTP server and downloaded each test run by your device.

``mach package`` does build and sign a robocop APK, but ``mach
robocop`` does not use it.  (This signed APK is used to test
signed releases on the buildbots).

As always, changes to ``mobile/android/base``, ``mobile/android/chrome``,
``mobile/android/modules``, etc., require::

    mach build mobile/android/base && mach package && mach install

as usual.

Licensing
---------

Robotium is an open source tool licensed under the Apache 2.0 license and the original
source can be found here:
https://github.com/RobotiumTech/robotium

We are including robotium-solo-5.5.4.jar as a binary and are not modifying it in any way
from the original download found at:
https://github.com/RobotiumTech/robotium/wiki/Downloads