Watcher Horizon plugin.
Go to file
Li Wei 7fa7901476 Drop *openstack/common* in flake8 exclude
There is not *openstack/common* directory in watcher-dashboard,
we should drop it for improving searching efficiency.

Change-Id: Ie37d37b28640b00c87f30bb5c263647a54cab4e7
2016-09-22 16:59:11 +08:00
devstack Add policies for API access control to watcher-dashboard 2016-07-26 06:25:05 +00:00
doc/source Watcher Dashboard - Initial commit 2016-02-17 13:38:41 +00:00
tools Add policies for API access control to watcher-dashboard 2016-07-26 06:25:05 +00:00
watcher_dashboard Update table's actions 2016-09-22 08:36:27 +00:00
.gitignore Watcher Dashboard - Initial commit 2016-02-17 13:38:41 +00:00
.gitreview Added .gitreview 2016-02-04 09:33:04 +00:00
babel-django.cfg Watcher Dashboard - Initial commit 2016-02-17 13:38:41 +00:00
babel-djangojs.cfg Watcher Dashboard - Initial commit 2016-02-17 13:38:41 +00:00
HACKING.rst Watcher Dashboard - Initial commit 2016-02-17 13:38:41 +00:00
LICENSE Watcher Dashboard - Initial commit 2016-02-17 13:38:41 +00:00
manage.py Watcher Dashboard - Initial commit 2016-02-17 13:38:41 +00:00
MANIFEST.in Watcher Dashboard - Initial commit 2016-02-17 13:38:41 +00:00
README.rst Add policies for API access control to watcher-dashboard 2016-07-26 06:25:05 +00:00
requirements.txt Updated from global requirements 2016-08-22 09:42:07 +02:00
run_tests.sh Added Goals and Strategies to Dashboard 2016-05-25 11:47:39 +02:00
setup.cfg modify the home-page info with the developer documentation 2016-09-20 14:38:18 +05:30
setup.py Updated from global requirements 2016-07-27 11:11:06 +02:00
test-requirements.txt Remove discover from test-requirements 2016-08-22 08:12:06 +00:00
tox.ini Drop *openstack/common* in flake8 exclude 2016-09-22 16:59:11 +08:00

OpenStack Dashboard plugin for Watcher project

Installation

First off, create a virtual environment and install the Horizon dependencies:

$ git clone https://github.com/openstack/horizon
$ cd horizon
$ python tools/install_venv.py

We will refer to the folder you are now in as <HORIZON_DIR>. If you want more details on how to install Horizon, you can have a look at the Horizon documentation, especially their quickstart tutorial.

Then, you need to install Watcher Dashboard on the server running Horizon. To do so, you can issue the following commands:

$ git clone git://git.openstack.org/openstack/watcher-dashboard
$ cd watcher-dashboard
$ pip install -e .

We will refer to the folder you are now in as <DASHBOARD_DIR>.

The next step is now to register the Watcher Dashboard plugins against your Horizon. To do so, you can execute the tools/register_plugin.sh:

$ cd <DASHBOARD_DIR>
$ ./tools/register_plugin.sh . <HORIZON_DIR>

This script will then create the needed symlinks within Horizon so that it can load the Watcher plugin when it starts.

If you wish to have Horizon running being an Apache server, do not forget to start the service via the following command:

$ sudo service apache2 restart

For more details on how to configure Horizon for a production environment, you can refer to their online installation guide.

DevStack setup

Add the following to your DevStack local.conf file

enable_plugin watcher-dashboard git://git.openstack.org/openstack/watcher-dashboard

Unit testing

First of all, you have to create an environment to run your tests in. This step is actually part of the run_tests.sh script which creates and maintains a clean virtual environment.

Here below is the basic command to run Watcher Dashboard tests:

$ ./run_tests.sh

The first time you will issue the command above, you will be asked if you want to create a virtual environment. So unless you have installed everything manually (in which case you should use the -N flag), you need to accept

Integration testing

Before being able to run integration tests, you need to have a Horizon server running with Watcher Dashboard plugin configured. To do so, you can run a test server using the following command:

$ ./run_tests.sh --runserver 0.0.0.0:8000

By default, integration tests expect to find a running Horizon server at http://localhost:8000/ but this can be customized by editing the watcher_dashboard/test/integration_tests/horizon.conf configuration file. Likewise, this Horizon will be looking, by default, for a Keystone backend at http://localhost:5000/v2.0. So in order to customize its location, you will have to edit watcher_dashboard/test/settings.py by updating the OPENSTACK_KEYSTONE_URL variable.

To run integration tests:

$ ./run_tests.sh --integration

You can use PhantomJS as a headless browser to execute your integration tests. On an Ubuntu distribution you can install it via the following command:

$ sudo apt-get install phantomjs

Then you can run your integration tests like this:

$ ./run_tests.sh --integration --selenium-headless

Please note that these commands are also available via tox.

Note

As of the Mitaka release, the dashboard for watcher is now maintained outside of the Horizon codebase, in this repository.

Policies

You can enable policies on Watcher Optimization panel, by updating in the <HORIZON_DIR>/openstack_dashboard/settings.py configuration file the following parameters

POLICY_FILES = { ... 'infra-optim': 'watcher_policy.json',

}

You can also update the file <HORIZON_DIR>/openstack_dashboard/conf/watcher_policy.conf to customize your policies.

Watcher project: https://git.openstack.org/openstack/watcher

Watcher at wiki.openstack.org: https://wiki.openstack.org/wiki/Watcher

Launchpad project: https://launchpad.net/watcher

Join us on IRC (Internet Relay Chat):

Network: Freenode (irc.freenode.net/watcher)
Channel: #openstack-watcher

Or send an email to openstack-dev@lists.openstack.org.