diff --git a/cinder/scheduler/filter_scheduler.py b/cinder/scheduler/filter_scheduler.py index e87c2f67d5b..459da3696a5 100644 --- a/cinder/scheduler/filter_scheduler.py +++ b/cinder/scheduler/filter_scheduler.py @@ -270,10 +270,6 @@ class FilterScheduler(driver.Scheduler): self._populate_retry(filter_properties, request_spec['volume_properties']) - if resource_type is None: - msg = _("volume_type cannot be None") - raise exception.InvalidVolumeType(reason=msg) - request_spec_dict = jsonutils.to_primitive(request_spec) filter_properties.update({'context': context, @@ -427,7 +423,7 @@ class FilterScheduler(driver.Scheduler): if not weighed_hosts: LOG.warning(_LW('No weighed hosts found for volume ' 'with properties: %s'), - filter_properties['request_spec']['volume_type']) + filter_properties['request_spec'].get('volume_type')) return None return self._choose_top_host(weighed_hosts, request_spec) diff --git a/cinder/scheduler/filters/capabilities_filter.py b/cinder/scheduler/filters/capabilities_filter.py index e6e3c2d5190..5d64b150c8a 100644 --- a/cinder/scheduler/filters/capabilities_filter.py +++ b/cinder/scheduler/filters/capabilities_filter.py @@ -30,6 +30,10 @@ class CapabilitiesFilter(filters.BaseHostFilter): Check that the capabilities provided by the services satisfy the extra specs associated with the resource type. """ + + if not resource_type: + return True + extra_specs = resource_type.get('extra_specs', []) if not extra_specs: return True diff --git a/cinder/tests/unit/scheduler/test_filter_scheduler.py b/cinder/tests/unit/scheduler/test_filter_scheduler.py index d92193065fb..1814e523465 100644 --- a/cinder/tests/unit/scheduler/test_filter_scheduler.py +++ b/cinder/tests/unit/scheduler/test_filter_scheduler.py @@ -147,7 +147,7 @@ class FilterSchedulerTestCase(test_scheduler.SchedulerTestCase): 'size': 1}, 'volume_id': fake.VOLUME_ID} request_spec = objects.RequestSpec.from_primitives(request_spec) - self.assertRaises(exception.InvalidVolumeType, + self.assertRaises(exception.NoValidHost, sched.schedule_create_volume, fake_context, request_spec,