Commit Graph

45329 Commits

Author SHA1 Message Date
Matt Riedemann
70afc0d540 Handle conflicts for os-assisted-volume-snapshots
Since a guest-assisted disk snapshot is performed on the compute
that the instance is running on, there are only certain states
that the instance can be in to perform this operation. For example,
if the instance is shelved_offloaded then the instance does not
have a host and we can't cast to a compute to perform the snapshot.

Given how unrestrictive this API was before, the only restriction
we place on the state is that the instance does not have a task_state
set. We allow any vm_state for performing the operation as long as
there is a host and no task_state.

As noted in the code, we'd normally return a 409 in this case but
according to our microversion docs [1] that would be a new error
code and require a version bump, so this change just uses 400 and
leaves a TODO to make this 409 in a later mass return code update
microversion.

[1] https://docs.openstack.org/developer/nova/api_microversion_dev.html#f1

Change-Id: I1dc54a38f02bb48921bcbc4c2fdcc2c946e783c1
Closes-Bug: #1657585
2017-03-02 15:10:26 -05:00
Jenkins
68e808623e Merge "Stop using mox stubs in nova.tests.unit.api.openstack.compute.test_serversV21" 2017-03-02 14:33:26 +00:00
Jenkins
9650dc3897 Merge "Remove mox from nova/tests/unit/objects/test_service.py" 2017-03-02 13:41:04 +00:00
Jenkins
288cfbc785 Merge "Remove mox from nova/tests/unit/virt/vmwareapi/test_configdrive.py" 2017-03-02 13:40:32 +00:00
Jenkins
25e5f4ac12 Merge "Remove mox from nova/tests/unit/db/test_db_api.py" 2017-03-02 13:39:53 +00:00
Jenkins
5823d36723 Merge "Add some metadata logging to root cause ssh failure" 2017-03-02 13:39:18 +00:00
Gao Yuan
919377e39c Stop using mox stubs in nova.tests.unit.api.openstack.compute.test_serversV21
switch mox to mock

Part of blueprint remove-mox-pike

Change-Id: Iad06d4883a0fbebd932ef8aa98c19980048ffae7
2017-03-02 17:02:08 +08:00
Jenkins
cb01463af4 Merge "Check for 204 case in DynamicVendorData" 2017-03-02 07:08:26 +00:00
Jenkins
957bd1fdcb Merge "Updated from global requirements" 2017-03-01 21:44:17 +00:00
Matt Riedemann
3c1943f8d9 Check for 204 case in DynamicVendorData
Before b9587587c2 we were doing
an explicit check on the response status codes, but after
that change, we just rely on the bool override in requests.Reponse
which is True for any repsonse code less than 400. In the 204 case
we won't have response text, so we should handle that before trying
to load the json repsonse text. Because TypeError and ValueError are
handled it would just result in a warning if you got a 204, unless
CONF.api.vendordata_dynamic_failure_fatal was True in which case
it's a failure (as shown in the unit test update here).

Change-Id: Iba95fd0112ae4510ef21fdb44fcb281b14567c07
Closes-Bug: #1669084
2017-03-01 14:16:29 -05:00
Kevin Benton
99989cb652 Add some metadata logging to root cause ssh failure
Instances aren't getting SSH keys in some circumstances.
This adds a few debug statements to see if the Nova metadata
service thinks an instance has keys.

Related-Bug: #1668958
Change-Id: I3095d3024b62d5ebb4ea9e388a40ed94ef8f832b
2017-03-01 18:29:06 +00:00
Jenkins
3a2a181796 Merge "Handle VolumeBDMIsMultiAttach in os-assisted-volume-snapshots" 2017-03-01 14:46:12 +00:00
OpenStack Proposal Bot
fc60d683e2 Updated from global requirements
Change-Id: I31717cc909f38acce18c384df62e091a529b68b2
2017-03-01 04:12:35 +00:00
Jenkins
37cd9a961b Merge "Updated from global requirements" 2017-03-01 03:35:25 +00:00
Jenkins
a1d374cef6 Merge "[placement] Add Traits related table to the api database" 2017-03-01 02:16:24 +00:00
OpenStack Proposal Bot
5245fba88d Updated from global requirements
Change-Id: I2485a4e5fbe826b3dc73ff205bbb4a725801256a
2017-02-28 23:22:42 +00:00
He Jie Xu
7dafc66d5c [placement] Add Traits related table to the api database
This patch adds DB table `traits` and `resource_provider_traits` into
the api database.

The traits table is used to represent the trait. The resource_provider_traits
table is used to represent the relationship between trait and resource provider.

Part of implementation blueprint shared-resources-pike

Change-Id: I5c34bdd1423beab53cc4af45e016d9a9bba5ffda
2017-02-28 17:43:54 -05:00
Jenkins
55521a1a15 Merge "api-ref: Body verification for os-hypervisors.inc" 2017-02-28 21:29:29 +00:00
Jenkins
c2f09262e2 Merge "Remove mox from nova.tests.unit.virt.xenapi.test_vmops[1]" 2017-02-28 21:29:00 +00:00
Jenkins
e503acfd1b Merge "Stop using mox in compute/test_hypervisors.py" 2017-02-28 20:13:33 +00:00
Jenkins
689530de67 Merge "Remove mox in nova/tests/unit/compute/test_shelve.py (3)" 2017-02-28 20:13:05 +00:00
Sujitha
5ac78a114c Remove mox from nova/tests/unit/db/test_db_api.py
Part of blueprint remove-mox-pike

Change-Id: I5d053faaf7657ad21e812221ec637b1f4aa92d84
2017-02-28 19:31:44 +00:00
Jenkins
a3655c3114 Merge "Make compute/api instance get set target cell on context" 2017-02-28 19:21:35 +00:00
Jenkins
1ef9cbdcf4 Merge "Tests: remove .testrepository/times.dbm in tox.ini" 2017-02-28 19:21:09 +00:00
Jenkins
5d9bfa0f4e Merge "Remove run_tests.sh" 2017-02-28 16:38:24 +00:00
Jenkins
45cb83829e Merge "Add device_id when creating ports" 2017-02-28 16:37:57 +00:00
Jenkins
424972e2f0 Merge "Fix typos detected by toolkit misspellings." 2017-02-28 14:55:19 +00:00
Duong Ha-Quang
79a7fa874e Remove mox in nova/tests/unit/compute/test_shelve.py (3)
Stop using mox in test_shelve.py in below test cases:

- test_unshelve
- test_unshelve_volume_backed

Change-Id: I2394b0588bc7210efd16456af2fc12dc7071681c
Partially-Implements: blueprint remove-mox-pike
2017-02-28 14:36:18 +00:00
Jenkins
c990c73f4f Merge "Enable coverage report" 2017-02-28 13:54:26 +00:00
Dao Cong Tien
407b92cc6a Stop using mox in compute/test_hypervisors.py
Change-Id: I2834a33961b90821ac8084f65133c16210ee097d
Partially-Implements: blueprint remove-mox-pike
2017-02-28 13:32:05 +00:00
John Garbutt
15280bde1d Add device_id when creating ports
Currently, when nova is creating ports, we don't update the device_id
until we bind the port much later in the process. It's better to set the
device_id when we create the port for a variety of reasons, such as it
stops other instances trying to use the port we just created.

The real reason it is changed here is because in a few edge cases Nova
still fails to correctly clean up ports we created. By adding the
device_id we should be able to more easily track down the cause of the
leaking ports, and it may help fix the issue too.

Change-Id: Ie697ad6520622d6f01f06b19b143d5f8ac21e053
Related-Bug: 1603909
2017-02-28 13:19:20 +00:00
Jenkins
8b34afcfa1 Merge "Updated from global requirements" 2017-02-27 22:58:44 +00:00
Dan Smith
3c7b73b4e7 Make compute/api instance get set target cell on context
Some of the apis use common.get_instance() which calls compute/api
get(). This makes that also set_target_cell() on the context like
the internal-to-servers utility method before. Now things like
server delete will work with cells.

Change-Id: I72e33b00577f53039a2d3caa4f9e716898b7f713
2017-02-27 13:41:24 -08:00
Jenkins
30cb671bda Merge "Remove invalid tests-py3 whitelist item" 2017-02-27 20:52:14 +00:00
Sujitha
263b8e6970 Remove mox from nova.tests.unit.virt.xenapi.test_vmops[1]
Remove mox from GetConsoleOutputTestCase in
nova/tests/unit/virt/xenapi/test_vmops.py

Part of blueprint remove-mox-pike

Change-Id: I3bc75d00d368a9c229d312ed6525fa8ddd5d4844
2017-02-27 19:33:24 +00:00
Jenkins
9d1e813e61 Merge "Ignore deleted services in minimum version calculation" 2017-02-27 19:12:29 +00:00
Maciej Szankin
98cbf72e57 Tests: remove .testrepository/times.dbm in tox.ini
Existance of this file causes py3* tests to fail if
run after py27. This patch adds cleaning up of this
file before running py3* tests.

Change-Id: I64ef1eac7f05f217674c73ddd2cc3af773dd75ce
Closes-Bug: #1229445
2017-02-27 18:17:51 +00:00
OpenStack Proposal Bot
63bd4d1257 Updated from global requirements
Change-Id: If2efd874bb41faf366e4a5ac6075615fe1ad4ed9
2017-02-27 18:14:04 +00:00
Maciej Szankin
6a571a4493 Remove invalid tests-py3 whitelist item
The tests for XenAPI plugins were introduced with change [1].
This change also appended them to the python3 test whitelist,
as the functionality could only be executed on python2.4 environment.
The aforementioned changes were removed with change [2], but
the whitelist item was left behind. This change removes the obsolete
line.

[1] 2aa81e9ef6
[2] 21149582ff

Change-Id: Ibc15e9a06adf34512eda904d0bb3eba1eed04784
2017-02-27 18:11:11 +00:00
Jenkins
68e56ab408 Merge "Remove unused logging import" 2017-02-27 17:24:54 +00:00
Jenkins
37d33dc1e4 Merge "Tolerate WebOb===1.7.1" 2017-02-27 17:24:32 +00:00
Jenkins
3f5b5c9a31 Merge "api/metadata/vendordata_dynamic: don't import Requests for its constants" 2017-02-27 17:20:32 +00:00
Dan Smith
c79770e615 Ignore deleted services in minimum version calculation
When we go to detect the minimum version for a given service, we
should ignore any deleted services. Without this, we will return
the minimum version of all records, including those that have been
deleted with "nova service-delete". This patch filters deleted
services from the query.

Closes-Bug: #1668310
Change-Id: Ic96a5eb3728f97a3c35d2c5121e6fdcd4fd1c70b
2017-02-27 07:55:42 -08:00
Ildiko Vancsa
63805735c2 Remove check_attach
This patch finishes to remove the 'check_attach' call from Nova
completely. As Cinder already performs the required checks as part
of the 'reserve_volume' (os-reserve) call it is unnecessary to check the
statemachine in Nova also and it can lead to race conditions.

The missing 'reserve_volume' call is added to the BFV flow. In case of
build failure the volume will be locked in 'attaching' state until the
instance in ERROR state is cleaned up.

We also check AZ for each volume attach operation which we haven't
done for unshelve. A release note is added to enable 'cross_az_attach'
in case the user does not care about AZ.

The compute service version had to be bumped as the old computes still
perform 'check_attach', which will fail when the API reserves the
volume and the volume state moves to 'attaching'. If the computes
are not new enough the old check will be called as opposed to
'reserve_volume'.

Closes-Bug: #1581230
Change-Id: I3a3caa4c566ecc132aa2699f8c7e5987bbcc863a
2017-02-26 20:34:05 -05:00
Matt Riedemann
d83ff6bc93 Handle VolumeBDMIsMultiAttach in os-assisted-volume-snapshots
Change c1a61fcc37 made
BlockDeviceMapping.get_by_volume raise VolumeBDMIsMultiAttach
but we weren't handling it in the create method of the
os-assisted-volume-snapshots API. This adds the handling of
the exception so it will result in a 400 instead of a 500
error if we hit it.

Change-Id: Ie544d10ada5ee1812ec5f201b02f7ba0af449bd7
Related-Bug: #1533834
2017-02-26 17:05:03 -05:00
Jordan Pittier
b9587587c2 api/metadata/vendordata_dynamic: don't import Requests for its constants
Python-requests isn't really needed, don't import it to prevent
copy/paste of the anti pattern of accessing it's codes directly.

Fix one unit test that was returning a 204 but actually including data
in it, but expecting that data to not be used.

Change-Id: I9f6eda0c3e6f7d390abca5e9e4ebe059788ee11f
2017-02-26 07:13:40 -05:00
Danfeng
90b6a3984a Fix typos detected by toolkit misspellings.
* pip install misspellings
* git ls-files | grep -v locale | misspellings -f -

doc/source/upgrade.rst:177: incidentially -> "incidentally"
nova/conf/libvirt.py:286: dependant -> "dependent"

Change-Id: I9ae81c23de6eb4eb720552571267a372365b95d9
2017-02-26 13:50:17 +08:00
Jenkins
8b498ce199 Merge "Updated from global requirements" 2017-02-25 19:17:24 +00:00
Jenkins
87f2d0656d Merge "Fix typo in nova/network/neutronv2/api.py" 2017-02-25 19:15:00 +00:00
Jenkins
9175018622 Merge "Avoid multiple initializations of Host class" 2017-02-25 14:54:01 +00:00