2015-01-23 12:19:54 +01:00
# unleash
2014-11-10 16:25:22 +01:00
2016-06-18 11:52:51 +02:00
__Warning: We are in the process of splitting up unleash into multiple packages in this repository, if you want to test the previous package see [previous tag ](https://github.com/finn-no/unleash/tree/v1.0.0-alpha.2 ) __
2016-06-18 11:36:50 +02:00
2016-11-07 09:54:07 +01:00
[![Build Status ](https://travis-ci.org/Unleash/unleash.svg?branch=master )](https://travis-ci.org/Unleash/unleash)
2016-11-10 21:15:16 +01:00
[![Coverage Status ](https://coveralls.io/repos/github/Unleash/unleash/badge.svg?branch=master )](https://coveralls.io/github/Unleash/unleash?branch=master)
[![Dependency Status ](https://david-dm.org/Unleash/unleash.svg )](https://david-dm.org/Unleash/unleash?path=packages/unleash-api)
[![devDependency Status ](https://david-dm.org/Unleash/unleash/dev-status.svg )](https://david-dm.org/Unleash/unleash?path=packages/unleash-api#info=devD)
2016-11-07 10:07:12 +01:00
![Admin UI ](https://cloud.githubusercontent.com/assets/572/5873775/3ddc1a66-a2fa-11e4-923c-0a9569605dad.png )
2015-01-23 12:19:54 +01:00
[Demo ](http://unleash.herokuapp.com/ ) instance on Heroku
2014-11-10 16:39:17 +01:00
2015-01-23 12:19:54 +01:00
This repo contains the unleash-server, which contains the admin UI and a place to ask for the status of features. In order to make use of unleash you will also need a client implementation.
2014-11-10 16:39:17 +01:00
Known client implementations:
- [unleash-client-java ](https://github.com/finn-no/unleash-client-java )
2015-03-11 08:57:29 +01:00
- [unleash-client-node ](https://github.com/finn-no/unleash-client-node )
2016-09-12 12:06:49 +02:00
## Project details
- [Project Roadmap ](https://github.com/finn-no/unleash/wiki/Roadmap )
2014-11-10 16:39:17 +01:00
2015-12-01 11:56:53 +01:00
## Run with docker
We have set up docker-compose to start postgres and the unleash server together. This makes it really fast to start up
unleash locally without setting up a database or node.
2016-06-18 01:11:49 +02:00
You find the docker files inside the `packages/unleash-docker` folder
2015-12-01 11:56:53 +01:00
```bash
$ docker-compose build
$ docker-compose up
```
2014-11-10 16:39:17 +01:00
## Development
2014-12-12 14:11:09 +01:00
### Create a local unleash databases in postgres
2014-10-31 13:03:54 +01:00
2014-10-31 16:35:35 +01:00
```bash
$ psql postgres < < SQL
CREATE USER unleash_user WITH PASSWORD 'passord';
CREATE DATABASE unleash;
GRANT ALL PRIVILEGES ON DATABASE unleash to unleash_user;
2014-12-12 14:11:09 +01:00
CREATE DATABASE unleash_test;
GRANT ALL PRIVILEGES ON DATABASE unleash_test to unleash_user;
2014-10-31 16:35:35 +01:00
SQL
```
2014-12-12 14:11:09 +01:00
Then set env vars:
2014-10-31 16:35:35 +01:00
```
export DATABASE_URL=postgres://unleash_user:passord@localhost:5432/unleash
2014-12-12 14:11:09 +01:00
export TEST_DATABASE_URL=postgres://unleash_user:passord@localhost:5432/unleash_test
2014-10-31 16:35:35 +01:00
```
2014-11-10 16:39:17 +01:00
### Commands
2014-10-31 16:35:35 +01:00
```
// Install dependencies
npm install
2016-11-10 21:15:16 +01:00
// Build unleash-frontend
// (yes this is a bit wierd and be easier when we have a release of the frontend artifact).
// You can of course "npm link unleash-frontend" instead
cd node_modules/unleash-frontend & & npm install
2014-12-12 14:11:09 +01:00
2016-11-10 21:15:16 +01:00
// Start server in development
npm start:dev
2014-10-31 16:35:35 +01:00
// Admin dashboard
http://localhost:4242
// Feature API:
2016-11-10 21:15:16 +01:00
http://localhost:4242/api/features
2014-10-31 16:35:35 +01:00
2016-06-18 11:36:50 +02:00
// Execute tests in all packages:
2014-10-31 16:35:35 +01:00
npm test
```
2014-11-10 16:39:17 +01:00
### Making a schema change
2014-10-31 16:35:35 +01:00
1. Create `migrations/sql/NNN-your-migration-name.up.sql` with your change in SQL.
2. Create `migrations/sql/NNN-your-migration-name.down.sql` with the rollback of your change in SQL.
2016-05-01 16:28:30 +02:00
3. Run `db-migrate create your-migration-name` and edit the generated file to have this line: `module.exports = require('../scripts/migration-runner').create('NNN-your-migration-name');`
2014-11-13 20:00:34 +01:00
4. Run `db-migrate up` .
2014-10-31 16:35:35 +01:00
5. Generate LB artifact using `scripts/generate-liquibase-artifact` (TODO: make this internal)
2016-06-18 11:36:50 +02:00
### Publishing / Releasing new packages
Please run `npm run nsp` nad `npm run lint` checks before publishing.
Run `npm run publish` to start the publishing process.
Lerna is setup with independent versioning so you will be prompted with version per package, and lerna will update all the versions across packages.
2016-06-18 11:52:51 +02:00
`npm run publish:dry`