Skip to content

Latest commit

 

History

History
83 lines (53 loc) · 2.87 KB

CONTRIBUTING.md

File metadata and controls

83 lines (53 loc) · 2.87 KB

Contributing to Flocx-ui

Every developer should be able to contribute to flocx-ui while ensuring that the master branch is always in a pristine state.

To adhere to this idea please follow the procedure given below when contributing to flocx-ui.

  • Create an issue at https://github.com/CCI-MOC/flocx-ui/issues to propose new features, report bugs, and seek clarifications.
  • Keep your master branch in sync with the upstream master: https://github.com/CCI-MOC/flocx-ui
  • To contribute any changes to flocx-ui, first checkout a new branch from the master branch of your local fork of FLOCX.
  • Once the patch is ready, create a Pull Request on the upstream repository.
  • When the tests pass and review comments are addressed it will be merged with the master.

Project Structure

This project follows the Horizon plugin structure outlined in the Horizon docs.

Setting up the development environment

Prerequisites

  • docker — as well as docker-compose
  • flocx-keystone-dev - Flocx-keystone-dev should be running on port 5000.
  • flocx-market — Flocx-market should be running on port 8080.
  • node.js — The JavaScript tests and linters require both node and npm to be installed
  • tox - Tox handles the python virtualenv.

You can also specify a host and a port for the flocx-market using the FLOCX_API_HOST and FLOCX_API_PORT.

The defaults are http://localhost and 8081 respectively.

Install dependencies

$ npm install
# Running this will install all python dependencies as well using tox

Using docker

Make sure that the flocx-keystone-dev's public url is set to http://host.docker.internal:5000 using the following command before running the docker-compose up for keystone:

export KEYSTONE_PUBLIC_URL=http://host.docker.internal:5000
  1. Startup the docker-compose setup

Flocx-ui comes with a docker-compose file to automatically setup a horizon dashboard at http://localhost:8000 and install the flocx-ui plugin:

$ docker-compose up

The server should now be running at: http://localhost:8000

  1. Configure the ironic-ui service and endpoint
$ openstack service create --name ironic --description ironic baremetal
$ openstack endpoint create ironic public http://baremetal
  1. Login to horizon using development credentials:

Username: admin

Password: secret

To view the flocx page, navigate to Project > Other > Flocx

Running tests and linters

Use the included npm scripts below to run tests and linters in JavaScript and Python.

Run tests

  • npm run test:js
  • npm run test:py

Run linters

  • npm run lint:js
  • npm run lint:py