Skip to content

Latest commit

 

History

History
78 lines (50 loc) · 2.83 KB

README.md

File metadata and controls

78 lines (50 loc) · 2.83 KB

React Native CircleCI Orb

A CircleCI Orb for building and deploying React Native apps.

This orb is a fork of React Native Community's CirleCI Orb with a few changes.

There are several nuances when it comes to CI/CD with React Native: which machines to use, caching, etc. This orb simplifies the process in addition to making the build process for mobile projects at Very consistent.

Getting Started

We recommend reading the Using Orbs guide from the CircleCI documentation to get an overview of how to use Orbs.

This Orb provides three different categories of tools to help you build and test your React Native app on CircleCI:

  • Executors: Machines which are configured for use with React Native.
  • Commands: Individual tasks which you can piece together in your own jobs to perform tasks like installing dependencies, building an APK, or running Detox tests.
  • Jobs: Groups of commands which are typically used together as a stage in a pipeline.

Setup

⚠️ Important: You will need a macOS plan enabled for building iOS apps and for e2e testing on iOS and Android. Private projects require a payment plan for this.

  1. Inside CirleCI, enable these settings:
  • 3rd party orbs: Your Org -> Settings -> Security -> Enable Usage of 3rd Party Orbs
  • Pipelines: Project Settings -> Advanced Settings -> Pipelines
  1. Use CircleCI version 2.1 at the top of your .circleci/config.yml
version: 2.1
  1. Invoke the orb in your config:
orbs:
  rn: verypossible-labs/[email protected]

You can now use elements from the orb in your workspace by prefixing them with rn. You can change rn to anything you'd like.

  1. Android only: Add this task in android/app/build.gradle
task downloadDependencies() {
  description 'Download all dependencies to the Gradle cache'
  doLast {
    configurations.findAll().each { config ->
      if (config.name.contains("minReactNative") && config.canBeResolved) {
        print config.name
        print '\n'
        config.files
      }
    }
  }
}

Usage

See the examples.

Roadmap

Please see the open issues for a list of known issues / proposed features.

Contributing

Contributions are welcome! Any contributions you make are greatly appreciated. Please see CONTRIBUTING.md and our Code of Conduct.

License

Distributed under the MIT license

Acknowledgements