Boris Pavlovic af1c8b7652 Improve Rally Logging (part 2)
- Remove translations

  Nobody is using translations for Rally and I don't think that
  anybody is going to use it. Target auditory for Rally are
  developers/operators which usually know well english.
  For me this looks like waste of resources, performance
  degradation (cause we are calling _()), complexity
  (+1 thing that you need to know)

- Pass to log already formatted strings

  It's very bad because in case of wrong formatting, it
  doesn't fail instead just writes errors to the logs,
  as well information about trace is lost, so it's super
  hard to fix it

  Log wrapper doesn't allow to use LOG anymore for
  formatting strings

  All places are fixed

- Improve logging of exceptions

LOG.exception() already logs exception, which means it's bad idea to
pass str(e) to it. Instead we should provide clear description of what
happend. Improved few places to write warnings or exceptions in case
of different level of logs. In few places just use LOG.exception

- Part of log messages were improved and simplified

Depends-On: If23d874e8b73de12ba2b8c4e028a55543af6381b
Change-Id: Ibc1e1f4f554649d14b8fe4801557b83922ecefe3
2017-10-05 22:57:39 +00:00
..
2017-09-19 18:01:25 -07:00
2014-10-07 13:50:40 +00:00
2017-06-30 12:38:07 -07:00
2017-09-26 17:01:56 +03:00
2017-05-02 15:19:54 +03:00
2017-03-22 01:01:20 +08:00

Rally Gate Jobs

For each patch submitted for review on Gerrit, there is a set of tests called gate jobs to be run against it. These tests check whether the Rally code works correctly after applying the patch and provide additional guarantees that it won't break the software when it gets merged. Rally gate jobs contain tests checking the codestyle (via pep8), unit tests suites, functional tests and a set of Rally benchmark tasks that are executed against a real devstack deployment.

rally-gate.sh

This script runs a set of real Rally benchmark tasks and fetches their results in textual / visualized form (available via a special html page by clicking the corresponding job title in Gerrit). It checks that scenarios don't fail while being executed against a devstack deployment and also tests SLA criteria to ensure that benchmark tasks have completed successfully. Jenkins uses this script by runnint the 'gate-rally-dsvm-rally' job, 'gate-rally-dsvm-manila-multibackend' job and 'gate-rally-dsvm-neutron-rally' job.

rally_verify.py

This script runs various "rally verify" commands. This set of commands allow us to perform Tempest tests of OpenStack live cloud and display verification results. The verification results obtained by running various "rally verify <cmd>" commands including "start", "show", "list" are compared using the "rally verify results" command, which are then saved in csv, html and json formats in the "rally-verify" directory. Jenkins uses this script by running the 'gate-rally-dsvm-verify' job.

test_install.sh

This script tests the correct working of the install_rally.sh, used for the installation of Rally. Jenkins tests this script by running it against Centos7 and Ubuntu 16.04 in the corresponding jobs 'gate-rally-install-centos-7' and 'gate-rally-install-ubuntu-xenial'.

Jenkins

Jenkins is a Continuous Integration system which works as the scheduler. It receives events related to proposed changes, triggers tests based on those events, and reports back. For each patch that is uploaded for review on Gerrit, Jenkins runs it against the various rally gate jobs listed below along with their functions and local equivalents:

  • gate-rally-pep8 : code style check

    (equal to tox -epep8)

  • gate-rally-docs : documention generation

    (equal to tox -edocs)

  • gate-rally-python27 : unit tests against python27

    (equal to tox -epy27)

  • gate-rally-python35 : unit tests against python35

    (equal to tox -epy35)

  • rally-coverage : generates unit test

    coverage (equal to tox -cover)

  • gate-rally-install-centos-7 : testing of test_install.sh

    (described above) against Centos7

  • gate-rally-install-ubuntu-xenial : testing of test_install.sh

    (described above) against Ubuntu 16.04

  • gate-rally-dsvm-rally : runs rally-gate.sh

    (described above) against OpenStack deployed by devstack with nova-network (It is standard dsvm job)

  • gate-rally-dsvm-manila-multibackend(non-voting) : runs rally-gate.sh against

    manila

  • gate-rally-dsvm-neutron-rally : runs rally-gate.sh against

    OpenStack deployed by devastack with neutron

  • gate-rally-dsvm-cli : runs tests/functional/*

    (equal to tox -ecli)

  • gate-rally-dsvm-verify(non-voting) : runs rally_verify.py and

    tests Rally and Tempest integration in all possible ways

  • gate-rally-tox-self(non-voting) : not yet used

and a success in these tests(except non-voting) would mean that the patch is approved by Jenkins.