Examples and libraries for (Unity3d) mobile game automation testing. This was started as a project for a hack day but the information and unity packages here might be useful for real game projects.
Mobile game automation testing is tricky, the purpose of this project is to provide game developers and QA personel with ideas, examples and libraries which can aid in setting up test automation for a game project.
- appium can handle device communication for both Android and iOS
- This includes installing apps, screenshotting, sending touch-events and reading logs
For game test automation on mobile, the go-to solution is often to use image recognition (e.g. OpenCV) to identify captured screenshots or assets are visible on screen. This works in some cases but comes with a lot of problems:
- Games should be tested during development, the assets of the game keep changing and it is a hassle to keep them up to date.
- Managing different versions of assets for different versions (Android, iOS, free, paid, HD) will lead to confusion about which version should be used in which test.
- Mobile devices have different resolutions and screen aspects, so the image comparison needs to deal with scaling
- Image comparison algorithms are slow for the currently large resolutions of devices
- Animated assets cause problems
- Taking screenshots is slow
- Using a VNC-solution will cause latency and artifacts
- etc...
The easiest way to communicate information from the game to the tests scripts is to read them from log. Logcat for Android or syslog for iOS. In Unity3d you can do this simply by using the Debug class. If you have a lot of information you need to read from the game to the test-scripts you can use a standard format such as JSON. The itest-niacin libraries used in this repository can handle the JSON parsing in your tests scripts.
Image recognition can be made much more robust for this. For a faster implementation consider using QR-codes, there are good, fast QR-code reading libraries which allows you to quickly find if your scene/sprite/object was rendered correctly and visible for the player. Please keep in mind that QR-codes are designed with error correction which enables it to be read even with only a part of the QR-code visible. TODO: Examples and libs with QR-codes
For native UI-elemnents of both Android and iOS this is solved by the platform and you can use Appium to find elements on screen. For games this gets more difficult as the platform cannot help you find the elements. A solution which will work for many cases (especially menus and 2D games) is to instument the game to write positions of the elements/objects into the device log. Once again using a standard format such as JSON is recommended.
See description below in Use in your own project
on how to integrate the Unity-asset and test libraries into your game project to implement this.
- Install Android Debug Bridge
- Install appium 1.4.16
- Connect an Android device or use emulator
- Start appium server
git clone https://github.com/UnityTech/GamesTestAutomationExample
cd GamesTestAutomationExample/tests
./run-tests-android.sh
- Download the file
example-unity-project/AutomationHelpers.unitypackage
from this repository and drag to your unity project - Drag the
ObjectLogger
-prefab from the folderAssets/AutomationHelpers/Prefabs
into root of your project - Open the
ObjectLogger
-Gameobject in inspector and drag the Gameobject you wish to use in your test in appropriate fieldsLogged Objects
-fields should be populated with typical GameobjectsUi menu Object
-field can be populated with a UI-object (unity 5+)
Example of building from command line (Mac - you might have to change Unity path). Executed from root folder of this repo.
/Applications/Unity\ 5.3.4f1/Unity.app/Contents/MacOS/Unity -projectPath $(pwd)/example-unity-project -exportPackage Assets/AutomationHelpers AutomationHelpers.unitypackage -batchmode -quit
- Write better docs with screenshots
- More examples
- Other methods of testing
- Explain what one can do with this project
- Cloud based testing example
- Python version of test scripts