Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

ipwa

Package Overview
Dependencies
Maintainers
1
Versions
71
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ipwa

🚀 Isomorphic progressive web native cloud app generator. Enough said!

  • 2.35.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
11
increased by57.14%
Maintainers
1
Weekly downloads
 
Created
Source

Pipeline codecov This project is using Percy.io for visual regression testing. cypress

iPWA

🚀 Spin up an isomorphic progressive web app or native app deployable in the cloud, publishable as an npm package or docker container with a fully automated supercharged pipeline, all in under an hour, so you can focus on creating stuff!

How this works

This package was created with automated pipeline in mind. One codebase for web and native apps where when something gets merged to master, it gets to production. All you need to do is spin up a new project, set the tokens and secrets correctly and the rest is all magic. When you push code to master, it will just be deployed everywhere after a series of checks. What happens behind the scene is once you push code to Github, it triggers Github actions. If its the master branch, it runs a basic Sanity Check where it builds the client and server code base, runs lint and unittests and reports to Codecov. This sanity check is followed by staging in Heroku. The application is dockerized and deployed as a docker container on Heroku. Once done, regression tests are performed on this staging environment. Unit tests, Cypress tests, Puppeteer and Percy visual regression tests are performed on this environment. Once passed, the docker image is pushed to Dockerhub and Github Container Registry, deployed into Firebase and published to Expo as over-the-air update. To top it all, its published to npm as well.

Setup Project

Install ipwa globally

npm i -g ipwa

Create a new ipwa app

ipwa my-app install

This will create a new project called my-app in the current directory and install npm dependencies.

Create a new project in Github. Do not push anything yet.

Create new Codecov app and set CODECOV_TOKEN secret in Github. This is where our unit test reports are stored.

Create new Heroku app and set HEROKU_APP_NAME in ./.github/workflows/build-master.yml and HEROKU_API_KEY secret in Github. This is where our app will be staged.

Set config_environment__STAGE_URL environment variable or set STAGE_URL in .configrc

Run npm run test:cypress:open, create a new project in Cypress and set CYPRESS_PROJECT_ID and CYPRESS_TOKEN secrets in Github.

Create new Percy app and set PERCY_TOKEN secrets in Github. This is where our visual regression test reports are stored.

Sign up to Docker and set DOCKER_USER and DOCKER_PASS secrets in Github. This is where our docker image is pushed.

Set GITHUB_DOCKER_IMAGE_NAME & DOCKERHUB_DOCKER_IMAGE_NAME in ./.github/workflows/build-master.yml. The docker image above will be pushed to Github package registry as well.

Sign up to npm and set NPM_TOKEN secret in Github.

Sign up to expo and set EXPO_CLI_USERNAME and EXPO_CLI_PASSWORD secrets in Github. This is where our expo app will be published.

Create new firebase app and set FIREBASE_APP_NAME in ./.github/workflows/build-master.yml and FIREBASE_TOKEN secrets in Github. This will be our production environment.

Push the new project you just created to Github.

Local setup

Install ipwa

npm i -g ipwa

Spawn a new ipwa app.

ipwa my-app install

Run app locally

Make sure npm dependencies are installed.

npm run dev in one shell,

npm run nodemon in another.

Run app as docker container

  • Set the following environment variables.
    • DOCKERHUB_DOCKER_IMAGE_NAME
npm run build:docker

Run as a helm app

Make sure minikube and helm are installed.

Set HELM_APP_NAME environment variable.

npm run build:helm

Unit tests

npm run test

Run Codecov

  • Set the following environment variables.
    • CODECOV_TOKEN
npm run test:codecov

Run Cypress tests

  • Set the following environment variables.
    • CYPRESS_PROJECT_ID
    • CYPRESS_TOKEN
npm run test:cypress:open

Run Percy

  • Set the following environment variables.
    • PERCY_TOKEN
npm run test:percy

Run Puppeteer

Set config_environment__STAGE_URL environment variable or set STAGE_URL in .configrc

npm run test:puppeteer

Deploy on Heroku

  • Set the following environment variables.

    • HEROKU_APP_NAME
    • HEROKU_API_KEY
npm run release:heroku

Deploy on Firebase

  • Set the following environment variables.
    • FIREBASE_TOKEN
npm run release:firebase

Release image on Dockerhub Container Registry

Set the following environment variables:

  • DOCKER_USER
  • DOCKER_PASS
  • DOCKERHUB_DOCKER_IMAGE_NAME
npm run release:dockerhub

Release image on Github Container Registry

Set the following environment variables:

  • GITHUB_REPO
  • GITHUB_DOCKER_IMAGE_NAME
  • GITHUB_USER
  • GITHUB_TOKEN
npm run release:github

Release npm package to npm registry

  • Set the following environment variables:
    • NPM_TOKEN
npm run release:npm

Publish app on Expo

  • Set the following environment variables.
    • EXPO_CLI_USERNAME
    • EXPO_CLI_PASSWORD
npm run release:expo

⭐️ Star us on GitHub — it helps!

Keywords

FAQs

Package last updated on 01 Mar 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc