My next adventure: Sparta Sales

This week was my first week at Sparta Sales. Sparta is a sales gamification platform that helps sales organisations drive sales growth and build stronger sales culture.

I had my last day at Citrix on July 1st. Long story short, I had a blast at Citrix, but the opportunity at Sparta was just to good for me to pass on. At Citrix I got to work with some amazingly talented people, travel the world and create one of the best mobile conference apps in the world (check it out! Even Apple thinks so). I will miss it all dearly.

Sparta was founded in Stockholm, Sweden in 2014. Today we are proud to say that we have some of the Nordic’s largest sales organisations as customers such as Bonnier, Modern Times Group, Tele2, Canal Digital, Com Hem, Hyundai and many more.

The company has a warm and welcoming environment, a multicultural and diverse team and a can-do mentality where everything is possible. I am very proud to be part of this team.

We are currently looking for a talented frontend engineer, so if you know of any, please send them my way!



Continuous deployment for free when building a mobile iOS app and API


I am a big fan of CI and CD and the overall mentality that you should always be deploying. There should never be any stress involved in the fact that you are deploying. You should always be able to trust your code.

While building my latest hobby project, one of the first thing I started doing was to setup all the environments that was needed to make sure I don’t break anything as the project grows. Since it is a hobby project, I would prefer to get as far as I can with free tiers available at different providers.

In this article I will outline my setup and how you can grow into the paid plans at each provider while taking away the initial costs. Making sure that the only initial cost is a smaller amount of development time.

Technology Stack

The backend is a Ruby on Rails API that is serving JSON. This gives me a few things I need to test in the backend:

  • API Requests
  • Controllers
  • Models

All of the above are tested using RSpec.

The mobile iOS app uses Cedar as a test framework and I pesonally strive to maintain a good test coverage (of course, where it makes sense).

CircleCI (iOS)

CircleCI just opened up mobile iOS support as a beta feature and you can request access to it by sending them an email and then activate it:

CircleCI now offers Beta support for building and testing iOS (and OSX) projects. To enable this feature, go to Project Settings > Experimental Settings and enable the “Build iOS project” experimental setting. This will cause builds for this project to be run on OSX machines rather than the usual Linux containers, and iOS-related build and test commands will be automatically inferred.

They offer one private project for free which suits us perfectly, since we only need one for the iOS app.

Fabric (iOS)

Beta by Crashlytics is a cross-platform toolset built to make beta distribution easy. I followed a sample project that was available for CircleCI and Testflight and modified that to get my CircleCI to push my builds to Fabric.

Codeship (Web)

Codeship is a continuous integration & delivery as a service provider. They also offer a free tier with these restrictions:

  • 1 concurrent build
  • 1 test pipelines
  • 100 private builds / month
  • 5 private projects

It will not scale very well if we start deploying a lot, but it will get you quite far to start off with. They have an awesome support for Ruby on Rails so in this case, its extremely easy to get up and running!

Heroku (Web)

Heroku is a cloud platform as a service. That means you do not have to worry about infrastructure; you just focus on your application. They offer instant Deployment with Git push, where we will instead push our code to GitHub and let Codeship run the CI and deploy to Heroku instead if everything gets a green light

Slack (All)

In my opinion, Slack is like IRC but for companies. You can create open channels for the projects, groups and topics that the whole team shares. I suggest you create a #notifications channel where all your CI posts their status updates when a build fails (or passes). This way the entire team knows when something goes awry.


The Swedish Startup Scene In Numbers

SUP46 in Stockholm put together some awesome facts about the Swedish Startup Scene: