1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
# 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 openstack.network.v2 import security_group
from openstack.network.v2 import security_group_rule
from openstack.tests.functional import base
class TestSecurityGroupRule(base.BaseFunctionalTest):
IPV4 = "IPv4"
PROTO = "tcp"
PORT = 22
DIR = "ingress"
ID = None
RULE_ID = None
def setUp(self):
super().setUp()
self.NAME = self.getUniqueString()
sot = self.user_cloud.network.create_security_group(name=self.NAME)
assert isinstance(sot, security_group.SecurityGroup)
self.assertEqual(self.NAME, sot.name)
self.ID = sot.id
rul = self.user_cloud.network.create_security_group_rule(
direction=self.DIR,
ethertype=self.IPV4,
port_range_max=self.PORT,
port_range_min=self.PORT,
protocol=self.PROTO,
security_group_id=self.ID,
)
assert isinstance(rul, security_group_rule.SecurityGroupRule)
self.assertEqual(self.ID, rul.security_group_id)
self.RULE_ID = rul.id
def tearDown(self):
sot = self.user_cloud.network.delete_security_group_rule(
self.RULE_ID, ignore_missing=False
)
self.assertIsNone(sot)
sot = self.user_cloud.network.delete_security_group(
self.ID, ignore_missing=False
)
self.assertIsNone(sot)
super().tearDown()
def test_find(self):
sot = self.user_cloud.network.find_security_group_rule(self.RULE_ID)
self.assertEqual(self.RULE_ID, sot.id)
def test_get(self):
sot = self.user_cloud.network.get_security_group_rule(self.RULE_ID)
self.assertEqual(self.RULE_ID, sot.id)
self.assertEqual(self.DIR, sot.direction)
self.assertEqual(self.PROTO, sot.protocol)
self.assertEqual(self.PORT, sot.port_range_min)
self.assertEqual(self.PORT, sot.port_range_max)
self.assertEqual(self.ID, sot.security_group_id)
def test_list(self):
ids = [o.id for o in self.user_cloud.network.security_group_rules()]
self.assertIn(self.RULE_ID, ids)
|