mirror of
https://github.com/Unleash/unleash.git
synced 2025-10-22 11:18:20 +02:00
Unleash is the open source feature toggle service.
activation-strategiescontinuous-deliverycontinuous-deploymentdevopsdevtoolexperimentsfeaturefeature-flagsfeature-togglefeature-togglesfeature-togglinghacktoberfesttogglesunleashvariants
| .vscode | ||
| helpers | ||
| lib | ||
| migrations | ||
| public | ||
| scripts | ||
| test | ||
| .dockerignore | ||
| .editorconfig | ||
| .eslintrc | ||
| .gitignore | ||
| .travis.yml | ||
| app.js | ||
| artifact.json | ||
| docker-compose.yml | ||
| Dockerfile | ||
| finnbuild.json | ||
| LICENSE | ||
| package.json | ||
| Procfile | ||
| README.md | ||
| server-dev.js | ||
| server-impl.js | ||
| server.js | ||
| Vagrantfile | ||
| webpack.config.js | ||
unleash
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
- Create
migrations/sql/NNN-your-migration-name.up.sqlwith your change in SQL. - Create
migrations/sql/NNN-your-migration-name.down.sqlwith the rollback of your change in SQL. - Run
db-migrate create your-migration-nameand edit the generated file to have this line:module.exports = require('../scripts/migration-runner').create('NNN-your-migration-name'); - Run
db-migrate up. - Generate LB artifact using
scripts/generate-liquibase-artifact(TODO: make this internal)



