https://github.com/openstack/rally
Raw File
Tip revision: 7ad868bb9bc7834fa573f3612b8f3f22e2bb9719 authored by Andrey Kurilin on 18 January 2024, 12:11:51 UTC
Update u-c file
Tip revision: 7ad868b
CHANGELOG.rst
=========
Changelog
=========

.. Changelogs are for humans, not machines. The end users of Rally project are
   human beings who care about what's is changing, why and how it affects them.
   Please leave these notes as much as possible human oriented.

.. Each release can use the next sections:

    - **Added** for new features.
    - **Changed** for changes in existing functionality.
    - **Deprecated** for soon-to-be removed features/plugins.
    - **Removed** for now removed features/plugins.
    - **Fixed** for any bug fixes.

.. Release notes for existing releases are MUTABLE! If there is something that
   was missed or can be improved, feel free to change it!

unreleased
----------

Fixed
~~~~~

* Correct `python_requires` version to indicate correct minimum supported
  python version

[4.0.0] - 2024-01-10
--------------------

Fixed
~~~~~

* Parsing subunit v2 stream (rally-verify component) when the result is
  wrapped by ``memoryview`` python object.

Changed
~~~~~~~

* `xrally/xrally docker image <https://hub.docker.com/r/xrally/xrally>`_ switched
   to use python3.11-slim as a base image instead of python3.9-slim.

* Use 'draft-7' as a default jsonschema validator when there is no meta-schema
  field specified at ``$schema``.

Added
~~~~~

* CI checks for Python 3.11 compatibility

* Support for specifying platform of context as a part of required_context
  validator like bellow:

  .. code-block:: python

     from rally.task import scenario
     from rally.task import validation

     @scenario.configure(name="Dummy.scenario")
     @validation.add("required_context", contexts=["ctx_name@platform"])
     class ElasticsearchLogInstanceName(scenario.Scenario):
         def run(self):
              pass   

Removed
~~~~~~~

* Support for Python 3.6 and Python 3.7

[3.4.0] - 2023-05-23
--------------------

This is the last release with support of Python 3.6 and Python 3.7

Fixed
~~~~~

* rally.utils.sshutils.SSH.execute leaves fifo files.

  `Launchpad-bug #1956956 <https://launchpad.net/bugs/1956956>`_

Changed
~~~~~~~

`xrally/xrally docker image <https://hub.docker.com/r/xrally/xrally>`_ switched
to use python3.9-slim as a base image instead of ubuntu 20.04.

Added
~~~~~

* Pin SQLAlchemy to <2.0.0
* CI for running unit and functional tests using python 3.10
* CI jobs that check Rally installation compatibility with CentOS 9 Stream and
  Ubuntu Jammy

Removed
~~~~~~~

* CI jobs with installation compatibility checks for CentOS 7, CentOS 8
  (CentOS 8 Stream is checked instead), Ubuntu Bionic.

[3.3.0] - 2021-06-16
--------------------

Changed
~~~~~~~

* ``rally verify`` returns 0 on success, 1, 2 or 3 depending on detected issue.

* Switch docker image from ubuntu 18.04 to ubuntu 20.04

* Move from Freenode to OFTC irc network

Removed
~~~~~~~

* dependency on decorator library.

[3.2.0] - 2020-10-30
--------------------

Added
~~~~~

* Extend CI for checking installation on Ubuntu Focal environment.
* Extend ``rally task start`` command output with the progress of finishing
  workloads
* Introduce ``rally task restart`` command.

Fixed
~~~~~

* [verification component] Make config parser case sensitivity in
  configure-verifier

  `Launchpad-bug #1877930 <https://launchpad.net/bugs/1877930>`_

[3.1.0] - 2020-05-08
--------------------

Changed
~~~~~~~

* Validator for scenario arguments do not initialize scenario class anymore for
  discovering argument spec of the *run* method.

* Docker image includes the latest setuptools

Fixed
~~~~~

* [verification component] Failure while parsing subunit v2 stream in case of
  unwanted test_id

  `Launchpad-bug #1871406 <https://launchpad.net/bugs/1871406>`_

[3.0.0] - 2020-03-23
--------------------

Added
~~~~~

* CI for covering unit and functional tests against Python 3.8 environment.
  Everything works, so we have proved Python 3.8 support

* Add CI job for testing installation of Rally at Centos 8.

* Updating a *latest* tag of `docker image
  <https://hub.docker.com/r/xrally/xrally>`_ on every merged commit.

Changed
~~~~~~~

* *rally plugin show* command returns not-zero exit code in case of not found
  or multiple match errors

* `docker image <https://hub.docker.com/r/xrally/xrally>`_ is switched to use
  python3.6.

* *path_or_url* plugin follows redirects while validating urls now.

* *rally task sla-check* fails if there is no data.

Deprecated
~~~~~~~~~~

* Command *rally task results* is deprecated. Use *rally task report --json*
  instead.

* Module *rally.common.sshutils* is deprecated. Use *rally.utils.sshutils*
  instead.

* Module *rally.common.yamlutils* is deprecated. It was designed for CLI usage
  and moves to right place.

* Module *rally.common.fileutils* is deprecated.

* All modules from *rally.plugins.common.contexts* are deprecated. Use
  *rally.plugins.task.contexts* instead.

* All modules from *rally.plugins.common.exporters* are deprecated. Use
  *rally.plugins.task.exporters* instead.

* Module *rally.plugins.common.hook.sys_call* is deprecated. Use
  *rally.plugins.task.hooks.sys_call* instead.

* All modules from *rally.plugins.common.hook.triggers* are deprecated. Use
  *rally.plugins.task.hook_triggers* instead.

* All modules from *rally.plugins.common.runners* are deprecated. Use
  *rally.plugins.task.runners* instead.

* All modules from *rally.plugins.common.scenarios* are deprecated. Use
  *rally.plugins.task.scenarios* instead.

* All modules from *rally.plugins.common.sla* are deprecated. Use
  *rally.plugins.task.sla* instead.

* All modules from *rally.plugins.common.verification* are deprecated. Use
  *rally.plugins.verification* instead.

Removed
~~~~~~~

* Python 2.7, Python 3.4 and Python 3.5 support

* Devstack plugin. It was deprecated long time ago. rally-openstack project
  should be used instead

* *rally.common.utils.distance* method was deprecated since Rally 0.4.1

* *rally.common.utils.format_float_to_str* method was deprecated since
  Rally 0.11.2. *rally.utils.strutils.format_float_to_str* should be used
  instead.

* *rally.task.atomic.optional_action_timer* decorator was deprecated since
  Rally 0.10.0

* *rally.task.hook.Hook* class was deprecated since Rally 0.10.0.
  *rally.task.hook.HookAction* should be used instead.

* *rally.task.trigger* module was deprecated since Rally 0.10.0.
  *rally.task.hook.HookTrigger* should be used instead.

* *rally.common.i18n* module was deprecated since Rally 0.10.0

* *namespace* argument of *configure* decorator of Scenario, Context,
  Validators plugins. It was deprecated since Rally 0.10.0 in favor of
  *platform*.

* *install_rally.sh* script is too complicated and installs only rally
  framework without plugins.

Fixed
~~~~~

* inaccurate calculation of 90 and 95 percentiles in case of 10k+ iterations

[2.1.0] - 2019-11-19
--------------------

Please note that Python 2.7 will reach the end of its life on
January 1st, 2020. A future version of Rally will drop support for Python 2.7,
it will happen soon. Also, the same will happen with support of Python 3.4 and
Python 3.5

Removed
~~~~~~~

Library *netaddr* from direct project requirements. We never use it at Rally
framework.

Fixed
~~~~~

Support of latest alembic

`Launchpad-bug #1844884 <https://launchpad.net/bugs/1844884>`_

[2.0.0] - 2019-09-13
--------------------

Changed
~~~~~~~

python jsonschema dependency is not limited by *<3.0.0* anymore and you can
use draft-7 as for now.

Removed
~~~~~~~

* *rally task sla_check* command was deprecated in Rally 0.8.0 in favor of
  *rally task sla-check*.

* *rally-manage db* command (and the whole *rally-manage* entry-point) was
  deprecated in Rally 0.10.0 in favor of *rally db* command.

* *--namespace* argument was deprecated in Rally 0.10.0 in favor of
  *--platform* which has better meaning.
  Affected commands: *rally plugin show*, *rally plugin list*,
  *rally verify list-plugins*, *rally verify create-verifier*.

* *--tasks* argument of *rally task report* command and *--task* argument of
  *rally task use* command were deprecated in Rally 0.10.0 in favor of
  unified *--uuid* argument.

* *--junit* argument of *rally task report* command is deprecated in
  Rally 0.10.0 in favor of *rally task export --type junit-xml*

[1.6.0] - 2019-06-19
--------------------

Added
~~~~~

A list of tests to skip while running verification now supports regular
expressions.

Fixed
~~~~~

* incompatibility with SQLAlchemy 1.3
* several py3 issues of verification component

[1.5.1] - 2019-05-15
--------------------

Fixed
~~~~~

**rally deployment create --fromenv** creates wrong spec for
rally-openstack<=1.4.0 which doesn't pass **rally deployment check**.

`Launchpad-bug #1829030 <https://launchpad.net/bugs/1829030>`_


[1.5.0] - 2019-05-08
--------------------

Added
~~~~~

New two charts **EmbeddedChart** and **EmbeddedExternalChart** for embedding
custom html code or external pages as complete charts of scenarios.

[1.4.1] - 2019-02-28
--------------------

Fixed
~~~~~

* Python 3 issue of Verification component
* Docker README file

[1.4.0] - 2019-02-04
--------------------

Changed
~~~~~~~

* Add the --html-static option to commands ``rally task trends``, it could generate
  trends report with embedded js/css.

* Removed dependency to ``morph`` library.

Fixed
~~~~~

* ``rally`` command crashes while calling without any arguments

* Fix the ssh error while passing an dss key in ssh utils.

  `Launchpad-bug #1807870 <https://launchpad.net/bugs/1807870>`_


[1.3.0] - 2018-12-01
--------------------

Added
~~~~~

* Add the --deployment option to commands ``rally task report`` and
  ``rally task export`` that allows to report/export all tasks from defined
  deployment.

* Briefly: the new base image is published at `Docker Hub
  <https://hub.docker.com/r/xrally/xrally>`_
  Detailed story: Long time ago Rally team introduced first docker images which
    were hosted by `rallyforge account at Docker Hub
    <https://hub.docker.com/r/rallyforge/rally/>`_. Due to various
    circumstances we lost access to that account and Docker support restored
    access to it in a strange way (we lost all repositories and could not
    recreate them). That is why Rally team started publishing docker images
    from scratch. The new organization was created -`xRally
    <https://hub.docker.com/r/xrally>`_ . Since we already had plans to move
    OpenStack plugins to the separate repository, we started publishing images
    with in-tree OpenStack plugins to `xrally/xrally-openstack repository
    <https://hub.docker.com/r/xrally/xrally-openstack/>`_. As soon as, a
    separate package for OpenStack plugins was introduced, we switched the
    source of `xrally/xrally-openstack Docker Hub repository
    <https://hub.docker.com/r/xrally/xrally-openstack/>`_ to `rally-openstack
    git repository <http://github.com/openstack/rally-openstack>`_.
    As for Rally 1.0.0 we finally have pure framework without heavy
    dependencies and can start publishing separate images for Rally framework
    itself which can be used as a base image for all plugins.
    New images will be located at `xrally/xrally Docker Hub repository
    <https://hub.docker.com/r/xrally/xrally>`_.

Changed
~~~~~~~

* ``rally --version`` prints version of Rally framework with versions of
  installed plugins instead of printing just version of Rally framework.
* Dockerfile moved from the root directory to ./etc/docker/

Fixed
~~~~~

A floating bug with ``constant_for_duration`` runner.

`Launchpad-bug #1800447 <https://launchpad.net/bugs/1800447>`_

[1.2.1] - 2018-09-27
--------------------

Minor inner fixes

[1.2.0] - 2018-09-19
--------------------

Added
~~~~~

* New validator ``map_keys`` for checking keys of specific argument.
* Support of ElasticSearch 6.x cluster *elastic* exporter.

Changed
~~~~~~~

* Improved validation errors for task component.
* [ElasticSearch exporter] Do not send 'no-name-action' index when the item
  fails after some atomic actions completed and there is a root atomic.
  For example, there is 'wait-for-some-resource-ready' action. It consists of
  a bunch of get requests to update the current status. After specified timeout
  this action can fail if the resource is not in the right state. In such case,
  there is no reason to use 'no-name-action' for saving the error, the parent
  index (i.e 'wait-for-some-resource-ready') will already store it.

[1.1.0] - 2018-08-07
--------------------

Added
~~~~~

* Introducing ``rally env cleanup`` command for performing disaster cleanup.
* New CI jobs for checking compatibility with Python 3.4, 3.6, 3.7 .

Changed
~~~~~~~

* The output of json task result exporter (``rally task report --json``) is
  extended with information about environment where task was executed (new
  ``env_name`` and ``env_uuid`` properties)

* Add the --filter-by option to the command ``rally task detailed``, which
  allows us to show only those workloads which we are interested in (see the
  examples below).
  Examples:

  1. show only failed workloads
     ``rally task detailed --filter-by sla-failures``
  2. show only those workloads which include the next scenario plugin(s)
     ``rally task detailed --filter-by scenarios=scenario1[,scenarios2...]``

* `requirements
  <https://github.com/openstack/rally/blob/1.1.0/requirements.txt>`_ and
  `constraints (suggested versions)
  <https://github.com/openstack/rally/blob/1.1.0/upper-constraints.txt>`_ files
  are updated.

Removed
~~~~~~~

* Disturbing warning message about removing in-tree OpenStack plugins. This
  message became redundant after Rally 1.0.0 when such plugins were removed.
* OpenStack related configuration options for sample file.
* Deprecated in Rally 0.10 ``rally.task.exporter.Exporter`` class in favor of
  ``rally.task.exporter.TaskExporter``.

Fixed
~~~~~

* Building HTML reports for verifications at python 3 environment.
  `Launchpad-bug #1785549 <https://launchpad.net/bugs/1785549>`_

Deprecated
~~~~~~~~~~

* 'async' argument of API method task.abort in favor of 'wait' argument which
  doesn't conflict with a reserved keyword in python 3.7

[1.0.0] - 2018-06-20
--------------------

It finally happened. We are happy to inform you that OpenStack plugins has a
single home - https://github.com/openstack/rally-openstack .
All in-tree plugins are removed now and framework part become more lightweight.

What does it mean for you?!
~~~~~~~~~~~~~~~~~~~~~~~~~~~
If you are interested only in OpenStack plugins, just change the package you
are installing from ``rally`` to ``rally-openstack``. If you have custom
OpenStack plugins which inherits from upstream, change python imports from
``rally.plugins.openstack`` to ``rally_openstack``. That is all.

If you are interested not only in OpenStack, you can start using your favourite
tool for various platforms and systems. Here you can find our first attempts
to seize the world - https://github.com/xrally/xrally-docker and
https://github.com/xrally/xrally-kubernetes.

Changed
~~~~~~~

Since OpenStack plugins were moved to the separate repository, the new release
notes should become light as well, so there is no need in separate pages for
each release. All release notes will be aggregated in
`a single file CHANGELOG.rst
<https://github.com/openstack/rally/blob/master/CHANGELOG.rst>`_.

Also, it is sad to mention, but due to OpenStack policies we need to stop
duplicating release notes at ``git tag message``. At least for now.

Removed
~~~~~~~

* All OpenStack related plugins.

Fixed
~~~~~

* Validation of existing platforms in Python 3 environment.
* Support of testr for verifiers.

[0.0.0] - [0.12.1]
------------------

Release notes for Rally ``0.0.0``-``0.12.1`` are available at
https://github.com/openstack/rally/tree/master/doc/release_notes/archive
back to top