ad8cb0f621
Change-Id: I7a3e858e4dbbb6d41e1704ddbe004a8aeb9f9728
98 lines
2.3 KiB
ReStructuredText
98 lines
2.3 KiB
ReStructuredText
===========================
|
|
Freezer - Horizon Dashboard
|
|
===========================
|
|
|
|
Requirements
|
|
============
|
|
|
|
Freezer Dashboard requires a freezer API endpoint which you can install following this steps::
|
|
|
|
https://github.com/stackforge/freezer/blob/master/freezer_api/README.rst
|
|
|
|
API registration
|
|
================
|
|
|
|
Register freezer api endpoint::
|
|
|
|
https://github.com/stackforge/freezer/blob/master/freezer_api/README.rst#3-api-registration
|
|
|
|
If keystone service-create and endpoint-create are not available you can set as a fallback the following on::
|
|
|
|
# vim /opt/stack/horizon/openstack_dashboard/local/local_settings.py
|
|
|
|
# add FREEZER_API_URL = http://<api_url>:<port>
|
|
|
|
|
|
Dev Installation
|
|
================
|
|
|
|
In the installation procedure we'll assume your main Horizon dashboard
|
|
directory is /opt/stack/horizon/openstack_dashboard/dashboards/.
|
|
|
|
|
|
To install freezer dashboard for development you need to do the following::
|
|
|
|
# git clone https://github.com/stackforge/freezer
|
|
|
|
# cd freezer/horizon_web_ui
|
|
|
|
# cp _50_freezer.py /opt/stack/horizon/openstack_dashboard/local/enabled/
|
|
|
|
# modify _50_freezer.py (line 9) and point the path to the freezer repo.
|
|
|
|
# cd /opt/stack/horizon/
|
|
|
|
# ./run_tests.sh --runserver 0.0.0.0:8000
|
|
|
|
# pip install -r requirements.txt
|
|
|
|
|
|
Production Installation
|
|
=======================
|
|
|
|
To deploy freezer dashboard in production you need to do the following::
|
|
|
|
# git clone https://github.com/stackforge/freezer
|
|
|
|
# cd freezer/horizon_web_ui
|
|
|
|
# cp _50_freezer.py /opt/stack/horizon/openstack_dashboard/local/enabled/
|
|
|
|
# modify _50_freezer.py (line 9) and point the path to the freezer repo.
|
|
|
|
# restart apache2 service
|
|
|
|
|
|
A new tab called "Disaster Recovery" will be on your panels.
|
|
|
|
|
|
Running the unit tests
|
|
======================
|
|
|
|
1. Create a virtual environment::
|
|
|
|
virtualenv --no-site-packages -p /usr/bin/python2.7 .venv
|
|
|
|
2. Activate the virtual environment::
|
|
|
|
. ./.venv/bin/activate
|
|
|
|
3. Install the requirements::
|
|
|
|
pip install -r test-requirements.txt
|
|
|
|
4. Run the tests::
|
|
|
|
python manage.py test . --settings=freezer_ui.tests.settings
|
|
|
|
Test coverage
|
|
-------------
|
|
|
|
1. Collect coverage information::
|
|
|
|
coverage run --source='.' --omit='.venv/*' manage.py test . --settings=freezer_ui.tests.settings
|
|
|
|
2. View coverage report::
|
|
|
|
coverage report
|