1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-16 00:06:40 +01:00
Unleash is the open source feature toggle service.
Go to file
2016-06-16 22:08:52 +02:00
.vscode upgrade knex 2016-05-06 09:39:37 +02:00
lib Remove finn config #133 2016-06-16 18:17:07 +02:00
migrations Move all custom-scripts to /scripts folder 2016-06-16 14:27:23 +02:00
public Fixed placeholder for favicon.ico 2016-06-16 14:27:23 +02:00
scripts Move all custom-scripts to /scripts folder 2016-06-16 14:27:23 +02:00
test Statefull modules should be injected from top 2016-06-16 14:35:50 +02:00
.dockerignore more finn cleanups 2016-06-16 22:08:52 +02:00
.editorconfig Add editorconfig 2015-02-05 14:29:35 +01:00
.eslintrc #108 Add eslint-config-spt and remove jshint (#111) 2016-04-24 22:41:37 +02:00
.gitignore ignored vscode files 2016-06-16 14:03:49 +02:00
.travis.yml Upgrade to node 5.8 2016-03-16 20:44:49 +01:00
app.js formatting 2016-06-16 14:35:50 +02:00
docker-compose.yml upgrade node to 4.2.2. Closes #106 2015-12-01 12:05:12 +01:00
Dockerfile Upgrade to node 5.8 2016-03-16 20:44:49 +01:00
LICENSE Update LICENSE 2014-09-29 16:46:35 +02:00
package.json remove unsued packages 2016-06-16 18:20:11 +02:00
Procfile add procfile 2016-04-27 22:04:54 +02:00
README.md Move all custom-scripts to /scripts folder 2016-06-16 14:27:23 +02:00
server-dev.js Fixed api from server-impl to make it easier to require. 2016-06-16 17:27:13 +02:00
server-impl.js Remove finn config #133 2016-06-16 18:17:07 +02:00
server.js Fixed api from server-impl to make it easier to require. 2016-06-16 17:27:13 +02:00
webpack.config.js #108 Add eslint-config-spt and remove jshint (#111) 2016-04-24 22:41:37 +02:00

unleash

Build Status Code Climate Coverage Status Dependency Status devDependency Status

Admin UI

Demo instance on Heroku

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.

Known client implementations:

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.

$ docker-compose build
$ docker-compose up

Development

Create a local unleash databases in postgres

$ psql postgres <<SQL
CREATE USER unleash_user WITH PASSWORD 'passord';
CREATE DATABASE unleash;
GRANT ALL PRIVILEGES ON DATABASE unleash to unleash_user;
CREATE DATABASE unleash_test;
GRANT ALL PRIVILEGES ON DATABASE unleash_test to unleash_user;
SQL

Then set env vars:

export DATABASE_URL=postgres://unleash_user:passord@localhost:5432/unleash
export TEST_DATABASE_URL=postgres://unleash_user:passord@localhost:5432/unleash_test

Commands

// Install dependencies
npm install

// Run migrations in your local DBs
./node_modules/.bin/db-migrate up
DATABASE_URL=$TEST_DATABASE_URL ./node_modules/.bin/db-migrate up

// Start server in dev-mode:
npm run dev

// Admin dashboard
http://localhost:4242

// Feature API:
http://localhost:4242/features

// Execute tests:
npm test

// Run tests with postgres running in docker:
npm run docker-test

Making a schema change

  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.
  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');
  4. Run db-migrate up.
  5. Generate LB artifact using scripts/generate-liquibase-artifact (TODO: make this internal)