Overriding RxJava Schedulers — getting it right with RxLint

Peter Tackage
Oct 14, 2017 · 2 min read

My previous articles [1], [2] highlighted the importance of overriding the default Scheduler for certain RxJava operators to help ensure the validity of your tests and I also presented the Scheduler Injection pattern as a means of achieving this.

However, manually performing this can be error prone. You need to be familiar enough with the dozens of RxJava operators to know when it’s applicable and consequently, despite code reviews, mistakes can slip in and lead to flaky tests and bugs in your app.

RxLint has been around for a while and provides custom Lint checks for common RxJava mistakes. Since the recent version 1.6, it contains a check which reports a warning if an operator is using a default Scheduler.

Let’s take the example of debounce. Now when using RxLint, if we forget to override the Scheduler, a warning is reported -

Image for post
Image for post
Oops! We forgot to provide our own Scheduler!

RxLint works by scanning the associated @SchedulerSupport annotation value of the RxJava operator call sites in your code. If it finds an instance where the operator declaration is using its own Scheduler, such as @SchedulerSupport(SchedulerSupport.COMPUTATION), then the warning is generated.

With a little corrective action we can fix this up by providing our own injected Scheduler instance -

Image for post
Image for post

So if you’ve been following the Scheduler Injection pattern, try out the latest RxLint and hopefully it makes your life a little easier.

Welcome to a place where words matter. On Medium, smart voices and original ideas take center stage - with no ads in sight. Watch

Follow all the topics you care about, and we’ll deliver the best stories for you to your homepage and inbox. Explore

Get unlimited access to the best stories on Medium — and support writers while you’re at it. Just $5/month. Upgrade

Get the Medium app

A button that says 'Download on the App Store', and if clicked it will lead you to the iOS App store
A button that says 'Get it on, Google Play', and if clicked it will lead you to the Google Play store