Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/NewSpring/Holtzman

The main NewSpring namespace and utilities for all newspring packages.
https://github.com/NewSpring/Holtzman

javascript jest meteor react

Last synced: 4 months ago
JSON representation

The main NewSpring namespace and utilities for all newspring packages.

Awesome Lists containing this project

README

        

Holtzman
=======================
[![NewSpring
Church](https://img.shields.io/badge/NEWSPRING_CHURCH-Holtzmann-6BAC43.svg?style=flat&logoWidth=17&logo=%2BUAAAABGdBTUEAALGPC/xhBQAAAeFJREFUSA29lU0rRFEYx%2B81k/eFUpO3hUmREpGEYrKQ2VGslLKwkw/iC/AFbKVsvSTFIMVydsSCGHsvmev3THOv6cy5Z17c66nfnDnP23/Oveecsa0yzHGcYdIWYAo6oQMikIFXuIETOLJt%2B4mxOkNoCdJQrn2RuANDFSlSEIcUVGtZCjchWlKYpARkIAg7p0mLryjBBHxCkHZMs9oiUZzyGINamfqDt3WCf3lnqoA6/8Yx4Ikykd0Ytu2LoC0fKKUZ%2BuS7xpbx3Wv8rkt2Yi9MwCrI%2BdSZg7NNxEZKLK1fV63z0WcMng39VmoonNcVV%2BPjlrmibt1QmxTBaUOCNsQK6mASutUERHfx%2BV1vPSIo92LZhkgDyddwBnfM1zTFDxqfuGIVC1Ikr%2BB3i1vWhnRS7EOZu9OcoN%2BucpPUsUtxNCtz07RJVvhmytDEpKbQcker0GH6LsUZU0LQMRG8DbqpqZ8InpoSgo6J4CFkg27s1y/KQX3kLO2RsOiT1Eo8VhBTd2VEiUtq8f9fvoF7eY8zT%2BV9oQ7ySC1WecGwFapSvrl3hngs9fguYTBM4dwKRYBVvjPMgtz4oZknKAqIvjDMwA7IH%2Bb/GY94FA4gUPPeod9SUGsnloQ5iIMcEaERKrYfBD49JTL9FwYAAAAASUVORK5CYII%3D)](https://newspring.cc)
[![Build Status](https://travis-ci.org/NewSpring/Holtzman.svg)](https://travis-ci.org/NewSpring/Holtzman)
[![Coverage Status](https://coveralls.io/repos/github/NewSpring/Holtzman/badge.svg?branch=master)](https://coveralls.io/github/NewSpring/Holtzman?branch=master)

Holtzman is an application framework for building high speed, web + native, reactive applications. It is built using Reactjs, Redux, and Meteor. This repository contains the application framework and instructions for usage.

**Table of Contents**

[Prerequisites](#prerequisites)

[Quick Start](#quick-start)

[Structure](#structure)

[Local Development](#local-development)
* [Testing](#testing)
* [Linting](#linting)
* [Typing](#typing)

[Deploys](#deploys)

[Contributing](#contributing)

## Prerequisites

- [Meteor](https://www.meteor.com/): `curl https://install.meteor.com/ | sh`;
- [Install Node](https://github.com/creationix/nvm) via NVM. Latest stable: 8.4.0+
- On Mac run `xcode-select --install` to install command line tools.
- [Install Yarn](https://yarnpkg.com/en/docs/install) via your preferred method. We use [Homebrew](https://brew.sh/). Latest stable
version can be found [here](https://github.com/yarnpkg/yarn/releases/).
- \*[Xcode](https://developer.apple.com/xcode/) for iOS.
- \*[Cocoapods](https://cocoapods.org) for iOS.
- \*[Android Dev Tools](https://guide.meteor.com/mobile.html) instructions for
Android.

\* optional unless you want to build natively

## Quick Start

```
$ git clone [email protected]:NewSpring/Holtzman.git
$ cd Holtzmann
& yarn install
$ cp ./.meteor/sample.settings.json ./.meteor/settings.json
$ WEB=true meteor run --settings ./.meteor/settings.json
```
You may need some additional parameters for your meteor settings file.

## Structure

This repo contains the code base used to build v5 of the NewSpring site and native app. Our sites and native apps share much of the same functionality, and therefore share the same code.

- `/assets`: additional assets that don't need to be loaded over a web server
- `/client`: entry point for client
- `/imports`: basically all code, client and server
- `/public`: static assets to be loaded from web server
- `/.dev`: command line scripts used for deployment, testing, etc
- `/server`: entry point for server
- `/stylesheets`: sass for generating our css using sass and junction
- `*/__tests__`: tests adjacent to the module they are testing
- `*/__stories__`: react storybook stories adjacent to the module they are displaying
- `*/__mocks__`: module mocks for testing adjacent to the module they mock.
- `main.html`: root HTML file
- `mobile-config.js`: used to generate cordova apps
- `package.json`: used to manage yarn dependencies and etc.
- `yarn.lock`: used to make sure all developers are using the same package versions

### Imports directory

`/imports/` contains all of the working files for Holtzman. Inside are the following directories:
- `/components`: React components and higher-ordered components.
- `/data`: all data manipulation methods and utilities.
- `/deprecated`: old files that are to be removed. **Nothing new should be added here**.
- `/pages`: app pages
- `/util`: additional helper functions

## Local Development

### Basics

To install all dependencies, we use [Yarn](https://yarnpkg.com/). To get started:
1. Clone down the repo
2. Make sure you have the Yarn CLI [installed](https://yarnpkg.com/en/docs/install)
3. Run `yarn`.

Use the `meteor run` command. It may be helpful to
alias the command in your command line for quick startups.

Holtzman uses environment variables to control certain aspects of building.
Setting these variables will cause either the web version or the mobile version
to build.

`$ WEB=true`
`$ NATIVE=true`

you can leave these off instead of setting them to false. Its not recommended to
set these using `export`. Instead you can add them to the command like this:

- `WEB=true meteor run --settings ./.meteor/settings.json`
- `NATIVE=true meteor run ios-device --settings ./.meteor/settings.json`

*Building*

The build done for production on web is this:

`NODE_ENV="production" WEB=true meteor build .build --architecture os.linux.x86_64 --server https://my.newspring.cc --mobile-settings ./.meteor/settings.json`

The build for native is this:

`NODE_ENV="production" NATIVE=true meteor build .build --architecture os.linux.x86_64 --server https://native.newspring.cc --mobile-settings ./.meteor/settings.json`

- all builds are done from the project root.

### Testing

This project uses [Jest](https://facebook.github.io/jest/) for unit tests. These tests are located in `__tests__` subfolders adjacent to the thing they're testing.

To run tests, call `yarn test` or `yarn test -- --watch`. This will also run `eslint` and `flow` tests when complete.

### Linting

This project includes linting using [ESLint](http://eslint.org/). To manually run eslint, use `yarn lint`. There are tools available for many editors to show you errors while you work. Its recommended to use one of these tools and enable the option to use project based eslint which will use the eslint thats installed with yarn.

### Typing

This project contains static typing for some of our code. We use [Flow](https://flowtype.org/) for this. To enable flow to a file,
add `// @flow` to the very top of the file.

To run flow, use `yarn flow`.

## CI and Deploys

This project is automatically tested on Jenkins CI. It is tested on every branch push as well as every PR. If a PR is open, then pushes to the branch being requested also get tested.

- For authenticated users, detailed test results can be see in the [Jenkins Control Panel](https://ci.newspring.io)
- Test results can also be seen under the [branches tab](https://github.com/newspring/holtzman) in GitHub

This project can be deployed by Jenkins through its [web UI](https://ci.newspring.io). We have 2 different versions of the application: web and native. We also have 2 different environments to deploy to: beta and production. Currently, only the web platform can be deployed through Jenkins. Native builds currently are manually run and submitted.

## Deploy Process

This details how administrators to the repository with admin access inside Jenkins can deploy the project to all of our platforms.

- Tests are run for all pull requests.
- Passing tests for pull requests generate a GitHub tag in the format:

`GH-B`
- Building For Web
- Open the `Holtzman-Web` project in Jenkins.
- Click `Build with Parameters` on the sidebar.
- Choose the environment (beta or production)
- Choose the tag you wish to deploy
- Click Build

## Contributing

For more information about contributing PRs and issues, see our [Contribution Guidelines](CONTRIBUTING.md).

[Good First PR](https://github.com/NewSpring/Holtzman/labels/good%20first%20pr) is a great starting point for people new to this project.