
This migrates the above files from tempest. This includes tempest commits: * security_group_rules_client.py: If8c82c978d269f59f4606b65b25e1eace20e9b4a * test_security_group_rules_client.py: I2df27f5603a46eb8454556e410b2feea5ab22539 to see the commit history for these files refer to the above Change-Ids in the tempest repository. Partially implements blueprint migrate-service-clients-to-tempest-lib Change-Id: I2be5d9983dd31a2af455fdb5c495227f22b3f575
49 lines
1.9 KiB
Python
49 lines
1.9 KiB
Python
# Copyright 2012 OpenStack Foundation
|
|
# All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
from oslo_serialization import jsonutils as json
|
|
|
|
from tempest_lib.api_schema.response.compute.v2_1 import \
|
|
security_groups as schema
|
|
from tempest_lib.common import rest_client
|
|
|
|
|
|
class SecurityGroupRulesClient(rest_client.RestClient):
|
|
|
|
def create_security_group_rule(self, **kwargs):
|
|
"""Creating a new security group rules.
|
|
|
|
parent_group_id :ID of Security group.
|
|
ip_protocol : ip_proto (icmp, tcp, udp).
|
|
from_port: Port at start of range.
|
|
to_port : Port at end of range.
|
|
Following optional keyword arguments are accepted:
|
|
cidr : CIDR for address range.
|
|
group_id : ID of the Source group.
|
|
"""
|
|
post_body = json.dumps({'security_group_rule': kwargs})
|
|
url = 'os-security-group-rules'
|
|
resp, body = self.post(url, post_body)
|
|
body = json.loads(body)
|
|
self.validate_response(schema.create_security_group_rule, resp, body)
|
|
return rest_client.ResponseBody(resp, body)
|
|
|
|
def delete_security_group_rule(self, group_rule_id):
|
|
"""Deletes the provided Security Group rule."""
|
|
resp, body = self.delete('os-security-group-rules/%s' %
|
|
group_rule_id)
|
|
self.validate_response(schema.delete_security_group_rule, resp, body)
|
|
return rest_client.ResponseBody(resp, body)
|