The backdrop to this post was that at Money Dashboard we wanted to deliver a brand new native app on both the Android and iOS platform to replace a native wrapper around our responsive web application. Although the exact feature set was not clear from the start, there were some core functionality that we knew had to be included and so we set about developing this. Initially, we started to develop on both platforms at the same time splitting our resources evenly with Android only ever slightly ahead.
As the product began to take shape and decisions around what we wanted to include, so began the debate as to which platform to deliver on first. Initially, there was an understandable desire to release both apps at the same time but after careful consideration we desired against this. We wanted to gauge feedback from users and refine a single platform before taking those lessons and applying them to the second platform. There were real concerns that if we just developed the same app on 2 platforms, not only would it be longer before we would be able to get feedback, bugs would most likely appear on both and could result in poor reviews and a mad dash to get fixes out on both.
iOS or Android?
With agreement reached to focus on a single platform, the decision was simply which one first? There has been quite a bit of airtime given to this topic and much of it seems to favour delivering an iOS app first as highlighted in the following articles.
iOS first and Android much much later
The fallacy of Android first
Why Android first is a myth
For us however, we took the opposite approach and decided to push forward with Android based upon the following key reasons:
- We had more resources available to us for developing an Android app. We didn't require any new hardware (Android Studio on Windows) and almost all of the project team had Android devices. Furnishing the entire team with a Mac Mini each would have been a significant up front cost as would obtaining a set of test devices.
- We run our continuous integration in the cloud and configuring a build agent for Android development was very straight forward. Our cloud environment did not have support for OSX and a local build agent for iOS would be required.
- The development team were comfortable working in Java with many having used it at university or in previous employment. Objective C & Swift were brand new and with a steep learning curve for the team.
- The Google Play submission process is significantly faster than that of Apple with the ability to submit a new version of an app into the store within hours as against a process which can sometimes take 7 days or more.
- Google Play has a nicely integrated beta facility which is easy to distribute your app to a defined group for early adopters (those who expressed an interest in our beta release were mainly Android users).