python-openstackclient 9.0.0__py3-none-any.whl → 10.0.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (284) hide show
  1. openstackclient/__init__.py +2 -6
  2. openstackclient/api/api.py +41 -23
  3. openstackclient/api/compute_v2.py +44 -25
  4. openstackclient/api/object_store_v1.py +75 -97
  5. openstackclient/api/volume_v2.py +2 -1
  6. openstackclient/api/volume_v3.py +2 -1
  7. openstackclient/common/availability_zone.py +58 -42
  8. openstackclient/common/clientmanager.py +56 -29
  9. openstackclient/common/configuration.py +10 -3
  10. openstackclient/common/envvars.py +2 -2
  11. openstackclient/common/extension.py +14 -5
  12. openstackclient/common/limits.py +10 -5
  13. openstackclient/common/module.py +14 -6
  14. openstackclient/common/pagination.py +8 -2
  15. openstackclient/common/progressbar.py +7 -6
  16. openstackclient/common/project_cleanup.py +13 -7
  17. openstackclient/common/quota.py +97 -99
  18. openstackclient/common/versions.py +8 -2
  19. openstackclient/compute/client.py +7 -3
  20. openstackclient/compute/v2/agent.py +17 -10
  21. openstackclient/compute/v2/aggregate.py +36 -22
  22. openstackclient/compute/v2/console.py +14 -8
  23. openstackclient/compute/v2/console_connection.py +11 -3
  24. openstackclient/compute/v2/flavor.py +39 -21
  25. openstackclient/compute/v2/host.py +14 -6
  26. openstackclient/compute/v2/hypervisor.py +14 -5
  27. openstackclient/compute/v2/hypervisor_stats.py +10 -2
  28. openstackclient/compute/v2/keypair.py +29 -14
  29. openstackclient/compute/v2/server.py +249 -169
  30. openstackclient/compute/v2/server_backup.py +10 -4
  31. openstackclient/compute/v2/server_event.py +21 -12
  32. openstackclient/compute/v2/server_group.py +21 -11
  33. openstackclient/compute/v2/server_image.py +19 -10
  34. openstackclient/compute/v2/server_migration.py +24 -10
  35. openstackclient/compute/v2/server_share.py +274 -0
  36. openstackclient/compute/v2/server_volume.py +10 -4
  37. openstackclient/compute/v2/service.py +14 -7
  38. openstackclient/compute/v2/usage.py +26 -21
  39. openstackclient/identity/client.py +8 -3
  40. openstackclient/identity/common.py +78 -47
  41. openstackclient/identity/v2_0/catalog.py +14 -7
  42. openstackclient/identity/v2_0/ec2creds.py +21 -10
  43. openstackclient/identity/v2_0/endpoint.py +23 -11
  44. openstackclient/identity/v2_0/project.py +25 -14
  45. openstackclient/identity/v2_0/role.py +28 -14
  46. openstackclient/identity/v2_0/role_assignment.py +9 -3
  47. openstackclient/identity/v2_0/service.py +23 -11
  48. openstackclient/identity/v2_0/token.py +12 -5
  49. openstackclient/identity/v2_0/user.py +26 -15
  50. openstackclient/identity/v3/access_rule.py +26 -12
  51. openstackclient/identity/v3/application_credential.py +59 -24
  52. openstackclient/identity/v3/catalog.py +14 -7
  53. openstackclient/identity/v3/consumer.py +22 -11
  54. openstackclient/identity/v3/credential.py +36 -16
  55. openstackclient/identity/v3/domain.py +37 -18
  56. openstackclient/identity/v3/ec2creds.py +25 -12
  57. openstackclient/identity/v3/endpoint.py +42 -20
  58. openstackclient/identity/v3/endpoint_group.py +28 -17
  59. openstackclient/identity/v3/federation_protocol.py +38 -16
  60. openstackclient/identity/v3/group.py +55 -32
  61. openstackclient/identity/v3/identity_provider.py +92 -57
  62. openstackclient/identity/v3/implied_role.py +21 -9
  63. openstackclient/identity/v3/limit.py +38 -16
  64. openstackclient/identity/v3/mapping.py +26 -13
  65. openstackclient/identity/v3/policy.py +23 -12
  66. openstackclient/identity/v3/project.py +43 -23
  67. openstackclient/identity/v3/region.py +36 -16
  68. openstackclient/identity/v3/registered_limit.py +40 -16
  69. openstackclient/identity/v3/role.py +61 -31
  70. openstackclient/identity/v3/role_assignment.py +23 -6
  71. openstackclient/identity/v3/service.py +36 -16
  72. openstackclient/identity/v3/service_provider.py +37 -15
  73. openstackclient/identity/v3/tag.py +23 -6
  74. openstackclient/identity/v3/token.py +30 -14
  75. openstackclient/identity/v3/trust.py +32 -14
  76. openstackclient/identity/v3/unscoped_saml.py +10 -2
  77. openstackclient/identity/v3/user.py +49 -26
  78. openstackclient/image/client.py +7 -3
  79. openstackclient/image/v1/image.py +33 -26
  80. openstackclient/image/v2/cache.py +14 -9
  81. openstackclient/image/v2/image.py +74 -48
  82. openstackclient/image/v2/info.py +7 -1
  83. openstackclient/image/v2/metadef_namespaces.py +109 -13
  84. openstackclient/image/v2/metadef_objects.py +28 -15
  85. openstackclient/image/v2/metadef_properties.py +24 -13
  86. openstackclient/image/v2/metadef_resource_type_association.py +14 -7
  87. openstackclient/image/v2/metadef_resource_types.py +7 -1
  88. openstackclient/image/v2/task.py +15 -6
  89. openstackclient/locale/tr_TR/LC_MESSAGES/openstackclient.po +7 -192
  90. openstackclient/network/client.py +7 -2
  91. openstackclient/network/common.py +16 -241
  92. openstackclient/network/utils.py +36 -22
  93. openstackclient/network/v2/address_group.py +27 -16
  94. openstackclient/network/v2/address_scope.py +24 -13
  95. openstackclient/network/v2/bgpvpn/bgpvpn.py +463 -0
  96. openstackclient/network/v2/bgpvpn/constants.py +30 -0
  97. openstackclient/network/v2/bgpvpn/network_association.py +214 -0
  98. openstackclient/network/v2/bgpvpn/port_association.py +490 -0
  99. openstackclient/network/v2/bgpvpn/router_association.py +288 -0
  100. openstackclient/network/v2/default_security_group_rule.py +19 -10
  101. openstackclient/network/v2/floating_ip.py +110 -159
  102. openstackclient/network/v2/floating_ip_port_forwarding.py +30 -18
  103. openstackclient/network/v2/fwaas/__init__.py +0 -0
  104. openstackclient/network/v2/fwaas/group.py +466 -0
  105. openstackclient/network/v2/fwaas/policy.py +518 -0
  106. openstackclient/network/v2/fwaas/rule.py +574 -0
  107. openstackclient/network/v2/ip_availability.py +13 -5
  108. openstackclient/network/v2/l3_conntrack_helper.py +22 -13
  109. openstackclient/network/v2/local_ip.py +24 -13
  110. openstackclient/network/v2/local_ip_association.py +14 -7
  111. openstackclient/network/v2/ndp_proxy.py +20 -11
  112. openstackclient/network/v2/network.py +129 -196
  113. openstackclient/network/v2/network_agent.py +46 -25
  114. openstackclient/network/v2/network_auto_allocated_topology.py +22 -11
  115. openstackclient/network/v2/network_flavor.py +27 -16
  116. openstackclient/network/v2/network_flavor_profile.py +23 -12
  117. openstackclient/network/v2/network_meter.py +21 -10
  118. openstackclient/network/v2/network_meter_rule.py +21 -11
  119. openstackclient/network/v2/network_qos_policy.py +25 -15
  120. openstackclient/network/v2/network_qos_rule.py +32 -17
  121. openstackclient/network/v2/network_qos_rule_type.py +13 -5
  122. openstackclient/network/v2/network_rbac.py +23 -12
  123. openstackclient/network/v2/network_segment.py +20 -11
  124. openstackclient/network/v2/network_segment_range.py +56 -29
  125. openstackclient/network/v2/network_service_provider.py +7 -1
  126. openstackclient/network/v2/network_trunk.py +38 -22
  127. openstackclient/network/v2/port.py +54 -29
  128. openstackclient/network/v2/router.py +75 -52
  129. openstackclient/network/v2/security_group.py +87 -157
  130. openstackclient/network/v2/security_group_rule.py +100 -280
  131. openstackclient/network/v2/subnet.py +49 -28
  132. openstackclient/network/v2/subnet_pool.py +30 -17
  133. openstackclient/network/v2/taas/tap_flow.py +22 -11
  134. openstackclient/network/v2/taas/tap_mirror.py +22 -11
  135. openstackclient/network/v2/taas/tap_service.py +23 -12
  136. openstackclient/object/client.py +7 -2
  137. openstackclient/object/v1/account.py +13 -6
  138. openstackclient/object/v1/container.py +25 -15
  139. openstackclient/object/v1/object.py +25 -15
  140. openstackclient/py.typed +0 -0
  141. openstackclient/shell.py +46 -10
  142. openstackclient/tests/functional/base.py +55 -20
  143. openstackclient/tests/functional/common/test_extension.py +4 -0
  144. openstackclient/tests/functional/common/test_quota.py +3 -1
  145. openstackclient/tests/functional/compute/v2/common.py +14 -13
  146. openstackclient/tests/functional/compute/v2/test_flavor.py +3 -1
  147. openstackclient/tests/functional/compute/v2/test_server.py +3 -0
  148. openstackclient/tests/functional/identity/v2/common.py +10 -6
  149. openstackclient/tests/functional/identity/v2/test_role.py +4 -4
  150. openstackclient/tests/functional/identity/v3/common.py +25 -19
  151. openstackclient/tests/functional/identity/v3/test_group.py +20 -20
  152. openstackclient/tests/functional/identity/v3/test_idp.py +3 -1
  153. openstackclient/tests/functional/identity/v3/test_project.py +10 -10
  154. openstackclient/tests/functional/identity/v3/test_role.py +18 -18
  155. openstackclient/tests/functional/identity/v3/test_role_assignment.py +12 -12
  156. openstackclient/tests/functional/identity/v3/test_user.py +8 -8
  157. openstackclient/tests/functional/image/base.py +1 -6
  158. openstackclient/tests/functional/network/v2/common.py +5 -2
  159. openstackclient/tests/functional/network/v2/test_floating_ip.py +10 -4
  160. openstackclient/tests/functional/network/v2/test_ip_availability.py +4 -0
  161. openstackclient/tests/functional/network/v2/test_network_meter_rule.py +3 -2
  162. openstackclient/tests/functional/network/v2/test_network_segment.py +5 -0
  163. openstackclient/tests/functional/network/v2/test_subnet.py +13 -9
  164. openstackclient/tests/functional/object/v1/common.py +4 -0
  165. openstackclient/tests/functional/volume/v2/common.py +4 -0
  166. openstackclient/tests/functional/volume/v2/test_volume_snapshot.py +27 -11
  167. openstackclient/tests/functional/volume/v2/test_volume_type.py +2 -2
  168. openstackclient/tests/functional/volume/v3/common.py +4 -0
  169. openstackclient/tests/functional/volume/v3/test_volume_snapshot.py +11 -7
  170. openstackclient/tests/functional/volume/v3/test_volume_type.py +2 -2
  171. openstackclient/tests/unit/common/test_availability_zone.py +35 -49
  172. openstackclient/tests/unit/common/test_extension.py +2 -2
  173. openstackclient/tests/unit/common/test_module.py +12 -7
  174. openstackclient/tests/unit/common/test_project_cleanup.py +3 -1
  175. openstackclient/tests/unit/common/test_quota.py +6 -26
  176. openstackclient/tests/unit/compute/v2/fakes.py +25 -0
  177. openstackclient/tests/unit/compute/v2/test_flavor.py +28 -2
  178. openstackclient/tests/unit/compute/v2/test_keypair.py +6 -6
  179. openstackclient/tests/unit/compute/v2/test_server.py +11 -96
  180. openstackclient/tests/unit/compute/v2/test_server_share.py +287 -0
  181. openstackclient/tests/unit/identity/v3/fakes.py +3 -0
  182. openstackclient/tests/unit/identity/v3/test_group.py +4 -14
  183. openstackclient/tests/unit/identity/v3/test_identity_provider.py +303 -299
  184. openstackclient/tests/unit/identity/v3/test_user.py +4 -4
  185. openstackclient/tests/unit/image/v2/test_image.py +11 -11
  186. openstackclient/tests/unit/image/v2/test_metadef_namespaces.py +105 -6
  187. openstackclient/tests/unit/network/test_common.py +0 -155
  188. openstackclient/tests/unit/network/v2/bgpvpn/__init__.py +0 -0
  189. openstackclient/tests/unit/network/v2/bgpvpn/fakes.py +179 -0
  190. openstackclient/tests/unit/network/v2/bgpvpn/test_bgpvpn.py +584 -0
  191. openstackclient/tests/unit/network/v2/bgpvpn/test_network_association.py +285 -0
  192. openstackclient/tests/unit/network/v2/bgpvpn/test_port_association.py +384 -0
  193. openstackclient/tests/unit/network/v2/bgpvpn/test_router_association.py +297 -0
  194. openstackclient/tests/unit/network/v2/fwaas/__init__.py +0 -0
  195. openstackclient/tests/unit/network/v2/fwaas/test_group.py +897 -0
  196. openstackclient/tests/unit/network/v2/fwaas/test_policy.py +869 -0
  197. openstackclient/tests/unit/network/v2/fwaas/test_rule.py +980 -0
  198. openstackclient/tests/unit/network/v2/taas/{test_osc_tap_flow.py → test_tap_flow.py} +18 -25
  199. openstackclient/tests/unit/network/v2/taas/{test_osc_tap_mirror.py → test_tap_mirror.py} +19 -29
  200. openstackclient/tests/unit/network/v2/taas/{test_osc_tap_service.py → test_tap_service.py} +19 -29
  201. openstackclient/tests/unit/network/v2/test_address_group.py +2 -2
  202. openstackclient/tests/unit/network/v2/{test_floating_ip_network.py → test_floating_ip.py} +3 -2
  203. openstackclient/tests/unit/network/v2/test_floating_ip_port_forwarding.py +13 -13
  204. openstackclient/tests/unit/network/v2/test_network_agent.py +8 -4
  205. openstackclient/tests/unit/network/v2/test_network_auto_allocated_topology.py +3 -3
  206. openstackclient/tests/unit/network/v2/test_network_flavor.py +2 -2
  207. openstackclient/tests/unit/network/v2/test_network_qos_policy.py +1 -1
  208. openstackclient/tests/unit/network/v2/test_network_qos_rule.py +2 -2
  209. openstackclient/tests/unit/network/v2/test_network_rbac.py +1 -1
  210. openstackclient/tests/unit/network/v2/test_network_segment.py +1 -1
  211. openstackclient/tests/unit/network/v2/test_network_segment_range.py +7 -10
  212. openstackclient/tests/unit/network/v2/test_network_trunk.py +1 -1
  213. openstackclient/tests/unit/network/v2/test_router.py +8 -9
  214. openstackclient/tests/unit/network/v2/{test_security_group_network.py → test_security_group.py} +1 -20
  215. openstackclient/tests/unit/network/v2/{test_security_group_rule_network.py → test_security_group_rule.py} +7 -41
  216. openstackclient/tests/unit/network/v2/test_subnet.py +2 -1
  217. openstackclient/tests/unit/network/v2/test_subnet_pool.py +2 -1
  218. openstackclient/tests/unit/object/v1/fakes.py +8 -7
  219. openstackclient/tests/unit/object/v1/test_container.py +65 -101
  220. openstackclient/tests/unit/object/v1/test_container_all.py +8 -1
  221. openstackclient/tests/unit/object/v1/test_object.py +44 -84
  222. openstackclient/tests/unit/object/v1/test_object_all.py +8 -1
  223. openstackclient/tests/unit/test_hacking.py +108 -0
  224. openstackclient/tests/unit/volume/v2/fakes.py +1 -0
  225. openstackclient/tests/unit/volume/v2/test_volume_backup.py +1 -5
  226. openstackclient/tests/unit/volume/v2/test_volume_snapshot.py +2 -1
  227. openstackclient/tests/unit/volume/v2/test_volume_type.py +2 -4
  228. openstackclient/tests/unit/volume/v3/fakes.py +1 -0
  229. openstackclient/tests/unit/volume/v3/test_volume.py +60 -3
  230. openstackclient/tests/unit/volume/v3/test_volume_attachment.py +1 -1
  231. openstackclient/tests/unit/volume/v3/test_volume_backup.py +1 -5
  232. openstackclient/tests/unit/volume/v3/test_volume_snapshot.py +55 -1
  233. openstackclient/tests/unit/volume/v3/test_volume_type.py +2 -4
  234. openstackclient/volume/client.py +7 -3
  235. openstackclient/volume/v2/backup_record.py +15 -6
  236. openstackclient/volume/v2/consistency_group.py +29 -17
  237. openstackclient/volume/v2/consistency_group_snapshot.py +25 -10
  238. openstackclient/volume/v2/qos_specs.py +28 -17
  239. openstackclient/volume/v2/service.py +17 -6
  240. openstackclient/volume/v2/volume.py +57 -29
  241. openstackclient/volume/v2/volume_backend.py +19 -6
  242. openstackclient/volume/v2/volume_backup.py +46 -20
  243. openstackclient/volume/v2/volume_host.py +6 -4
  244. openstackclient/volume/v2/volume_snapshot.py +50 -24
  245. openstackclient/volume/v2/volume_transfer_request.py +31 -13
  246. openstackclient/volume/v2/volume_type.py +43 -24
  247. openstackclient/volume/v3/block_storage_cleanup.py +11 -3
  248. openstackclient/volume/v3/block_storage_cluster.py +19 -7
  249. openstackclient/volume/v3/block_storage_log_level.py +15 -6
  250. openstackclient/volume/v3/block_storage_manage.py +10 -4
  251. openstackclient/volume/v3/block_storage_resource_filter.py +17 -5
  252. openstackclient/volume/v3/service.py +16 -6
  253. openstackclient/volume/v3/volume.py +89 -39
  254. openstackclient/volume/v3/volume_attachment.py +43 -21
  255. openstackclient/volume/v3/volume_backup.py +53 -24
  256. openstackclient/volume/v3/volume_group.py +23 -13
  257. openstackclient/volume/v3/volume_group_snapshot.py +32 -13
  258. openstackclient/volume/v3/volume_group_type.py +26 -13
  259. openstackclient/volume/v3/volume_message.py +15 -7
  260. openstackclient/volume/v3/volume_snapshot.py +69 -32
  261. openstackclient/volume/v3/volume_transfer_request.py +31 -13
  262. openstackclient/volume/v3/volume_type.py +42 -24
  263. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.0.0.dist-info}/METADATA +6 -6
  264. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.0.0.dist-info}/RECORD +271 -260
  265. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.0.0.dist-info}/WHEEL +1 -1
  266. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.0.0.dist-info}/entry_points.txt +53 -1
  267. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.0.0.dist-info}/licenses/AUTHORS +4 -0
  268. python_openstackclient-10.0.0.dist-info/pbr.json +1 -0
  269. openstackclient/api/image_v1.py +0 -69
  270. openstackclient/api/image_v2.py +0 -79
  271. openstackclient/network/v2/floating_ip_pool.py +0 -38
  272. openstackclient/tests/functional/image/v1/test_image.py +0 -97
  273. openstackclient/tests/unit/api/test_image_v1.py +0 -96
  274. openstackclient/tests/unit/api/test_image_v2.py +0 -96
  275. openstackclient/tests/unit/network/v2/test_floating_ip_compute.py +0 -248
  276. openstackclient/tests/unit/network/v2/test_floating_ip_pool_compute.py +0 -49
  277. openstackclient/tests/unit/network/v2/test_floating_ip_pool_network.py +0 -39
  278. openstackclient/tests/unit/network/v2/test_network_compute.py +0 -404
  279. openstackclient/tests/unit/network/v2/test_security_group_compute.py +0 -392
  280. openstackclient/tests/unit/network/v2/test_security_group_rule_compute.py +0 -555
  281. python_openstackclient-9.0.0.dist-info/pbr.json +0 -1
  282. /openstackclient/{tests/functional/image/v1 → network/v2/bgpvpn}/__init__.py +0 -0
  283. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.0.0.dist-info}/licenses/LICENSE +0 -0
  284. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.0.0.dist-info}/top_level.txt +0 -0
@@ -1,555 +0,0 @@
1
- # Licensed under the Apache License, Version 2.0 (the "License"); you may
2
- # not use this file except in compliance with the License. You may obtain
3
- # a copy of the License at
4
- #
5
- # http://www.apache.org/licenses/LICENSE-2.0
6
- #
7
- # Unless required by applicable law or agreed to in writing, software
8
- # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
9
- # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
10
- # License for the specific language governing permissions and limitations
11
- # under the License.
12
-
13
- from unittest import mock
14
-
15
- from osc_lib import exceptions
16
-
17
- from openstackclient.api import compute_v2
18
- from openstackclient.network import utils as network_utils
19
- from openstackclient.network.v2 import security_group_rule
20
- from openstackclient.tests.unit.compute.v2 import fakes as compute_fakes
21
- from openstackclient.tests.unit.identity.v3 import fakes as identity_fakes
22
- from openstackclient.tests.unit import utils as tests_utils
23
-
24
-
25
- @mock.patch.object(compute_v2, 'create_security_group_rule')
26
- class TestCreateSecurityGroupRuleCompute(compute_fakes.TestComputev2):
27
- project = identity_fakes.FakeProject.create_one_project()
28
- domain = identity_fakes.FakeDomain.create_one_domain()
29
-
30
- # The security group rule to be created.
31
- _security_group_rule = None
32
-
33
- # The security group that will contain the rule created.
34
- _security_group = compute_fakes.create_one_security_group()
35
-
36
- def _setup_security_group_rule(self, attrs=None):
37
- self._security_group_rule = (
38
- compute_fakes.create_one_security_group_rule(attrs)
39
- )
40
- (
41
- expected_columns,
42
- expected_data,
43
- ) = network_utils.format_security_group_rule_show(
44
- self._security_group_rule
45
- )
46
- return expected_columns, expected_data
47
-
48
- def setUp(self):
49
- super().setUp()
50
-
51
- self.app.client_manager.network_endpoint_enabled = False
52
-
53
- compute_v2.find_security_group = mock.Mock(
54
- return_value=self._security_group,
55
- )
56
-
57
- # Get the command object to test
58
- self.cmd = security_group_rule.CreateSecurityGroupRule(self.app, None)
59
-
60
- def test_security_group_rule_create_no_options(self, sgr_mock):
61
- self.assertRaises(
62
- tests_utils.ParserException, self.check_parser, self.cmd, [], []
63
- )
64
-
65
- def test_security_group_rule_create_all_remote_options(self, sgr_mock):
66
- arglist = [
67
- '--remote-ip',
68
- '10.10.0.0/24',
69
- '--remote-group',
70
- self._security_group['id'],
71
- self._security_group['id'],
72
- ]
73
- self.assertRaises(
74
- tests_utils.ParserException,
75
- self.check_parser,
76
- self.cmd,
77
- arglist,
78
- [],
79
- )
80
-
81
- def test_security_group_rule_create_bad_protocol(self, sgr_mock):
82
- arglist = [
83
- '--protocol',
84
- 'foo',
85
- self._security_group['id'],
86
- ]
87
- self.assertRaises(
88
- tests_utils.ParserException,
89
- self.check_parser,
90
- self.cmd,
91
- arglist,
92
- [],
93
- )
94
-
95
- def test_security_group_rule_create_all_protocol_options(self, sgr_mock):
96
- arglist = [
97
- '--protocol',
98
- 'tcp',
99
- '--proto',
100
- 'tcp',
101
- self._security_group['id'],
102
- ]
103
- self.assertRaises(
104
- tests_utils.ParserException,
105
- self.check_parser,
106
- self.cmd,
107
- arglist,
108
- [],
109
- )
110
-
111
- def test_security_group_rule_create_network_options(self, sgr_mock):
112
- arglist = [
113
- '--ingress',
114
- '--ethertype',
115
- 'IPv4',
116
- '--icmp-type',
117
- '3',
118
- '--icmp-code',
119
- '11',
120
- '--project',
121
- self.project.name,
122
- '--project-domain',
123
- self.domain.name,
124
- self._security_group['id'],
125
- ]
126
- self.assertRaises(
127
- tests_utils.ParserException,
128
- self.check_parser,
129
- self.cmd,
130
- arglist,
131
- [],
132
- )
133
-
134
- def test_security_group_rule_create_default_rule(self, sgr_mock):
135
- expected_columns, expected_data = self._setup_security_group_rule()
136
- sgr_mock.return_value = self._security_group_rule
137
- dst_port = (
138
- str(self._security_group_rule['from_port'])
139
- + ':'
140
- + str(self._security_group_rule['to_port'])
141
- )
142
- arglist = [
143
- '--dst-port',
144
- dst_port,
145
- self._security_group['id'],
146
- ]
147
- verifylist = [
148
- (
149
- 'dst_port',
150
- (
151
- self._security_group_rule['from_port'],
152
- self._security_group_rule['to_port'],
153
- ),
154
- ),
155
- ('group', self._security_group['id']),
156
- ]
157
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
158
-
159
- columns, data = self.cmd.take_action(parsed_args)
160
-
161
- sgr_mock.assert_called_once_with(
162
- self.compute_client,
163
- security_group_id=self._security_group['id'],
164
- ip_protocol=self._security_group_rule['ip_protocol'],
165
- from_port=self._security_group_rule['from_port'],
166
- to_port=self._security_group_rule['to_port'],
167
- remote_ip=self._security_group_rule['ip_range']['cidr'],
168
- remote_group=None,
169
- )
170
- self.assertEqual(expected_columns, columns)
171
- self.assertEqual(expected_data, data)
172
-
173
- def test_security_group_rule_create_remote_group(self, sgr_mock):
174
- expected_columns, expected_data = self._setup_security_group_rule(
175
- {
176
- 'from_port': 22,
177
- 'to_port': 22,
178
- 'group': {'name': self._security_group['name']},
179
- }
180
- )
181
- sgr_mock.return_value = self._security_group_rule
182
- arglist = [
183
- '--dst-port',
184
- str(self._security_group_rule['from_port']),
185
- '--remote-group',
186
- self._security_group['name'],
187
- self._security_group['id'],
188
- ]
189
- verifylist = [
190
- (
191
- 'dst_port',
192
- (
193
- self._security_group_rule['from_port'],
194
- self._security_group_rule['to_port'],
195
- ),
196
- ),
197
- ('remote_group', self._security_group['name']),
198
- ('group', self._security_group['id']),
199
- ]
200
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
201
-
202
- columns, data = self.cmd.take_action(parsed_args)
203
-
204
- sgr_mock.assert_called_once_with(
205
- self.compute_client,
206
- security_group_id=self._security_group['id'],
207
- ip_protocol=self._security_group_rule['ip_protocol'],
208
- from_port=self._security_group_rule['from_port'],
209
- to_port=self._security_group_rule['to_port'],
210
- remote_ip=self._security_group_rule['ip_range']['cidr'],
211
- remote_group=self._security_group['id'],
212
- )
213
- self.assertEqual(expected_columns, columns)
214
- self.assertEqual(expected_data, data)
215
-
216
- def test_security_group_rule_create_remote_ip(self, sgr_mock):
217
- expected_columns, expected_data = self._setup_security_group_rule(
218
- {
219
- 'ip_protocol': 'icmp',
220
- 'from_port': -1,
221
- 'to_port': -1,
222
- 'ip_range': {'cidr': '10.0.2.0/24'},
223
- }
224
- )
225
- sgr_mock.return_value = self._security_group_rule
226
- arglist = [
227
- '--protocol',
228
- self._security_group_rule['ip_protocol'],
229
- '--remote-ip',
230
- self._security_group_rule['ip_range']['cidr'],
231
- self._security_group['id'],
232
- ]
233
- verifylist = [
234
- ('protocol', self._security_group_rule['ip_protocol']),
235
- ('remote_ip', self._security_group_rule['ip_range']['cidr']),
236
- ('group', self._security_group['id']),
237
- ]
238
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
239
-
240
- columns, data = self.cmd.take_action(parsed_args)
241
-
242
- sgr_mock.assert_called_once_with(
243
- self.compute_client,
244
- security_group_id=self._security_group['id'],
245
- ip_protocol=self._security_group_rule['ip_protocol'],
246
- from_port=self._security_group_rule['from_port'],
247
- to_port=self._security_group_rule['to_port'],
248
- remote_ip=self._security_group_rule['ip_range']['cidr'],
249
- remote_group=None,
250
- )
251
- self.assertEqual(expected_columns, columns)
252
- self.assertEqual(expected_data, data)
253
-
254
- def test_security_group_rule_create_proto_option(self, sgr_mock):
255
- expected_columns, expected_data = self._setup_security_group_rule(
256
- {
257
- 'ip_protocol': 'icmp',
258
- 'from_port': -1,
259
- 'to_port': -1,
260
- 'ip_range': {'cidr': '10.0.2.0/24'},
261
- }
262
- )
263
- sgr_mock.return_value = self._security_group_rule
264
- arglist = [
265
- '--proto',
266
- self._security_group_rule['ip_protocol'],
267
- '--remote-ip',
268
- self._security_group_rule['ip_range']['cidr'],
269
- self._security_group['id'],
270
- ]
271
- verifylist = [
272
- ('proto', self._security_group_rule['ip_protocol']),
273
- ('protocol', None),
274
- ('remote_ip', self._security_group_rule['ip_range']['cidr']),
275
- ('group', self._security_group['id']),
276
- ]
277
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
278
-
279
- columns, data = self.cmd.take_action(parsed_args)
280
-
281
- sgr_mock.assert_called_once_with(
282
- self.compute_client,
283
- security_group_id=self._security_group['id'],
284
- ip_protocol=self._security_group_rule['ip_protocol'],
285
- from_port=self._security_group_rule['from_port'],
286
- to_port=self._security_group_rule['to_port'],
287
- remote_ip=self._security_group_rule['ip_range']['cidr'],
288
- remote_group=None,
289
- )
290
- self.assertEqual(expected_columns, columns)
291
- self.assertEqual(expected_data, data)
292
-
293
-
294
- @mock.patch.object(compute_v2, 'delete_security_group_rule')
295
- class TestDeleteSecurityGroupRuleCompute(compute_fakes.TestComputev2):
296
- # The security group rule to be deleted.
297
- _security_group_rules = compute_fakes.create_security_group_rules(count=2)
298
-
299
- def setUp(self):
300
- super().setUp()
301
-
302
- self.app.client_manager.network_endpoint_enabled = False
303
-
304
- # Get the command object to test
305
- self.cmd = security_group_rule.DeleteSecurityGroupRule(self.app, None)
306
-
307
- def test_security_group_rule_delete(self, sgr_mock):
308
- arglist = [
309
- self._security_group_rules[0]['id'],
310
- ]
311
- verifylist = [
312
- ('rule', [self._security_group_rules[0]['id']]),
313
- ]
314
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
315
-
316
- result = self.cmd.take_action(parsed_args)
317
-
318
- sgr_mock.assert_called_once_with(
319
- self.compute_client, self._security_group_rules[0]['id']
320
- )
321
- self.assertIsNone(result)
322
-
323
- def test_security_group_rule_delete_multi(self, sgr_mock):
324
- arglist = [
325
- self._security_group_rules[0]['id'],
326
- self._security_group_rules[1]['id'],
327
- ]
328
- verifylist = [
329
- ('rule', arglist),
330
- ]
331
-
332
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
333
- result = self.cmd.take_action(parsed_args)
334
-
335
- sgr_mock.assert_has_calls(
336
- [
337
- mock.call(
338
- self.compute_client,
339
- self._security_group_rules[0]['id'],
340
- ),
341
- mock.call(
342
- self.compute_client,
343
- self._security_group_rules[1]['id'],
344
- ),
345
- ]
346
- )
347
- self.assertIsNone(result)
348
-
349
- def test_security_group_rule_delete_multi_with_exception(self, sgr_mock):
350
- arglist = [
351
- self._security_group_rules[0]['id'],
352
- 'unexist_rule',
353
- ]
354
- verifylist = [
355
- ('rule', arglist),
356
- ]
357
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
358
-
359
- sgr_mock.side_effect = [None, exceptions.NotFound('foo')]
360
-
361
- try:
362
- self.cmd.take_action(parsed_args)
363
- self.fail('CommandError should be raised.')
364
- except exceptions.CommandError as e:
365
- self.assertEqual('1 of 2 rules failed to delete.', str(e))
366
-
367
- sgr_mock.assert_has_calls(
368
- [
369
- mock.call(
370
- self.compute_client,
371
- self._security_group_rules[0]['id'],
372
- ),
373
- mock.call(self.compute_client, 'unexist_rule'),
374
- ]
375
- )
376
-
377
-
378
- class TestListSecurityGroupRuleCompute(compute_fakes.TestComputev2):
379
- # The security group to hold the rules.
380
- _security_group = compute_fakes.create_one_security_group()
381
-
382
- # The security group rule to be listed.
383
- _security_group_rule_tcp = compute_fakes.create_one_security_group_rule(
384
- {
385
- 'ip_protocol': 'tcp',
386
- 'from_port': 80,
387
- 'to_port': 80,
388
- 'group': {'name': _security_group['name']},
389
- }
390
- )
391
- _security_group_rule_icmp = compute_fakes.create_one_security_group_rule(
392
- {
393
- 'ip_protocol': 'icmp',
394
- 'from_port': -1,
395
- 'to_port': -1,
396
- 'ip_range': {'cidr': '10.0.2.0/24'},
397
- 'group': {'name': _security_group['name']},
398
- }
399
- )
400
- _security_group['rules'] = [
401
- _security_group_rule_tcp,
402
- _security_group_rule_icmp,
403
- ]
404
-
405
- expected_columns_with_group = (
406
- 'ID',
407
- 'IP Protocol',
408
- 'Ethertype',
409
- 'IP Range',
410
- 'Port Range',
411
- 'Direction',
412
- 'Remote Security Group',
413
- )
414
- expected_columns_no_group = expected_columns_with_group + (
415
- 'Security Group',
416
- )
417
-
418
- expected_data_with_group = []
419
- expected_data_no_group = []
420
- for _security_group_rule in _security_group['rules']:
421
- rule = network_utils.transform_compute_security_group_rule(
422
- _security_group_rule
423
- )
424
- expected_rule_with_group = (
425
- rule['id'],
426
- rule['ip_protocol'],
427
- '', # ethertype is a neutron-only thing
428
- rule['ip_range'],
429
- rule['port_range'],
430
- rule['remote_security_group'],
431
- )
432
- expected_rule_no_group = expected_rule_with_group + (
433
- _security_group_rule['parent_group_id'],
434
- )
435
- expected_data_with_group.append(expected_rule_with_group)
436
- expected_data_no_group.append(expected_rule_no_group)
437
-
438
- def setUp(self):
439
- super().setUp()
440
-
441
- self.app.client_manager.network_endpoint_enabled = False
442
-
443
- compute_v2.find_security_group = mock.Mock(
444
- return_value=self._security_group,
445
- )
446
- compute_v2.list_security_groups = mock.Mock(
447
- return_value=[self._security_group],
448
- )
449
-
450
- # Get the command object to test
451
- self.cmd = security_group_rule.ListSecurityGroupRule(self.app, None)
452
-
453
- def test_security_group_rule_list_default(self):
454
- parsed_args = self.check_parser(self.cmd, [], [])
455
-
456
- columns, data = self.cmd.take_action(parsed_args)
457
- compute_v2.list_security_groups.assert_called_once_with(
458
- self.compute_client, all_projects=False
459
- )
460
- self.assertEqual(self.expected_columns_no_group, columns)
461
- self.assertEqual(self.expected_data_no_group, list(data))
462
-
463
- def test_security_group_rule_list_with_group(self):
464
- arglist = [
465
- self._security_group['id'],
466
- ]
467
- verifylist = [
468
- ('group', self._security_group['id']),
469
- ]
470
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
471
-
472
- columns, data = self.cmd.take_action(parsed_args)
473
- compute_v2.find_security_group.assert_called_once_with(
474
- self.compute_client, self._security_group['id']
475
- )
476
- self.assertEqual(self.expected_columns_with_group, columns)
477
- self.assertEqual(self.expected_data_with_group, list(data))
478
-
479
- def test_security_group_rule_list_all_projects(self):
480
- arglist = [
481
- '--all-projects',
482
- ]
483
- verifylist = [
484
- ('all_projects', True),
485
- ]
486
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
487
-
488
- columns, data = self.cmd.take_action(parsed_args)
489
- compute_v2.list_security_groups.assert_called_once_with(
490
- self.compute_client, all_projects=True
491
- )
492
- self.assertEqual(self.expected_columns_no_group, columns)
493
- self.assertEqual(self.expected_data_no_group, list(data))
494
-
495
- def test_security_group_rule_list_with_ignored_options(self):
496
- arglist = [
497
- '--long',
498
- ]
499
- verifylist = [
500
- ('long', False),
501
- ]
502
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
503
-
504
- columns, data = self.cmd.take_action(parsed_args)
505
- compute_v2.list_security_groups.assert_called_once_with(
506
- self.compute_client, all_projects=False
507
- )
508
- self.assertEqual(self.expected_columns_no_group, columns)
509
- self.assertEqual(self.expected_data_no_group, list(data))
510
-
511
-
512
- class TestShowSecurityGroupRuleCompute(compute_fakes.TestComputev2):
513
- # The security group rule to be shown.
514
- _security_group_rule = compute_fakes.create_one_security_group_rule()
515
-
516
- columns, data = network_utils.format_security_group_rule_show(
517
- _security_group_rule
518
- )
519
-
520
- def setUp(self):
521
- super().setUp()
522
-
523
- self.app.client_manager.network_endpoint_enabled = False
524
-
525
- # Build a security group fake customized for this test.
526
- security_group_rules = [self._security_group_rule]
527
- security_group = {'rules': security_group_rules}
528
- compute_v2.list_security_groups = mock.Mock(
529
- return_value=[security_group],
530
- )
531
-
532
- # Get the command object to test
533
- self.cmd = security_group_rule.ShowSecurityGroupRule(self.app, None)
534
-
535
- def test_security_group_rule_show_no_options(self):
536
- self.assertRaises(
537
- tests_utils.ParserException, self.check_parser, self.cmd, [], []
538
- )
539
-
540
- def test_security_group_rule_show_all_options(self):
541
- arglist = [
542
- self._security_group_rule['id'],
543
- ]
544
- verifylist = [
545
- ('rule', self._security_group_rule['id']),
546
- ]
547
- parsed_args = self.check_parser(self.cmd, arglist, verifylist)
548
-
549
- columns, data = self.cmd.take_action(parsed_args)
550
-
551
- compute_v2.list_security_groups.assert_called_once_with(
552
- self.compute_client
553
- )
554
- self.assertEqual(self.columns, columns)
555
- self.assertEqual(self.data, data)
@@ -1 +0,0 @@
1
- {"git_version": "64cf0c33", "is_release": true}