Build a Mendix Native App with Bitrise

Last modified: January 9, 2025

Introduction

This guide helps you set up Bitrise to automate building a Mendix native app in the cloud. Bitrise is a popular continuous integration service optimized for mobile apps.

Prerequisites

Before starting this guide, make sure you have completed the following prerequisites:

Prerequisites for iOS

Prerequisites for Android

Set Up Your Build Project

To set up your build project, do the following:

  1. Create a workspace (if needed) in Bitrise.

  2. Create a new project in the workspace.

  3. Select the GitHub project generated by Build Native App as the repository. It is recommended to use the GitHub App Integration:

    Select repository
  4. Select the master branch and let Bitrise auto-detect the configuration.

  5. Confirm that the correct configuration has been detected:

    • Project type: React Native
    • Project directory: .
    • Root directory of Android project: android
    • Module: app
    • Variant: appstoreRelease
    • Project or Workspace path: ios/NativeTempalte.xcworkspace
    • Scheme name: nativeTemplate
    • Distribution method: Choose the distribution method you want to use
    • Build stack: Choose the latest Xcode version compatible with your Mendix version
  6. Finish creating the project.

  7. Abort the build if one starts automatically (you first need to setup code signing and adjust the workflow).

Setup Code Signing for iOS

Applications distributed to iOS devices must be signed with a certificate and a provisioning profile. To do so, you need to register as a developer with Apple and join one of their development programs (see Prerequisites).

Bitrise supports automatic provisioning via a constant connection with the App Store. To set it up, follow the guide from Bitrise.

If you prefer to manually set up provisioning, follow this guide from Bitrise instead.

Setup Code Signing for Android

Applications distributed to Android devices must be signed with a keystore. To distribute Android apps via the PlayStore, you must also register as an Android developer (see Prerequisites).

Bitrise lets you store your Android keystore in the build project. Follow this guide from Bitrise to upload and store the keystore.

Adjust Workflow

The default workflow (deploy) needs to be extended to work for Mendix native mobile apps. Open the build project and click on Workflow to access the workflow editor. With it, you can customize the commands you run in order to build your application.

Any additional workflows that may have been created can be removed. Select the workflow from the dropdown and click Properties > Delete workflow.

Add Missing npm Command

Add a missing npm command by doing the following:

  1. Add a new step after the step “Run npm command”.
  2. Choose Run npm command from the list of steps.
  3. Set the npm command with arguments to run to run configure.
  4. Save changes.

Remove Unneeded Operating System Targets

By default, Bitrise targets both Android and iOS. If you do not need to build for both operating systems (OS), remove all actions related to that OS and skip all steps below related to it as well.

For example, if you only target iOS, you can remove the actions Install missing Android SDK components and Android Build. This will significantly speed up your builds and save credits.

Add Android Code Signing (Android only)

To add Android code signing, do the following:

  1. Add a new step after the step Android Build.
  2. Choose Android Sign from the list of steps.
  3. Save changes.

Bitrise will use the uploaded keystore to sign the .apk.

Add Cocoapods Install (iOS only)

To add Cocoapods install on iOS, do the following:

  1. Add a new step before the step Xcode Archive.
  2. Choose Run CocoaPods install from the list of steps.
  3. Set Workdir to $BITRISE_SOURCE_DIR/ios
  4. Save changes.

This step will install the dependencies required for iOS.

Add iOS Code Signing (iOS Only)

  1. Add a new step before the step Xcode Archive (after Run CocoaPods install).
  2. Choose Manage iOS Code Singing from the list of steps.
  3. Set the distribution method to the method selected in section 3.
  4. Save changes.

Bitrise will use the provided iOS Signing information to sign the iOS app.

After these changes, your workflow should look like this (if you target both operating systems):

Completed workflow

Build Your App

Builds can be started manually or automatically. To start a build manually, open the build project and click Start build and confirm the dialog. A typical build will take approximately 20 minutes, but can take longer for complex applications with many dependencies.

When building, you can follow the build output and watch for progress and potential problems being reported there.

To set up automatic builds after running Build Native App, follow these steps:

  1. Open the Workflow Editor of your build project.
  2. Open the Triggers page.
  3. Click Add push trigger.
  4. Select Push branch for Condition 1 and change the Push branch to master.
  5. Select the deploy workflow and confirm.

Now, every time some runs Build Native App to update the application bundle, a new build will be triggered in Bitrise.

Additional Considerations

Our MVP Marcel Groeneweg has written a blog post about optimizing Mendix native mobile builds with Bitrise. Check it out on Medium (Mendix cannot take responsibility for third-party recommendations).