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.33.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

⭐️ Star us on GitHub — it helps!

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!

Salient Features

  1. Frontend in React, Redux
  2. Backend in Node
  3. Native in React Native (Expo)
  4. Isomorphic/Progressive Web Apps
  5. Unit testing using Jest
  6. Code coverage reports using Codecov
  7. Regression testing using Cypress, Puppeteer & Percy
  8. Fully automated pipeline using Github actions
  9. Deployable in Dockerhub, Github Container Registry as Docker image
  10. Publishable in npm, Github package registry as npm package
  11. Publishable in Expo as OTA updates.
  12. Deployable in Google Container Registry using Terraform (WIP)
  13. Helm charts deployable in a Kubernetes Cluster (WIP)

How this works

This package was created with automated pipeline in mind. All you need to do is spin up a new project, sign up to a few providers, 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.

Setup Project

Install ipwa globally

`npm i -g ipwa`

Spawn 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 your 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

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

Keywords

FAQs

Package last updated on 26 Feb 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