1016 Commits

Author SHA1 Message Date
Mehdi Abaakouk
c49594a62f Remove usage of contentmanager for executors
The context manager in the executor fit only for the blocking executor.
Even the dispatcher needs to run code before and after the application
callback, eventlet and future executors have to run the pre/post code
into the main thread and can run the callback into an other thread,
and that force them to run __enter__ and __exit__ manually and deal
the exception path.

This change adds a helper object instead of the context manager.
It is designed to be explicit on what must be executed
before and after the callback and what can be done in a thread or not.

All the executor code is now in the impl_pooledexecutor.py
and use the futures "PoolExecutor" API.

This use futurist to provide a eventlet and aioeventlet futures friendly
object.

Change-Id: I8cd7640f36beeda47560e3c82671bad3530e38d1
2015-07-08 13:42:10 +02:00
Jenkins
3b891fcfcb Merge "Deprecated impl_qpid" 2015-07-06 17:06:35 +00:00
Jenkins
1d3c39a02e Merge "Imported Translations from Transifex" 2015-07-06 16:48:28 +00:00
Jenkins
456155e318 Merge "Remove py26 artefacts from oslo.messaging code" 2015-07-06 16:48:08 +00:00
Jenkins
c9ae87bb77 Merge "Remove 2.6 classifier" 2015-07-06 12:13:58 +00:00
Jenkins
952fd2d422 Merge "Add WebOb and greenlet to requirements" 2015-07-06 09:57:37 +00:00
Jenkins
d9d325082e Merge "Use ServiceBase from oslo.service as a parent class" 2015-07-06 09:11:02 +00:00
Victor Sergeyev
2734fc8f50 Remove py26 artefacts from oslo.messaging code
If we are not support py26 anymore, we can remove py26 tox environment
and some specific code.

Change-Id: I9b935c0bcbb4ddfd5388ad5ad76c6e7662c9f2fa
2015-07-06 12:04:02 +03:00
Joshua Harlow
7c2aa0ced0 Remove 2.6 classifier
This removes the 2.6 classifier so that support for 2.6
is not noted (when building packages, on pypi...) as happening
anymore for oslo.messaging (since check/gating support for
it has been turned off).

Depends-On: I4013bf38a197c9a9d82b3956ddbd25450d913df9

Change-Id: Ic4150332fff0724e5178e14f91ac54d5a80d408b
2015-07-06 12:02:54 +03:00
OpenStack Proposal Bot
6f63aa9ad7 Imported Translations from Transifex
For more information about this automatic import see:
https://wiki.openstack.org/wiki/Translations/Infrastructure

Change-Id: Ia8f191905ce39b849a290862bafd92bbd7b23471
2015-07-06 06:13:34 +00:00
Davanum Srinivas
9ec11b727a Add WebOb and greenlet to requirements
Running "pip-missing-reqs" tox target showed these references
in our code. Since we refer to them directly, we should add
them to our requirements.

Depends-On: I0f07858e96ea3baf46f8a453e253b9ed29c7f7e2
Depends-On: I33bd2d9dff9cb7dc1a50177db7286b7317966784
Change-Id: Ie043415f217c0ca71702c41dbec835a2c26ef9cb
2015-07-04 03:59:39 +00:00
Jenkins
8dc5923a98 Merge "Add a missed raise statement" 2015-07-02 16:39:40 +00:00
Sergey Vilgelm
8aaa7c369b Use ServiceBase from oslo.service as a parent class
Inherit MessageHandlingServer from ServiceBase.
Add the dummy "reset" method to the MessageHandlingServer.

Closes-Bug: #1470484
Change-Id: I4159450f54609c5185146472179d4299fe0c9d30
2015-07-02 18:35:09 +03:00
Sergey Vilgelm
862aca7f32 Manual update the requirements
According to the disscussion[1] we have to remove the requirements-PYN.txt

[1] http://lists.openstack.org/pipermail/openstack-dev/2015-July/068469.html

Change-Id: I9de07e595f6f75b91ef3f92fddcd95300b15e772
2015-07-02 16:51:42 +03:00
Flavio Percoco
10c39d5df4 Deprecated impl_qpid
As per discussions, this patch marks the qpid driver as deprecated. The
removal release has been set to M.

DocImpact
Change-Id: I81f667e0f440ae4e0a7226800a5f99809fc6dce2
2015-07-02 11:10:17 +00:00
Victor Sergeyev
de6d4f11af Add a missed raise statement
Change-Id: I8cec4aaae56dac32b98910f0a620020996ae2814
2015-07-02 13:57:27 +03:00
Flavio Percoco
c9021c2116 Remove qpid-config call
There's no need to install qpid-tools and run qpid-config for this case.
The check on the process output should be enough. This also removes
qpid-tools as a dependency for the qpid jobs.

Change-Id: Ie81a2630cb5d593729b18569cc82b83e9817f6ab
2015-07-01 11:46:34 +00:00
Jenkins
3e46c151a7 Merge "Add tox target to find missing requirements" 2015-06-30 19:27:59 +00:00
Jenkins
2ec7ed602f Merge "Correct RPCVersionCapError message" 2015-06-27 03:23:42 +00:00
Davanum Srinivas
f1c2b8ff91 Add tox target to find missing requirements
Change-Id: I49465a614540c6cc1a0e3f1b448f13db940c784c
2015-06-26 07:26:24 -04:00
Jenkins
9d08842715 Merge "Imported Translations from Transifex" 2015-06-26 10:57:31 +00:00
Flavio Percoco
079c04f0d0 Fix qpid's functional gate
The loggin verbosity changed in 0.32 which our gate is pulling from the
updates repository. This patch updates the script to make it work again.

Closes-bug: #1468917
Change-Id: I88a1bc794246beb156d4301bd503fa51a7cd2cce
2015-06-26 06:35:00 +00:00
OpenStack Proposal Bot
254dfb4584 Imported Translations from Transifex
For more information about this automatic import see:
https://wiki.openstack.org/wiki/Translations/Infrastructure

Change-Id: I7b7d8cf9ce634d5fd00b215681ccc3ea09a997c1
2015-06-26 06:16:01 +00:00
Corey Wright
8422e975b3 Correct RPCVersionCapError message
This change adjusts the exception message to be more in line with the
version compatibility algorithm so as to accurately portray the
problem to the log recipient.

The RPCVersionCapError message can be grossly incorrect when the
requested message's major version is lower than the specified version
cap's major version, declaring the requested message version as too
high, when the real error is that the major versions differ (as major
versions are assumed to be incompatible).

Example:

    RPCVersionCapError: Requested message version, 3.23 is too
    high. It needs to be lower than the specified version cap 4.0.

Change-Id: Iceef999ed385f2ba77449c568127f50f83d47196
Closes-Bug: 1468525
2015-06-24 17:18:46 -05:00
Doug Hellmann
3b6ca5b6de Drop use of 'oslo' namespace package
The Oslo libraries have moved all of their code out of the 'oslo'
namespace package into per-library packages. The namespace package was
retained during kilo for backwards compatibility, but will be removed by
the liberty-2 milestone. This change removes the use of the namespace
package, replacing it with the new package names.

The patches in the libraries will be put on hold until application
patches have landed, or L2, whichever comes first. At that point, new
versions of the libraries without namespace packages will be released as
a major version update.

Please merge this patch, or an equivalent, before L2 to avoid problems
with those library releases.

Blueprint: remove-namespace-packages
https://blueprints.launchpad.net/oslo-incubator/+spec/remove-namespace-packages

Change-Id: I05a408b76d4f31b803769a27759e91df770511bb
2015-06-19 18:06:50 +00:00
Jenkins
a3a3c3faa8 Merge "Use inferred=True by default" 2015-06-16 09:49:22 +00:00
Jenkins
f3d70a923d Merge "Enable amqp's protocol unit tests everywhere" 2015-06-16 09:42:28 +00:00
Flavio Percoco
c8845b4bef Use inferred=True by default
Rabbitmq's amqp1.0 plugin doesn't have support for vbin8, which is the
default encoding used by qpid-proton. In order to workaround this issue
we should use inferred=True.

Closes-bug: #1465409
Change-Id: Id265917244d7e152c5e13a10df367a3e59de8e50
2015-06-15 23:16:57 +02:00
Flavio Percoco
f06b19628f Enable amqp's protocol unit tests everywhere
Now that python-qpid-proton has taken an approach similar to zmq's, it's
possible to install it in boxes where the C libraries are not present in
the system. This patch takes advantage of that to enable amqp protocol's
tests everywhere.

Change-Id: Ibce4c791aafadf45fa876d6a4f5373fde94769ff
2015-06-15 20:52:24 +02:00
Jenkins
4062c1caa6 Merge "Switch badges from 'pypip.in' to 'shields.io'" 2015-06-15 17:22:13 +00:00
Jenkins
ffcb3a34b4 Merge "Switch to warnings module instead of versionutils" 2015-06-14 01:45:12 +00:00
Jenkins
3800dd61c5 Merge "Don't use devstack to setup our functional env" 2015-06-13 00:47:18 +00:00
Jenkins
38558db420 Merge "Add drivers to the documentation" 2015-06-12 21:10:53 +00:00
Jenkins
985b1597b4 Merge "Provide better detection of failures during message send" 2015-06-12 11:09:11 +00:00
Joshua Harlow
a3b56af37f Switch badges from 'pypip.in' to 'shields.io'
The badge hosting at 'pypip.in' has been broken for a while
now, it was supposed to be fixed in the following PR(s):

- https://github.com/badges/pypipins/issues/39
- https://github.com/badges/pypipins/issues/38
- https://github.com/badges/pypipins/issues/37

That does not appear to have actually happened and/or is not
getting addressed, so switch to a more reliable badge hosting
site that provides the same badge information.

Change-Id: Ia1fd048e8f1810c4aaabc24bd01c7f0c18b79fd6
2015-06-11 20:38:19 -07:00
Mehdi Abaakouk
80ece65a54 Don't use devstack to setup our functional env
This adds a setup script for each tox functional target to start a
rabbitmq-server, qpidd or redis daemon dedicated for the functional
testing.

This script is responsible to spawn a preconfigured daemon needed for
the functional tests.

This also changes the gate script to just install the required packages
instead of setup a devstack.

This also fixes the zmq config options loading in tests

Closes-bug: #1442612

Change-Id: I27eb2c1d3d0ca67aa361c83e41372138e03d9bdd
2015-06-11 12:01:01 +02:00
Davanum Srinivas
2bf8d2f917 Switch to warnings module instead of versionutils
versionutils.py is no longer in oslo-incubator. So we can
either use versionutils from oslo_log or debtcollector instead.
However, oslo.messaging does not use oslo.log currently and we
should not be adding yet another library as a dependency here,
so we should just use the base python warnings library for
our limited use of deprecated() method.

Change-Id: Ib8a487051c894fa4828da65d4890b7a4f57f1d12
2015-06-10 22:23:16 -04:00
OpenStack Proposal Bot
2f14ca162f Updated from global requirements
Change-Id: I95c7c2b87735dae3e98ad401d05cf382022c1199
2015-06-11 00:47:50 +00:00
Jenkins
62e7280e0f Merge "rabbit: Add logging on blocked connection" 2015-06-10 17:11:50 +00:00
Victor Sergeyev
2e5ba4538e Get mox from mox3, not from six.moves
oslotest 1.7.0 breakes oslo.messaging unittests, because it doesn't add
mox to six.moves anymore - see change Ic59c73abb9b09cb594bf7df4173d7f99f81d526c

This patch fixes imports on test run.

Change-Id: Ia40b7733bd2e74b1a1703f2e1a5245f01debbd36
2015-06-10 14:44:59 +03:00
Mehdi Abaakouk
1f8ccd3ac5 rabbit: Add logging on blocked connection
When the broker will block the connection for a server-side issue
like disk full, it notifies the client.

This change adds the callback methods when this occurs to inform
the deployer about the reason of this blocking.

Change-Id: I5164b9e1b720f022b45a5718258df036ba8808ed
Closes-bug: #1454449
2015-06-09 10:35:24 +02:00
Kenneth Giusti
c127594de6 Provide better detection of failures during message send
This change causes the message sender to block until the messaging
infrastructure (e.g. the broker) assumes ownership of the message (or
fails to accept it).  If the message is accepted, then the sender will
either pend for a response (in the case of RPC), or simply return (in
the case of notification).  If the message is rejected by the
messaging infrastructure a MessagingException will be raised at the
sender.

Change-Id: I3f4a1ed1c17e18f6d629f16e6b5c99de45b083d6
Closes-Bug: #1377228
2015-06-08 20:42:10 -04:00
Jenkins
85c069e154 Merge "Set places to 0 in self.assertAlmostEqual()" 2015-06-08 16:41:39 +00:00
Jenkins
02ab25ecc6 Merge "Reduce magic conf attribute usage" 2015-06-08 16:40:22 +00:00
Jenkins
63bbdfc7c9 Merge "rabbit: test for new reply behavior" 2015-06-05 11:20:37 +00:00
Jenkins
2d133bee84 Merge "Enable fanout_target scenarios in test_impl_rabbit" 2015-06-05 11:20:11 +00:00
Victor Sergeyev
3044abbaf4 Reduce magic conf attribute usage
Connection class contains `magic` attribute conf, which contains (or at
least should contain) all config options. Set these config options as
class attributes to make the code more clear

Change-Id: Ib67f148e2ecf3def37e57d6e3359bced932fbc90
2015-06-05 11:12:58 +03:00
Jenkins
f51a4ef6c6 Merge "Imported Translations from Transifex" 2015-06-04 18:11:35 +00:00
Jenkins
d685e6f80a Merge "replace rpc_response_timeout use in rabbit driver" 2015-06-04 17:50:16 +00:00
OpenStack Proposal Bot
9f146bc299 Imported Translations from Transifex
For more information about this automatic import see:
https://wiki.openstack.org/wiki/Translations/Infrastructure

Change-Id: I55f2a8f6f81f12735f0cf5c0ad20401283bb4e08
2015-06-04 06:08:05 +00:00