How I killed app sales by going freemium

Shuveb Hussain
Jun 7, 2015 · 7 min read

To scratch my own itch of being able to send web articles to my Kindle from my iPhone or iPad, I wrote an iOS app, Comfy Read. With iOS 8 supporting app extensions, Apple had made it possible to acquire little bits of structured information from pretty much any app with the magical box-and-arrow “share” button. It was sufficiently powerful for my purposes. All I needed was the article URL, which I would send to a server. The server would then fetch the article, format it, package it into a .mobi file the Kindle can deal with and send it to Amazon for delivery to the device.

One reason I was doing this was to learn what new features iOS 8 had from a developer’s perspective, and and other to solve a real problem I was having. I wondered if other people were looking for an app like this. I usually read myself to sleep every night and through the day, I’ve usually sent some article over to my Kindle from my iPhone, iPad or browser. I was more interested in releasing my first iOS app to the App Store to experience first hand what the real deal is. I did not expect to market this at all, since I simply didn’t have the time. But it would be an experiment in seeing how an app would fare with no marketing at all — just depending on downloads via searches in the App Store.

Comfy Read v1.0

Comfy Read went on sale on the 21st of January this year. I priced it at $ 1.99, up-front. Although I did not have the time to do any real marketing for the app, I did create a very simple website for it. It has a home page, a help documentation page and a contact page. I got a mail from Apple saying that the app was “ready for sale”, meaning that it now had hit the App Store. Amazingly, people were finding Comfy Read solely via the App Store search without me having to do anything. I cannot overstate it’s importance. Apparently many were having the same itch as me. If you are building an app, you most certainly have to come up with a good list of keywords and include them in your app submission form. Comfy Read has one advantage, though. It has a singular purpose. It’s features do not overlap with those of other apps in the App Store. It was fairly easy to accurately predict the search process prospective users will go through and come up with keywords for it. It was easy and it seemed to be working. Plus there are millions of Kindles and millions of iOS devices out there. This would have happened anyway.

Search and find

This is how Comfy Read v1.0 fared during the month of April this year.

I pulled the app from the App Store on May 17th. Let me explain why. Since I wasn't interested in the few hundred dollars that Comfy Read was making every month, I wanted to use it to experiment with various revenue models on the App Store. Having a real app with real users, although a small number — what was far more interesting to me was the opportunity to play around with different business models. In the 5 months that Comfy Read was on the app store, users had sent close to 10,000 articles to their Kindle devices. It was very amusing to see all this. Plus it was heartwarming to see good reviews.

Comfy Read v1 reviews from the US

And one guy from Canada totally killed it. He/she went so much overboard that it actually looks like a paid review! I assure you that it is not.

What developer’s dreams are made of

With Apple making analytics available on iTunes Connect, I was amazed to see that Comfy Read was having conversion rates of anywhere between 6 and 9%. Pretty amazing for an up-front paid app, I thought. For example, from the analytics screenshot above, you can see that for 1,080 Comfy Read’s App Store page visits, there were 97 units sold in April. That’s a 8.98% conversion rate. Same for other months for which data is available as well.

Going freemium

Comfy Read 2: A free app with in-app purchases for “article credits”

I added a few other features to Comfy Read and Comfy Read 2 was born. But before that, I had to come up with a freemium model will work. This is what I came up with: A free app that allowed 10 free articles initially, enough for users to get a taste of the service. After these “article credits” ran out, users would still be able to send one article everyday for free. To overcome the one article per day restriction and send articles anytime, users could buy “article credits” from via in-app purchases and send articles anytime.

Actually, one article per day was enough for most users. There was this small risk that most people would never need to buy credits and so the app would not make any money. But it was worth the learning. On May 16th, Comfy Read 2 hit the App Store. and this is how the numbers look. Again, still no marketing. Users are still finding the app via the App Store search.

May 17th to April 5th on the App Store for Comfy Read 2

The conversion rate for people who visit the App Store page? 27.83% Again, very nice numbers. Almost one among three people visiting the App Store listing page for Comfy Read 2 are actually installing the app. This is a 300% improvement over the upfront paid app scenario. To keep the experiment fair, I pulled the first version of Comfy Read from the App Store the next day Comfy Read 2 was released.

So, what happens now? Will v2.0, the freemium app that a lot more users are downloading beat v1.0, the older version, financially? Not by a long shot.

Comfy Read 2 in-app purchases for 20 days

In the past 20 days, Comfy Read 2 has seen just 5 in-app purchases. May be it is too early to say that for some apps, free with in-app purchases won’t work. But the current trend I am seeing with v2 points to just that. Sometimes, less is more.

Freemium is not a panacea

Mobile Growth

Your app is live.

Mobile Growth

Your app is live. Now what? You can also find us at our meetups: and at our cross platform conference

Shuveb Hussain

Written by

Part-time philosopher, part-time programmer, part-time human being

Mobile Growth

Your app is live. Now what? You can also find us at our meetups: and at our cross platform conference