Horizon UI for Monasca
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
OpenDev Sysadmins b7bedc0e81 OpenDev Migration Patch 6 days ago
debian Initial installer work 5 years ago
grafana-dashboards fix a typo in drilldown.js 11 months ago
monitoring Fix the partial missing metrics in Create Alarm Definition flow 4 months ago
tools Make monasca-ui python3 compatible 1 year ago
.gitignore Update pep8 checks 1 year ago
.gitreview OpenDev Migration Patch 6 days ago
.zuul.yaml Import cover job 6 months ago
LICENSE pypi packaging files 4 years ago
README.rst Update README with latest deployment steps 8 months ago
babel-django.cfg This is a preparation for using Zanata 3 years ago
babel-djangojs.cfg This is a preparation for using Zanata 3 years ago
lower-constraints.txt Drop nose dependencies 8 months ago
manage.py Add Apache 2.0 license to source file 2 years ago
mkdocs.yml Change repositories from stackforge to openstack 3 years ago
requirements.txt Fix README.rst and add syntax check 8 months ago
run_tests.sh Move coverage reports to `cover` directory 1 year ago
setup.cfg Add python3.5 classifier 4 months ago
setup.py Updated from global requirements 2 years ago
test-requirements.txt Drop nose dependencies 8 months ago
tox.ini Remove setup.py check from pep8 job 5 months ago


Team and repository tags



Monasca UI is implemented as a Horizon plugin that adds panels to Horizon. It is installed into devstack by the monasca-api plugin.

Devstack Deployment Set Up

  • cd /opt/stack/horizon
  • Install Openstack upper-constraints requirements pip install -c https://git.openstack.org/cgit/openstack/requirements/plain/upper-constraints.txt -r requirements.txt
  • Clone monasca-ui: git clone https://git.openstack.org/openstack/monasca-ui.git
  • Add git+https://git.openstack.org/openstack/monasca-ui.git to requirements.txt.
  • Install monasca-ui required packages pip install -r requirements.txt (monasca-client packages will be installed.)
  • Edit openstack_dashboard/settings.py to include the following two lines:
    • import monitoring.enabled
    • monitoring.enabled, (Add this line to the settings_utils.update_dashboards list.)
  • Link monasca into Horizon:
ln -sf $(pwd)/../monasca-ui/monitoring/enabled/_50_admin_add_monitoring_panel.py \
ln -sf $(pwd)/../monasca-ui/monitoring/conf/monitoring_policy.json \
ln -sfF $(pwd)/../monasca-ui/monitoring $(pwd)/monitoring
  • Collect static files, run tests
python manage.py collectstatic --noinput
python manage.py compress
  • Restart apache service service apache2 restart

Development Environment Set Up

Get the Code

git clone https://git.openstack.org/openstack/monasca-ui.git  # clone monasca-ui
git clone https://git.openstack.org/openstack/horizon.git  # clone horizon
git clone https://github.com/monasca/grafana.git  # clone grafana
git clone https://github.com/openstack/monasca-grafana-datasource.git # clone grafana plugins

Set up Horizon

Since Monasca UI is a Horizon plugin, the first step is to get their development environment set up.

cd horizon
cp openstack_dashboard/local/local_settings.py.example openstack_dashboard/local/local_settings.py

Pro Tip: Make sure you have Horizon running correctly before proceeding. For more details visit: https://docs.openstack.org/horizon/latest/#setup

Set up Monasca-UI

  • Edit openstack_dashboard/local/local_settings.py to modify the OPENSTACK_HOST IP address to point to devstack.
  • Add monasca-client to requirements.txt. Get the latest version from: https://pypi.org/project/python-monascaclient
  • Link monasca into Horizon:
ln -sf $(pwd)/../monasca-ui/monitoring/enabled/_50_admin_add_monitoring_panel.py \
ln -sf $(pwd)/../monasca-ui/monitoring/conf/monitoring_policy.json \
ln -sfF $(pwd)/../monasca-ui/monitoring $(pwd)/monitoring
./run_tests #load monasca-client into virtualenv

Set up Grafana 4.1

Start Server

./run_tests.sh --runserver

Style checks

To check if the code follows python coding style, run the following command from the root directory of this project:

$ tox -e pep8

Coverage checks

To measure the code coverage, run the following command from the root directory of this project:

$ tox -e cover

Unit tests

To run all the unit test cases, run the following command from the root directory of this project:

$ tox -e py27,py35