DEV Community

Cover image for Using Appium for Automated Testing of Roku TV Apps
Bertha White
Bertha White

Posted on

Using Appium for Automated Testing of Roku TV Apps

One of the great things about Appium 2.0 is that you can find drivers to enable your automation testing across a wider variety of platforms than ever before; now including even media streaming platforms! In this article, we'll learn how to test Roku TV applications using a relatively new Appium driver for Roku TV. I implemented this driver on behalf of HeadSpin, and it's fully open source, available on GitHub: Appium for Roku TV. The full documentation for the driver is available there at the README, but we'll be covering all the highlights in this article.

How the Appium Roku driver works

To perform automation well on a given platform, it's always worth doing a little research on how app development for the platform works, beyond finding an Appium driver for it. This helps you understand how the driver itself works and what its requirements and limitations are. The more you know about iOS development, for example, the better use you'll be able to make of Appium's iOS driver. The same goes for Roku! The best source for Roku developer information is Roku's Developer Portal. This is the documentation I used to build the Appium Roku driver.

One thing to note right off the bat is that Roku apps are called "channels" (as in TV channels) in the Roku documentation, so be aware of how this language is a bit different from most platforms.

You might also notice that Roku publishes something called the Roku WebDriver, which is a WebDriver server implementation for Roku automation, written in Go. Its purpose is very similar to the purpose of the Appium Roku driver---to allow for WebDriver-style automation of Roku apps. So why did I bother to make an Appium Roku driver at all? When I looked into the Roku WebDriver implementation, it unfortunately did not follow standard W3C protocol conventions, nor was it already Appium-compatible. Reading through the code, it became apparent that the Roku WebDriver server was a thin layer on top of another Roku developer tool called the External Control Protocol (ECP). This is an API hosted on the Roku device itself which allows limited remote control and debugging of Roku developer channels. Beyond this, I noticed that the Roku WebDriver did not have certain features I thought were important, like the ability to find element objects and trigger them by calling the Click Element command. Ultimately, it seemed like a better idea to create and maintain an Appium driver based on the same protocol, so that's what we did!

The ECP takes care of most of how the Appium driver works, since it lets you do things like get a dump of the UI element hierarchy or simulate remote control keypresses. But it doesn't let you do things like install apps or take screenshots. Luckily, the Roku comes with a special developer mode website that you can access in a web browser locally connected to the Roku device. This website lets you upload your development apps (called "dev channels") and retrieve screenshots. The Appium driver simply calls out to this webserver when it needs to perform these tasks as part of its work, so you don't have to do it manually.

Requirements and limitations of the Appium Roku driver

Before beginning an automation project for any platform, it's important to make sure you understand the requirements and limitations of the platform, so you're not stuck in a dead end. This is definitely true for Roku test automation as well. Here are some of the requirements you'll need to keep in mind if you want Roku testing to be successful:

  • You will need a physical Roku device for testing. There is no such thing as a Roku emulator, unfortunately.
  • Your Roku needs to be on the same network as your Appium server (since the Appium server will make network calls to the Roku).
  • Your Roku needs to be in Developer Mode so that the ECP server and Dev Mode server are up and running.
  • You need to have access to your Roku channel as a .zip file in the format expected by the Roku channel sideloading (installation) service. In other words, it should be an archive of your source code, not a compiled version of the app.
  • And of course, you should have a functional Appium 2.0 server environment, ideally updated to the latest and greatest!
    Securely test content on Smart TVs with HeadSpin for perfecting digital experiences and increasing efficiency and user engagement. Learn more.
    Here are some limitations of the driver to keep in mind:

  • You cannot automate channels that you do not have the source code to (i.e., your dev channel). (Technically, you can still use the driver's remote-control emulation to do anything you want on the device, but this will be driving the device "blind"---you'll have no way to check the UI hierarchy or grab a screenshot). I.e., the Take Screenshot and Get Page Source commands only work if the dev channel is active.

  • Roku provides a way to see the UI element hierarchy, but no way to work with specific UI elements directly. The only way to interact the device is via the remote control. The Appium driver does however provide a special algorithm for emulating the Click Element command which will be highlighted below. It also has a convenience method for Send Keys, that simply sends keystrokes to the Roku as if a user were doing so with the remote. All this to say: you will be able to run the Find Element command, which is certainly useful for waiting for app state, but in general there is no way to interact with the element you have found. To trigger elements you'll need to use the driver's remote-control methods or one of the few convenience methods mentioned above.

  • Only one dev channel may be sideloaded at any given time. When you (or the driver) sideloads a dev channel, it will be given the channel ID of dev. So even though your app will have its own official channel ID used for publishing, the ID of the channel for automation purposes will basically always be dev.

  • When you take a screenshot of a screen which contains video content, that video content will be shown as a black rectangle. This is because Roku does not allow DRMed video content to leave the device except to authorized playback machines (like TVs).

Installing the Appium Roku driver

With the Appium 2.0 extension CLI, installing the driver is as easy as running:

appium driver install --source=npm @headspinio/appium-roku-driver
This will get you the latest version of the Roku driver. If you would like to upgrade at any point later, you can simply run:

appium driver update roku

Starting Roku app test automation sessions

There is also a special capability that determines how long the driver will wait in between remote key presses. This can be useful if the automated key presses are happening too quickly for your app to react to them. If you find yourself in this position, simply set the appium:keyCooldown capability to the number of milliseconds you want to wait in between key presses.

Apply data science and innovation to infotainment and in-cabin experience measurement. Know more.

Using a session to test Roku TV apps

Once you have a session going in your Appium client, you'll navigate your app and implement your automation test for Roku using primarily the following commands (note that the way to write these commands differs based on the client library you're using; you can refer to the client libray documentation for specific examples):

  • Install and remove apps
  • Launch apps
  • List available apps
  • Get information about the device That's it! This guide should be all you need to get started with automation testing for Roku. Now go forth and test your streaming apps on Roku TV devices! Remember, the project is open source, so if you think you've found a bug, please report it at the issue tracker, and of course, contributions are also welcome.

Original Source: https://www.headspin.io/blog/using-appium-for-automated-testing-of-roku-tv-apps

Top comments (0)