I'm trying to build a React Native APK with Expo (without ejecting). I can manage to locally get my environment variables from .env file when I do expo build:android in my local machine with all the project files.
When I do a push to my GitLab repository, I have this .gitlab-ci.yml file
---
image: node:alpine
cache:
key: ${CI_COMMIT_REF_SLUG}
paths:
- ~/.npm
- .jest
stages:
- test
- deploy
before_script:
- npm ci
jest-tests:
stage: test
script:
- npx jest --ci --passWithNoTests
expo-deployments:
stage: deploy
script:
- apk add --no-cache bash
- npx expo login -u $EXPO_USERNAME -p $EXPO_PASSWORD
- npx expo build:android --EXPO_ANDROID_GOOGLE_API_KEY $EXPO_ANDROID_GOOGLE_API_KEY --EXPO_IOS_GOOGLE_API_KEY $EXPO_IOS_GOOGLE_API_KEY --release-channel staging --non-interactive
- EXPO_ANDROID_GOOGLE_API_KEY=$EXPO_ANDROID_GOOGLE_API_KEY; EXPO_IOS_GOOGLE_API_KEY=$EXPO_IOS_GOOGLE_API_KEY; expo build:android --release-channel staging --non-interactive
I don't have in the repo the .env file, because of security.
Where all this variables are stored within each environment in GitLab:
(working perfectly)
EXPO_USERNAME = the username of my development account to access Expo.
EXPO_PASSWORD = the password of the account to access Expo.
(not working at all when trying to build)
EXPO_IOS_GOOGLE_API_KEY = "abcdefghijklmnopqrstuvwxyz"
EXPO_ANDROID_GOOGLE_API_KEY = "abcdefghijklmnopqrstuvwxz"
I wonder how could I set the Google Maps environment variables into the app when running the expo build:android command via GitLab CI pipeline:
- npx expo build:android
Finally I could manage to make this work the following way:
---
image: node:alpine
cache:
key: ${CI_COMMIT_REF_SLUG}
paths:
- ~/.npm
- .jest
stages:
- test
- deploy
before_script:
- npm ci
- ANDROID_GOOGLE_MAPS_API_KEY=${CI_COMMIT_BRANCH}_EXPO_ANDROID_GOOGLE_API_KEY
- IOS_GOOGLE_MAPS_API_KEY=${CI_COMMIT_BRANCH}_EXPO_IOS_GOOGLE_API_KEY
- export android=$( eval echo \$$ANDROID_GOOGLE_MAPS_API_KEY )
- export ios=$( eval echo \$$IOS_GOOGLE_MAPS_API_KEY )
jest-tests:
stage: test
script:
- npx jest --ci --passWithNoTests
expo-deployments:
stage: deploy
script:
- echo "EXPO_ANDROID_GOOGLE_API_KEY=$android" >> .env
- echo "EXPO_IOS_GOOGLE_API_KEY=$ios" >> .env
- apk add --no-cache bash
- npx expo login -u $EXPO_USERNAME -p $EXPO_PASSWORD
- npx expo build:android --release-channel staging --non-interactive
Where...
...CI_COMMIT_BRANCH is development|staging|production depending which branch in gitlab I am using.
...development_EXPO_ANDROID_GOOGLE_API_KEY | staging_EXPO_ANDROID_GOOGLE_API_KEY | production_EXPO_ANDROID_GOOGLE_API_KEY are variables that are stored at the Gitlab project.
... I am generating the .env file every time I run the script and saving there my variables with the respective value with: echo "EXPO_ANDROID_GOOGLE_API_KEY=$android" >> .env.
This way I don't need to push my .env file into Gitlab. I only need to define my variables in the settings of the project at Gitlab.
Hope this help to someone!
Related
I'm having trouble automating react native release build apps using firebase app distribution with Gitlab CI/CD. I get this error Error: set the --app option to a valid Firebase app id and try again
Also see image:
I've setup ".gitlab-ci.yml" file as below
## install project deps with --frozen-lockfile to make sure we will have the same packages version ( very recommended on running yarn install on ci)
##run: yarn install --frozen-lockfile
before_script:
- yarn install --frozen-lockfile
- yarn global add firebase-tools
stages:
- buildApp
buildApp project:
stage: buildApp
image: reactnativecommunity/react-native-android
cache:
key:
files:
- yarn.lock
paths:
- node_modules
policy: pull #`pull` the jobs pull the cache at the beginning but do not push the changes again.
script:
- yarn build:apk
- yarn install --pure-lockfile --cache-folder .yarn
- ./bin/app_distribution.sh
# - firebase use kavyatara --token "$FIREBASE_TOKEN"
# - firebase deploy --token "$FIREBASE_TOKEN"
artifacts:
paths:
- android/app/build/outputs/apk/release/app-release.apk
Also
app_distribution.sh file
#!/bin/bash
RELEASE_NOTE="New update Android build"
firebase appdistribution:distribute android/app/build/outputs/apk/release/app-release.apk \
--token "$FIREBASE_TOKEN" \
--app "$FIREBASE_APP_ID" \
--release-notes "$RELEASE_NOTE" --testers-file testers.txt
I am trying to integrate react-native-code-push into my gitlab-cli.yml script:
image: openjdk:8-jdk #Defining the Docker Image
react-native-code-push:
stage: react-native-code-push
script:
- appcenter login --token {APPCENTER_ACCESS_TOKEN_PLACEHOLDER}
- appcenter codepush release-react -a {example.example.com}/{example-name} -d Staging
- appcenter logout
only:
- dev
I am receiving the next error in my gitlab pipeline:
$ appcenter login --token APPCENTER_ACCESS_TOKEN_PLACEHOLDER
/bin/bash: line 121: appcenter: command not found
How could i handle this case, so gitlab has access to the AppCenter, can login into it, do the codepush and also logout of it.
Solved it.
image: node:lts
stages:
- react-native-code-push
before_script:
- npm install -g appcenter-cli
- yarn install
react-native-code-push:
stage: react-native-code-push
script:
- appcenter login --token {APPCENTER_ACCESS_TOKEN_PLACEHOLDER}
- appcenter codepush release-react -a example.example.com/example -d Staging
- appcenter logout
only:
- dev
I am using Gitlab CI to automate my expo project builds, for that I am using following commands to build and submit iOS app on TestFlight.
expo build:ios --non-interactive --skip-credentials-check
eas submit -p ios --latest --profile stage --non-interactive
The first command will return a build url, that url must be used in second command to submit build to TestFlight.
The issue is I am not able to get the url from expo build command, I tried using variable, but if I am using variable the command is not waiting for finish the command, so before the build finish next line is executed.
using variable
VER_BUILD_URL=$(expo build:ios --non-interactive
--skip-credentials-check)
Solution can be following:
I can get the url returned from expo build and can pass that url to eas submit
OR
expo must have a command to get the url directly from that command
We solved this by getting the build id from the output of the new eas build command and storing it in a variable. The variable can then be used in the next stage. Not sure if you can use the same solution with expo build:ios, as we just started building our first app with expo and directly used eas.
.template:
image: node:16-alpine
cache:
key: ${CI_COMMIT_REF_SLUG}
paths:
- .yarn
before_script:
- yarn install --cache-folder .yarn
- apk add --no-cache bash git
build:
extends: .template
stage: build
script:
- npx eas-cli build -p ios --non-interactive --profile production | tee $CI_PROJECT_DIR/.build-result-ios
- echo "IOS_BUILD_ID=$(sed -n "s/^Build details.*\/builds\/\([a-f0-9-]*\)$/\1/p" $CI_PROJECT_DIR/.build-result-ios)" >> build.env
artifacts:
reports:
dotenv: build.env
deploy:
image: node:16-alpine
stage: deploy
script:
- npx eas-cli submit -p ios --non-interactive --profile production --id=$IOS_BUILD_ID
dependencies:
- build-ios
needs:
- job: build-ios
artifacts: true
As a side note: With eas build you can also use the --auto-submit parameter.
I would like to print Git hash into footer of my Vue.js app. I have followed instructions in this question:
How to use environment variables at build time in a VueJS project
But just can't get it to work. process.env.VUE_APP_GIT_COMMIT variable is not set for the app. Variables set in .env files work just fine.
.gitlab.ci.yml:
build-frontend:
image: node:10.16.3-stretch
stage: build
before_script:
- cd frontend
variables:
VUE_APP_GIT_COMMIT: "$CI_COMMIT_SHORT_SHA"
script:
- npm install -g #vue/cli#3.11.0
- npm install
- npm run staging
artifacts:
paths:
- frontend/dist/
expire_in: 1 hour
deploy-staging-frontend:
image: python:3.7.4
stage: deploy
script:
- pip install awscli
- aws s3 sync --delete frontend/dist s3://bucket
Ok, after some research it seemed that the vue-cli-service build command only looks into the dot-files in the root of your project. (various .env files)
You could set all the variables in the Gitlab CI options and then, as Sergey stated in the comments, copy those variables to the .env file. Now, when vue-cli builds the project, it injects these values in the transpiled scripts.
You could issue a command like this before you build the project:
env | grep 'VUE_APP_' > .env
I also use a staging environment that is built when pushing into the staging branch. Therefore I have these variables set into Gitlab:
VUE_APP_VAR1=foo
VUE_APP_VAR2=bar
VUE_ACCEPT_VAR1=foo
VUE_ACCEPT_VAR2=bar
Since vue-cli wants the variables to start with VUE_APP_ I do a replace with sed:
env | grep 'VUE_ACCEPT_' | sed 's/VUE_ACCEPT_/VUE_APP_/' > .env
I built a Vue.js Vuex user interface. It works perfectly (on my laptop). I want to deploy it on Gitlab pages.
I used the file described here (except that I upgraded the Node.js version):
build site:
image: node:10.8
stage: build
script:
- npm install --progress=false
- npm run build
artifacts:
expire_in: 1 week
paths:
- dist
unit test:
image: node:10.8
stage: test
script:
- npm install --progress=false
- npm run unit
deploy:
image: alpine
stage: deploy
script:
- apk add --no-cache rsync openssh
- mkdir -p ~/.ssh
- echo "$SSH_PRIVATE_KEY" >> ~/.ssh/id_dsa
- chmod 600 ~/.ssh/id_dsa
- echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config
- rsync -rav --delete dist/ user#server.com:/your/project/path/
The job is marked as run successfully on the pipeline. However when I click on the pages URL I get a 404 HTTP error code.
What am I missing?
I was facing a similar issue when I was trying to deploy my Vue.js application to Gitlab pages. After weeks of trial and error, I have got it to work.
Seeing your above script your building the app, unit testing it and trying to deploy it to an external server. If you need it in Gitlab pages as well you have to use the pages job.
Here is my pages job for deploying a vue.js app to Gitlab pages:
pages:
image: node:latest
stage: deploy
script:
- npm install --progress=false
- npm run build
- rm -rf public
- mkdir public
- cp -r dist/* public
artifacts:
expire_in: 1 week
paths:
- public
only:
- master
Hope this is what you're looking for.
You can deploy without the pipeline. In order for this to work you have to first build your application for production. If you have used Vue cli this is done by invoking the build command. ex. npm run build
This will generate a dist folder where your assets are. This is what you have to push in your repository. For example, look at my repository.
https://github.com/DanijelH/danijelh.github.io
And this is the page
https://danijelh.github.io/