Some content in this post might be outdated. It was written before Codemagic became from a Flutter CI/CD to a CI/CD
for all mobile app platforms after introducing codemagic.yaml.
Oct 14, 2019
In this article, I will be comparing a single workflow and multiple parallel workflows for building, testing & publishing an app on Codemagic.
So, let’s first understand what are workflows on Codemagic.
What is Workflow
A workflow is a set of settings that determines how the app is to be built, tested and published. You can create several workflows for building different configurations of your app.
You can use workflows to get the following advantages:
- Separate the builds for different platforms
- Separate the release and debug builds
- To build and test different branches of a project
- To run different tests specific to a platform
- To build, test & publish apps in parallel
Creating a workflow
Workflows are really simple to create on Codemagic.
-
Log in to Codemagic.
-
From the Applications dashboard, search for the project that you want to build.
-
Go to the Settings of the project.
-
To create a new workflow, click on Duplicate workflow in the Workflow settings.
-
You can change the name of the workflow from the Workflow settings by clicking on it.
-
Now, you can define the configurations for this workflow.
So, you have now successfully created a workflow.
Build concurrency with Magic seats
Recently, Codemagic has introduced Magic seats for leveraging the Teams functionality.
Teams that consist of only regular seats have a build concurrency of 1 so they can run their builds one at a time. This means that if a new commit to the project is made, it cannot be built before the previous build has finished. With Magic seats, you can speed up the process by running builds in parallel.
Parallel builds
Running parallel builds on Codemagic is very simple.
-
Create more than one workflow with different configurations.
Now, for running them concurrently, just run the workflows one after another.
-
Go to one workflow and click on Start new build.
-
Make sure the correct workflow is selected and again click on Start new build.
-
After starting the build of one workflow, click on Settings.
-
From here we can start the build of the second workflow by selecting it and then again clicking on Start new build.
-
In this way we can start a number of parallel workflows together by repeating the steps from 2 to 5.
Review of parallel builds
Now, as we know how to run a number of workflows concurrently, let’s do some research to see if parallel workflows are really time saving.
For reviewing this, we will be creating two workflows (for two different platforms), one for Android & the other one for iOS.
And, we will also be leaving the Default Workflow with configuration of both the platforms as it is, so that we compare the result with it later.
Let’s get started.
-
Create one workflow by clicking on Duplicate workflow.
-
Name the first duplicate workflow to be Android Workflow
-
Now, scroll down and click on the Build tab.
-
Here, select only the Android platform. And click on Save.
-
Now, complete defining other Android-specific configurations for this workflow.
-
Create another duplicate workflow from the Default Workflow.
-
Name it iOS Workflow.
-
Select only iOS platform in the Build tab and complete defining other iOS-specific configurations.
-
Run the two workflows one after another, by clicking on Start new build and then selecting the appropriate workflow.
-
Wait for the builds to finish.
You can see the workflows while they are building in one place by going to the Builds tab.
The results are in now, and we can compare to see which one is faster, parallel workflows or a single workflow for both platforms.
So, from the results we see that the Android Workflow took 4m 10s to run and the iOS Workflow took 3m 35s to run. When we compare it with the Default Workflow which took 7m 29s to run, we can clearly see that using parallel workflows for each platform is much more efficient than running a single workflow for both platforms as the effective time in the case of parallel workflows is only 4m 10s, which is about 44% faster in this case.
In this case parallel workflow is about 44% faster than running single workflow for iOS and Android separately
Conclusion
Concurrent builds on Codemagic is very easy to set up by creating multiple workflows and then running them one after another. With the help of Magic seats, you can increase the number of parallel builds you and your team can run at a time. So, why use a single build when you can run concurrent builds saving a lot of your build time.
This article is written by Souvik Biswas. He is a passionate Mobile App Developer (Android and Flutter) and has worked on a number of mobile apps throughout his journey. Loves open source contribution on GitHub. He is currently pursuing a B.Tech degree in Computer Science and Engineering from Indian Institute of Information Technology Kalyani. He also writes Flutter articles on Medium – Flutter Community.
Discussion about this post