python-openstackclient 9.0.0__py3-none-any.whl → 10.1.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 (352) 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 +59 -43
  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 +36 -34
  14. openstackclient/common/pagination.py +50 -6
  15. openstackclient/common/progressbar.py +7 -6
  16. openstackclient/common/project_cleanup.py +11 -6
  17. openstackclient/common/quota.py +105 -103
  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 +42 -22
  25. openstackclient/compute/v2/host.py +14 -6
  26. openstackclient/compute/v2/hypervisor.py +16 -5
  27. openstackclient/compute/v2/hypervisor_stats.py +10 -2
  28. openstackclient/compute/v2/keypair.py +35 -16
  29. openstackclient/compute/v2/server.py +268 -179
  30. openstackclient/compute/v2/server_backup.py +10 -4
  31. openstackclient/compute/v2/server_event.py +28 -12
  32. openstackclient/compute/v2/server_group.py +23 -11
  33. openstackclient/compute/v2/server_image.py +19 -10
  34. openstackclient/compute/v2/server_migration.py +27 -10
  35. openstackclient/compute/v2/server_share.py +274 -0
  36. openstackclient/compute/v2/server_volume.py +13 -5
  37. openstackclient/compute/v2/service.py +17 -8
  38. openstackclient/compute/v2/usage.py +28 -23
  39. openstackclient/identity/client.py +8 -3
  40. openstackclient/identity/common.py +82 -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 +32 -12
  51. openstackclient/identity/v3/application_credential.py +66 -24
  52. openstackclient/identity/v3/catalog.py +14 -7
  53. openstackclient/identity/v3/consumer.py +22 -11
  54. openstackclient/identity/v3/credential.py +39 -17
  55. openstackclient/identity/v3/domain.py +40 -19
  56. openstackclient/identity/v3/ec2creds.py +25 -12
  57. openstackclient/identity/v3/endpoint.py +98 -64
  58. openstackclient/identity/v3/endpoint_group.py +28 -17
  59. openstackclient/identity/v3/federation_protocol.py +44 -20
  60. openstackclient/identity/v3/group.py +64 -40
  61. openstackclient/identity/v3/identity_provider.py +95 -57
  62. openstackclient/identity/v3/implied_role.py +21 -9
  63. openstackclient/identity/v3/limit.py +42 -17
  64. openstackclient/identity/v3/mapping.py +58 -28
  65. openstackclient/identity/v3/policy.py +23 -12
  66. openstackclient/identity/v3/project.py +59 -26
  67. openstackclient/identity/v3/region.py +39 -17
  68. openstackclient/identity/v3/registered_limit.py +41 -16
  69. openstackclient/identity/v3/role.py +62 -31
  70. openstackclient/identity/v3/role_assignment.py +25 -7
  71. openstackclient/identity/v3/service.py +39 -17
  72. openstackclient/identity/v3/service_provider.py +40 -16
  73. openstackclient/identity/v3/tag.py +23 -6
  74. openstackclient/identity/v3/token.py +30 -14
  75. openstackclient/identity/v3/trust.py +39 -18
  76. openstackclient/identity/v3/unscoped_saml.py +10 -2
  77. openstackclient/identity/v3/user.py +86 -36
  78. openstackclient/image/client.py +7 -3
  79. openstackclient/image/v1/image.py +33 -26
  80. openstackclient/image/v2/cache.py +16 -11
  81. openstackclient/image/v2/image.py +88 -56
  82. openstackclient/image/v2/info.py +7 -1
  83. openstackclient/image/v2/metadef_namespaces.py +117 -20
  84. openstackclient/image/v2/metadef_objects.py +32 -19
  85. openstackclient/image/v2/metadef_properties.py +30 -16
  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 +25 -27
  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 +27 -54
  93. openstackclient/network/v2/address_group.py +39 -16
  94. openstackclient/network/v2/address_scope.py +36 -20
  95. openstackclient/network/v2/bgpvpn/bgpvpn.py +477 -0
  96. openstackclient/network/v2/bgpvpn/constants.py +30 -0
  97. openstackclient/network/v2/bgpvpn/network_association.py +226 -0
  98. openstackclient/network/v2/bgpvpn/port_association.py +504 -0
  99. openstackclient/network/v2/bgpvpn/router_association.py +301 -0
  100. openstackclient/network/v2/default_security_group_rule.py +31 -14
  101. openstackclient/network/v2/floating_ip.py +121 -162
  102. openstackclient/network/v2/floating_ip_port_forwarding.py +41 -19
  103. openstackclient/network/v2/fwaas/__init__.py +0 -0
  104. openstackclient/network/v2/fwaas/group.py +499 -0
  105. openstackclient/network/v2/fwaas/policy.py +518 -0
  106. openstackclient/network/v2/fwaas/rule.py +610 -0
  107. openstackclient/network/v2/ip_availability.py +25 -8
  108. openstackclient/network/v2/l3_conntrack_helper.py +35 -13
  109. openstackclient/network/v2/local_ip.py +27 -13
  110. openstackclient/network/v2/local_ip_association.py +17 -7
  111. openstackclient/network/v2/ndp_proxy.py +23 -11
  112. openstackclient/network/v2/network.py +213 -213
  113. openstackclient/network/v2/network_agent.py +77 -34
  114. openstackclient/network/v2/network_auto_allocated_topology.py +27 -15
  115. openstackclient/network/v2/network_flavor.py +45 -21
  116. openstackclient/network/v2/network_flavor_profile.py +42 -17
  117. openstackclient/network/v2/network_meter.py +39 -15
  118. openstackclient/network/v2/network_meter_rule.py +40 -12
  119. openstackclient/network/v2/network_qos_policy.py +39 -21
  120. openstackclient/network/v2/network_qos_rule.py +48 -18
  121. openstackclient/network/v2/network_qos_rule_type.py +28 -9
  122. openstackclient/network/v2/network_rbac.py +34 -16
  123. openstackclient/network/v2/network_segment.py +32 -11
  124. openstackclient/network/v2/network_segment_range.py +70 -31
  125. openstackclient/network/v2/network_service_provider.py +7 -1
  126. openstackclient/network/v2/network_trunk.py +41 -22
  127. openstackclient/network/v2/port.py +141 -40
  128. openstackclient/network/v2/router.py +101 -67
  129. openstackclient/network/v2/security_group.py +97 -198
  130. openstackclient/network/v2/security_group_rule.py +115 -282
  131. openstackclient/network/v2/subnet.py +63 -34
  132. openstackclient/network/v2/subnet_pool.py +42 -24
  133. openstackclient/network/v2/taas/tap_flow.py +35 -14
  134. openstackclient/network/v2/taas/tap_mirror.py +28 -14
  135. openstackclient/network/v2/taas/tap_service.py +26 -12
  136. openstackclient/object/client.py +7 -2
  137. openstackclient/object/v1/account.py +13 -6
  138. openstackclient/object/v1/container.py +28 -16
  139. openstackclient/object/v1/object.py +28 -16
  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 +59 -19
  151. openstackclient/tests/functional/identity/v3/test_application_credential.py +1 -1
  152. openstackclient/tests/functional/identity/v3/test_group.py +20 -20
  153. openstackclient/tests/functional/identity/v3/test_idp.py +3 -1
  154. openstackclient/tests/functional/identity/v3/test_mapping.py +81 -0
  155. openstackclient/tests/functional/identity/v3/test_project.py +10 -10
  156. openstackclient/tests/functional/identity/v3/test_role.py +18 -18
  157. openstackclient/tests/functional/identity/v3/test_role_assignment.py +12 -12
  158. openstackclient/tests/functional/identity/v3/test_user.py +8 -8
  159. openstackclient/tests/functional/image/base.py +1 -6
  160. openstackclient/tests/functional/network/v2/common.py +5 -2
  161. openstackclient/tests/functional/network/v2/test_floating_ip.py +10 -4
  162. openstackclient/tests/functional/network/v2/test_ip_availability.py +4 -0
  163. openstackclient/tests/functional/network/v2/test_network_meter_rule.py +3 -2
  164. openstackclient/tests/functional/network/v2/test_network_segment.py +5 -0
  165. openstackclient/tests/functional/network/v2/test_subnet.py +13 -9
  166. openstackclient/tests/functional/object/v1/common.py +4 -0
  167. openstackclient/tests/functional/volume/v2/common.py +4 -0
  168. openstackclient/tests/functional/volume/v2/test_volume_snapshot.py +27 -11
  169. openstackclient/tests/functional/volume/v2/test_volume_type.py +2 -2
  170. openstackclient/tests/functional/volume/v3/common.py +4 -0
  171. openstackclient/tests/functional/volume/v3/test_volume_group.py +163 -0
  172. openstackclient/tests/functional/volume/v3/test_volume_snapshot.py +11 -7
  173. openstackclient/tests/functional/volume/v3/test_volume_type.py +2 -2
  174. openstackclient/tests/unit/common/test_availability_zone.py +35 -49
  175. openstackclient/tests/unit/common/test_extension.py +2 -2
  176. openstackclient/tests/unit/common/test_limits.py +1 -1
  177. openstackclient/tests/unit/common/test_module.py +82 -44
  178. openstackclient/tests/unit/common/test_project_cleanup.py +3 -1
  179. openstackclient/tests/unit/common/test_quota.py +15 -26
  180. openstackclient/tests/unit/compute/v2/fakes.py +26 -57
  181. openstackclient/tests/unit/compute/v2/test_agent.py +4 -4
  182. openstackclient/tests/unit/compute/v2/test_aggregate.py +1 -1
  183. openstackclient/tests/unit/compute/v2/test_console.py +2 -2
  184. openstackclient/tests/unit/compute/v2/test_console_connection.py +1 -1
  185. openstackclient/tests/unit/compute/v2/test_flavor.py +29 -3
  186. openstackclient/tests/unit/compute/v2/test_host.py +3 -3
  187. openstackclient/tests/unit/compute/v2/test_hypervisor.py +2 -2
  188. openstackclient/tests/unit/compute/v2/test_hypervisor_stats.py +1 -1
  189. openstackclient/tests/unit/compute/v2/test_keypair.py +7 -7
  190. openstackclient/tests/unit/compute/v2/test_server.py +26 -111
  191. openstackclient/tests/unit/compute/v2/test_server_backup.py +1 -1
  192. openstackclient/tests/unit/compute/v2/test_server_event.py +2 -2
  193. openstackclient/tests/unit/compute/v2/test_server_group.py +1 -1
  194. openstackclient/tests/unit/compute/v2/test_server_image.py +1 -1
  195. openstackclient/tests/unit/compute/v2/test_server_migration.py +4 -4
  196. openstackclient/tests/unit/compute/v2/test_server_share.py +287 -0
  197. openstackclient/tests/unit/compute/v2/test_server_volume.py +2 -2
  198. openstackclient/tests/unit/compute/v2/test_service.py +3 -3
  199. openstackclient/tests/unit/compute/v2/test_usage.py +1 -1
  200. openstackclient/tests/unit/identity/v2_0/fakes.py +3 -7
  201. openstackclient/tests/unit/identity/v2_0/test_endpoint.py +1 -1
  202. openstackclient/tests/unit/identity/v2_0/test_project.py +1 -1
  203. openstackclient/tests/unit/identity/v2_0/test_role.py +1 -1
  204. openstackclient/tests/unit/identity/v2_0/test_role_assignment.py +1 -1
  205. openstackclient/tests/unit/identity/v2_0/test_service.py +1 -1
  206. openstackclient/tests/unit/identity/v2_0/test_token.py +2 -2
  207. openstackclient/tests/unit/identity/v2_0/test_user.py +1 -1
  208. openstackclient/tests/unit/identity/v3/fakes.py +8 -38
  209. openstackclient/tests/unit/identity/v3/test_access_rule.py +3 -3
  210. openstackclient/tests/unit/identity/v3/test_application_credential.py +4 -4
  211. openstackclient/tests/unit/identity/v3/test_credential.py +5 -5
  212. openstackclient/tests/unit/identity/v3/test_domain.py +5 -5
  213. openstackclient/tests/unit/identity/v3/test_endpoint.py +6 -6
  214. openstackclient/tests/unit/identity/v3/test_endpoint_group.py +1 -1
  215. openstackclient/tests/unit/identity/v3/test_group.py +12 -22
  216. openstackclient/tests/unit/identity/v3/test_identity_provider.py +303 -299
  217. openstackclient/tests/unit/identity/v3/test_implied_role.py +1 -1
  218. openstackclient/tests/unit/identity/v3/test_limit.py +5 -5
  219. openstackclient/tests/unit/identity/v3/test_mappings.py +163 -79
  220. openstackclient/tests/unit/identity/v3/test_project.py +28 -5
  221. openstackclient/tests/unit/identity/v3/test_protocol.py +3 -3
  222. openstackclient/tests/unit/identity/v3/test_region.py +5 -5
  223. openstackclient/tests/unit/identity/v3/test_registered_limit.py +5 -5
  224. openstackclient/tests/unit/identity/v3/test_role.py +8 -8
  225. openstackclient/tests/unit/identity/v3/test_role_assignment.py +1 -1
  226. openstackclient/tests/unit/identity/v3/test_service.py +5 -5
  227. openstackclient/tests/unit/identity/v3/test_token.py +2 -2
  228. openstackclient/tests/unit/identity/v3/test_trust.py +4 -4
  229. openstackclient/tests/unit/identity/v3/test_user.py +77 -10
  230. openstackclient/tests/unit/image/v2/test_image.py +11 -11
  231. openstackclient/tests/unit/image/v2/test_metadef_namespaces.py +105 -6
  232. openstackclient/tests/unit/network/test_common.py +0 -155
  233. openstackclient/tests/unit/network/v2/bgpvpn/__init__.py +0 -0
  234. openstackclient/tests/unit/network/v2/bgpvpn/fakes.py +179 -0
  235. openstackclient/tests/unit/network/v2/bgpvpn/test_bgpvpn.py +584 -0
  236. openstackclient/tests/unit/network/v2/bgpvpn/test_network_association.py +285 -0
  237. openstackclient/tests/unit/network/v2/bgpvpn/test_port_association.py +384 -0
  238. openstackclient/tests/unit/network/v2/bgpvpn/test_router_association.py +297 -0
  239. openstackclient/tests/unit/network/v2/fakes.py +5 -77
  240. openstackclient/tests/unit/network/v2/fwaas/__init__.py +0 -0
  241. openstackclient/tests/unit/network/v2/fwaas/test_group.py +923 -0
  242. openstackclient/tests/unit/network/v2/fwaas/test_policy.py +869 -0
  243. openstackclient/tests/unit/network/v2/fwaas/test_rule.py +1005 -0
  244. openstackclient/tests/unit/network/v2/taas/{test_osc_tap_flow.py → test_tap_flow.py} +18 -25
  245. openstackclient/tests/unit/network/v2/taas/{test_osc_tap_mirror.py → test_tap_mirror.py} +19 -29
  246. openstackclient/tests/unit/network/v2/taas/{test_osc_tap_service.py → test_tap_service.py} +19 -29
  247. openstackclient/tests/unit/network/v2/test_address_group.py +26 -2
  248. openstackclient/tests/unit/network/v2/test_address_scope.py +24 -0
  249. openstackclient/tests/unit/network/v2/{test_floating_ip_network.py → test_floating_ip.py} +27 -2
  250. openstackclient/tests/unit/network/v2/test_floating_ip_port_forwarding.py +37 -13
  251. openstackclient/tests/unit/network/v2/test_ip_availability.py +25 -0
  252. openstackclient/tests/unit/network/v2/test_l3_conntrack_helper.py +29 -3
  253. openstackclient/tests/unit/network/v2/test_network.py +74 -12
  254. openstackclient/tests/unit/network/v2/test_network_agent.py +58 -5
  255. openstackclient/tests/unit/network/v2/test_network_auto_allocated_topology.py +3 -3
  256. openstackclient/tests/unit/network/v2/test_network_flavor.py +26 -2
  257. openstackclient/tests/unit/network/v2/test_network_flavor_profile.py +24 -0
  258. openstackclient/tests/unit/network/v2/test_network_meter.py +24 -0
  259. openstackclient/tests/unit/network/v2/test_network_qos_policy.py +25 -1
  260. openstackclient/tests/unit/network/v2/test_network_qos_rule.py +2 -2
  261. openstackclient/tests/unit/network/v2/test_network_qos_rule_type.py +24 -0
  262. openstackclient/tests/unit/network/v2/test_network_rbac.py +25 -1
  263. openstackclient/tests/unit/network/v2/test_network_segment.py +25 -1
  264. openstackclient/tests/unit/network/v2/test_network_segment_range.py +31 -10
  265. openstackclient/tests/unit/network/v2/test_network_trunk.py +1 -1
  266. openstackclient/tests/unit/network/v2/test_port.py +166 -0
  267. openstackclient/tests/unit/network/v2/test_router.py +36 -16
  268. openstackclient/tests/unit/network/v2/{test_security_group_network.py → test_security_group.py} +11 -8
  269. openstackclient/tests/unit/network/v2/{test_security_group_rule_network.py → test_security_group_rule.py} +28 -37
  270. openstackclient/tests/unit/network/v2/test_subnet.py +30 -5
  271. openstackclient/tests/unit/network/v2/test_subnet_pool.py +26 -1
  272. openstackclient/tests/unit/object/v1/fakes.py +8 -7
  273. openstackclient/tests/unit/object/v1/test_container.py +65 -101
  274. openstackclient/tests/unit/object/v1/test_container_all.py +8 -1
  275. openstackclient/tests/unit/object/v1/test_object.py +44 -84
  276. openstackclient/tests/unit/object/v1/test_object_all.py +8 -1
  277. openstackclient/tests/unit/test_hacking.py +108 -0
  278. openstackclient/tests/unit/volume/v2/fakes.py +21 -140
  279. openstackclient/tests/unit/volume/v2/test_volume_backup.py +6 -14
  280. openstackclient/tests/unit/volume/v2/test_volume_snapshot.py +8 -1
  281. openstackclient/tests/unit/volume/v2/test_volume_type.py +2 -4
  282. openstackclient/tests/unit/volume/v3/fakes.py +205 -100
  283. openstackclient/tests/unit/volume/v3/test_backup_record.py +114 -0
  284. openstackclient/tests/unit/volume/v3/test_consistency_group.py +720 -0
  285. openstackclient/tests/unit/volume/v3/test_consistency_group_snapshot.py +354 -0
  286. openstackclient/tests/unit/volume/v3/test_qos_specs.py +455 -0
  287. openstackclient/tests/unit/volume/v3/test_volume.py +60 -3
  288. openstackclient/tests/unit/volume/v3/test_volume_attachment.py +3 -1
  289. openstackclient/tests/unit/volume/v3/test_volume_backend.py +158 -0
  290. openstackclient/tests/unit/volume/v3/test_volume_backup.py +6 -14
  291. openstackclient/tests/unit/volume/v3/test_volume_group_type.py +65 -0
  292. openstackclient/tests/unit/volume/v3/test_volume_host.py +115 -0
  293. openstackclient/tests/unit/volume/v3/test_volume_snapshot.py +61 -1
  294. openstackclient/tests/unit/volume/v3/test_volume_type.py +2 -4
  295. openstackclient/volume/client.py +7 -3
  296. openstackclient/volume/v2/backup_record.py +15 -6
  297. openstackclient/volume/v2/consistency_group.py +29 -17
  298. openstackclient/volume/v2/consistency_group_snapshot.py +25 -10
  299. openstackclient/volume/v2/qos_specs.py +28 -17
  300. openstackclient/volume/v2/service.py +17 -6
  301. openstackclient/volume/v2/volume.py +60 -30
  302. openstackclient/volume/v2/volume_backend.py +19 -6
  303. openstackclient/volume/v2/volume_backup.py +48 -23
  304. openstackclient/volume/v2/volume_host.py +6 -4
  305. openstackclient/volume/v2/volume_snapshot.py +49 -24
  306. openstackclient/volume/v2/volume_transfer_request.py +31 -13
  307. openstackclient/volume/v2/volume_type.py +43 -24
  308. openstackclient/volume/v3/backup_record.py +94 -0
  309. openstackclient/volume/v3/block_storage_cleanup.py +11 -3
  310. openstackclient/volume/v3/block_storage_cluster.py +19 -7
  311. openstackclient/volume/v3/block_storage_log_level.py +15 -6
  312. openstackclient/volume/v3/block_storage_manage.py +10 -4
  313. openstackclient/volume/v3/block_storage_resource_filter.py +17 -5
  314. openstackclient/volume/v3/consistency_group.py +400 -0
  315. openstackclient/volume/v3/consistency_group_snapshot.py +225 -0
  316. openstackclient/volume/v3/qos_specs.py +389 -0
  317. openstackclient/volume/v3/service.py +16 -6
  318. openstackclient/volume/v3/volume.py +92 -40
  319. openstackclient/volume/v3/volume_attachment.py +47 -21
  320. openstackclient/volume/v3/volume_backend.py +130 -0
  321. openstackclient/volume/v3/volume_backup.py +55 -27
  322. openstackclient/volume/v3/volume_group.py +23 -13
  323. openstackclient/volume/v3/volume_group_snapshot.py +34 -17
  324. openstackclient/volume/v3/volume_group_type.py +27 -14
  325. openstackclient/volume/v3/volume_host.py +74 -0
  326. openstackclient/volume/v3/volume_message.py +18 -8
  327. openstackclient/volume/v3/volume_snapshot.py +70 -32
  328. openstackclient/volume/v3/volume_transfer_request.py +31 -13
  329. openstackclient/volume/v3/volume_type.py +42 -24
  330. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.1.0.dist-info}/METADATA +7 -8
  331. python_openstackclient-10.1.0.dist-info/RECORD +524 -0
  332. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.1.0.dist-info}/WHEEL +1 -1
  333. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.1.0.dist-info}/entry_points.txt +77 -25
  334. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.1.0.dist-info}/licenses/AUTHORS +9 -0
  335. python_openstackclient-10.1.0.dist-info/pbr.json +1 -0
  336. openstackclient/api/image_v1.py +0 -69
  337. openstackclient/api/image_v2.py +0 -79
  338. openstackclient/network/v2/floating_ip_pool.py +0 -38
  339. openstackclient/tests/functional/image/v1/test_image.py +0 -97
  340. openstackclient/tests/unit/api/test_image_v1.py +0 -96
  341. openstackclient/tests/unit/api/test_image_v2.py +0 -96
  342. openstackclient/tests/unit/network/v2/test_floating_ip_compute.py +0 -248
  343. openstackclient/tests/unit/network/v2/test_floating_ip_pool_compute.py +0 -49
  344. openstackclient/tests/unit/network/v2/test_floating_ip_pool_network.py +0 -39
  345. openstackclient/tests/unit/network/v2/test_network_compute.py +0 -404
  346. openstackclient/tests/unit/network/v2/test_security_group_compute.py +0 -392
  347. openstackclient/tests/unit/network/v2/test_security_group_rule_compute.py +0 -555
  348. python_openstackclient-9.0.0.dist-info/RECORD +0 -499
  349. python_openstackclient-9.0.0.dist-info/pbr.json +0 -1
  350. /openstackclient/{tests/functional/image/v1 → network/v2/bgpvpn}/__init__.py +0 -0
  351. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.1.0.dist-info}/licenses/LICENSE +0 -0
  352. {python_openstackclient-9.0.0.dist-info → python_openstackclient-10.1.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,923 @@
1
+ # Copyright 2016 FUJITSU LIMITED
2
+ # All Rights Reserved
3
+ #
4
+ # Licensed under the Apache License, Version 2.0 (the "License"); you may
5
+ # not use this file except in compliance with the License. You may obtain
6
+ # a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12
+ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13
+ # License for the specific language governing permissions and limitations
14
+ # under the License.
15
+ #
16
+
17
+ import copy
18
+ import re
19
+ from unittest import mock
20
+
21
+ from openstack.network.v2 import firewall_group
22
+ from openstack.test import fakes as sdk_fakes
23
+ from osc_lib import exceptions
24
+
25
+ from openstackclient.network.v2.fwaas import group as fwaas_group
26
+ from openstackclient.tests.unit.network.v2 import fakes as network_fakes
27
+ from openstackclient.tests.unit import utils as test_utils
28
+
29
+
30
+ CONVERT_MAP = {
31
+ 'ingress_firewall_policy': 'ingress_firewall_policy_id',
32
+ 'egress_firewall_policy': 'egress_firewall_policy_id',
33
+ 'no_ingress_firewall_policy': 'ingress_firewall_policy_id',
34
+ 'no_egress_firewall_policy': 'egress_firewall_policy_id',
35
+ 'positional_name': 'name',
36
+ 'project': 'project_id',
37
+ 'port': 'ports',
38
+ }
39
+
40
+
41
+ def _generate_response(source=None, data=None):
42
+ source = source if source else {}
43
+ up = {
44
+ 'admin_state_up': fwaas_group.AdminStateColumn(
45
+ source['admin_state_up']
46
+ )
47
+ }
48
+ if data:
49
+ up.append(data)
50
+ source.update(up)
51
+ return source
52
+
53
+
54
+ def _generate_req_and_res(verifylist, response):
55
+ request = dict(verifylist)
56
+ for key, val in verifylist:
57
+ del request[key]
58
+ if re.match('^no_', key) and val is True:
59
+ new_value = None
60
+ elif val is True or val is False:
61
+ new_value = val
62
+ elif key in ('name', 'description'):
63
+ new_value = val
64
+ else:
65
+ new_value = val
66
+ converted = CONVERT_MAP.get(key, key)
67
+ request[converted] = new_value
68
+ response[converted] = new_value
69
+ return request, response
70
+
71
+
72
+ class TestFirewallGroup(network_fakes.TestNetworkV2):
73
+ def check_results(self, headers, data, exp_req, is_list=False):
74
+ if is_list:
75
+ req_body = {self.res_plural: list(exp_req)}
76
+ else:
77
+ req_body = exp_req
78
+ self.mocked.assert_called_once_with(**req_body)
79
+ self.assertEqual(self.ordered_headers, tuple(sorted(headers)))
80
+
81
+ def setUp(self):
82
+ super().setUp()
83
+
84
+ self.resource = sdk_fakes.generate_fake_resource(
85
+ firewall_group.FirewallGroup
86
+ )
87
+
88
+ def _find_resource(*args, **kwargs):
89
+ return self.resource
90
+
91
+ self.network_client.find_firewall_group.side_effect = _find_resource
92
+ self.identity_client.projects.get.side_effect = lambda x: mock.Mock(
93
+ id=x
94
+ )
95
+ self.res = 'firewall_group'
96
+ self.res_plural = 'firewall_groups'
97
+ self.list_headers = (
98
+ 'ID',
99
+ 'Name',
100
+ 'Ingress Policy ID',
101
+ 'Egress Policy ID',
102
+ )
103
+ self.list_data = (
104
+ self.resource['id'],
105
+ self.resource['name'],
106
+ self.resource['ingress_firewall_policy_id'],
107
+ self.resource['egress_firewall_policy_id'],
108
+ )
109
+ self.headers = tuple(
110
+ (
111
+ *self.list_headers,
112
+ 'Description',
113
+ 'Status',
114
+ 'Ports',
115
+ 'State',
116
+ 'Shared',
117
+ 'Project',
118
+ )
119
+ )
120
+ self.data = _generate_response(self.resource)
121
+ self.ordered_headers = copy.deepcopy(tuple(sorted(self.headers)))
122
+ self.expected_data = (
123
+ self.resource['description'],
124
+ self.resource['egress_firewall_policy_id'],
125
+ self.resource['id'],
126
+ self.resource['ingress_firewall_policy_id'],
127
+ self.resource['name'],
128
+ self.resource['ports'],
129
+ self.resource['project_id'],
130
+ self.resource['shared'],
131
+ fwaas_group.AdminStateColumn(self.resource['admin_state_up']),
132
+ self.resource['status'],
133
+ )
134
+ self.ordered_columns = (
135
+ 'description',
136
+ 'egress_firewall_policy_id',
137
+ 'id',
138
+ 'ingress_firewall_policy_id',
139
+ 'name',
140
+ 'ports',
141
+ 'project_id',
142
+ 'shared',
143
+ 'admin_state_up',
144
+ 'status',
145
+ )
146
+
147
+
148
+ class TestCreateFirewallGroup(TestFirewallGroup):
149
+ def setUp(self):
150
+ super().setUp()
151
+ self.network_client.create_firewall_group.return_value = self.resource
152
+ self.mocked = self.network_client.create_firewall_group
153
+ self.cmd = fwaas_group.CreateFirewallGroup(self.app, None)
154
+
155
+ def _update_expect_response(self, request, response):
156
+ """Set expected request and response
157
+
158
+ :param request
159
+ A dictionary of request body(dict of verifylist)
160
+ :param response
161
+ A OrderedDict of request body
162
+ """
163
+ # Update response body
164
+ self.network_client.create_firewall_group.return_value = response
165
+ # Update response(finally returns 'data')
166
+ self.data = _generate_response(source=response)
167
+ self.expected_data = response
168
+
169
+ def test_create_with_no_option(self):
170
+ # firewall_group-create with mandatory (none) params.
171
+ arglist = []
172
+ verifylist = []
173
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
174
+ headers, _data = self.cmd.take_action(parsed_args)
175
+ self.assertEqual(self.ordered_headers, tuple(sorted(headers)))
176
+
177
+ def test_create_with_port(self):
178
+ # firewall_group-create with 'port'
179
+ port_id = 'id_for_port'
180
+
181
+ def _mock_find(*args, **kwargs):
182
+ return mock.Mock(id=args[0])
183
+
184
+ self.network_client.find_port.side_effect = _mock_find
185
+ arglist = ['--port', port_id]
186
+ verifylist = [('port', [port_id])]
187
+ request, response = _generate_req_and_res(verifylist, self.resource)
188
+ self._update_expect_response(request, response)
189
+
190
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
191
+ headers, data = self.cmd.take_action(parsed_args)
192
+
193
+ self.check_results(headers, data, request)
194
+
195
+ def test_create_with_ingress_policy(self):
196
+ ingress_policy = 'my-ingress-policy'
197
+
198
+ def _mock_port_fwg(*args, **kwargs):
199
+ return mock.Mock(id=args[0])
200
+
201
+ self.network_client.find_firewall_policy.side_effect = _mock_port_fwg
202
+
203
+ arglist = ['--ingress-firewall-policy', ingress_policy]
204
+ verifylist = [('ingress_firewall_policy', ingress_policy)]
205
+ request, response = _generate_req_and_res(verifylist, self.resource)
206
+ self._update_expect_response(request, response)
207
+
208
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
209
+ headers, data = self.cmd.take_action(parsed_args)
210
+ self.network_client.find_firewall_policy.assert_called_once_with(
211
+ ingress_policy, ignore_missing=False
212
+ )
213
+
214
+ self.check_results(headers, data, request)
215
+
216
+ def test_create_with_egress_policy(self):
217
+ egress_policy = 'my-egress-policy'
218
+
219
+ def _mock_find(*args, **kwargs):
220
+ return mock.Mock(id=args[0])
221
+
222
+ self.network_client.find_firewall_group.side_effect = _mock_find
223
+ self.network_client.find_firewall_policy.side_effect = _mock_find
224
+
225
+ arglist = ['--egress-firewall-policy', egress_policy]
226
+ verifylist = [('egress_firewall_policy', egress_policy)]
227
+ request, response = _generate_req_and_res(verifylist, self.resource)
228
+ self._update_expect_response(request, response)
229
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
230
+ headers, data = self.cmd.take_action(parsed_args)
231
+
232
+ self.network_client.find_firewall_policy.assert_called_once_with(
233
+ egress_policy, ignore_missing=False
234
+ )
235
+ self.check_results(headers, data, request)
236
+
237
+ def test_create_with_all_params(self):
238
+ name = 'my-name'
239
+ description = 'my-desc'
240
+ ingress_policy = 'my-ingress-policy'
241
+ egress_policy = 'my-egress-policy'
242
+
243
+ def _mock_find(*args, **kwargs):
244
+ return mock.Mock(id=args[0])
245
+
246
+ self.network_client.find_firewall_policy.side_effect = _mock_find
247
+ port = 'port'
248
+ self.network_client.find_port.side_effect = _mock_find
249
+ project_id = 'my-project'
250
+ arglist = [
251
+ name,
252
+ '--description',
253
+ description,
254
+ '--ingress-firewall-policy',
255
+ ingress_policy,
256
+ '--egress-firewall-policy',
257
+ egress_policy,
258
+ '--port',
259
+ port,
260
+ '--project',
261
+ project_id,
262
+ '--share',
263
+ '--disable',
264
+ ]
265
+ verifylist = [
266
+ ('positional_name', name),
267
+ ('description', description),
268
+ ('ingress_firewall_policy', ingress_policy),
269
+ ('egress_firewall_policy', egress_policy),
270
+ ('port', [port]),
271
+ ('shared', True),
272
+ ('project', project_id),
273
+ ('admin_state_up', False),
274
+ ]
275
+ request, response = _generate_req_and_res(verifylist, self.resource)
276
+ self._update_expect_response(request, response)
277
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
278
+ headers, data = self.cmd.take_action(parsed_args)
279
+
280
+ self.check_results(headers, data, request)
281
+
282
+ def test_create_with_name_option_deprecated(self):
283
+ name = 'my-name'
284
+ arglist = ['--name', name]
285
+ verifylist = [('name', name)]
286
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
287
+ with mock.patch.object(fwaas_group.LOG, 'warning') as mock_warning:
288
+ headers, _data = self.cmd.take_action(parsed_args)
289
+ mock_warning.assert_called_once_with(
290
+ 'The --name option is deprecated for the "firewall group '
291
+ 'create" command, please pass the name as a positional '
292
+ 'argument instead.'
293
+ )
294
+ self.assertEqual(self.ordered_headers, tuple(sorted(headers)))
295
+
296
+ def test_create_with_both_positional_and_option_name(self):
297
+ name = 'my-name'
298
+ arglist = [name, '--name', 'other-name']
299
+ verifylist = [
300
+ ('positional_name', name),
301
+ ('name', 'other-name'),
302
+ ]
303
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
304
+ self.assertRaises(
305
+ exceptions.CommandError, self.cmd.take_action, parsed_args
306
+ )
307
+
308
+ def test_create_with_shared_and_no_share(self):
309
+ arglist = [
310
+ '--share',
311
+ '--no-share',
312
+ ]
313
+ verifylist = [
314
+ ('shared', True),
315
+ ]
316
+ self.assertRaises(
317
+ test_utils.ParserException,
318
+ self.check_parser,
319
+ self.cmd,
320
+ arglist,
321
+ verifylist,
322
+ )
323
+
324
+ def test_create_with_ports_and_no(self):
325
+ port = 'my-port'
326
+ arglist = [
327
+ '--port',
328
+ port,
329
+ '--no-port',
330
+ ]
331
+ verifylist = [
332
+ ('port', [port]),
333
+ ('no_port', True),
334
+ ]
335
+ self.assertRaises(
336
+ test_utils.ParserException,
337
+ self.check_parser,
338
+ self.cmd,
339
+ arglist,
340
+ verifylist,
341
+ )
342
+
343
+ def test_create_with_ingress_policy_and_no(self):
344
+ policy = 'my-policy'
345
+ arglist = [
346
+ '--ingress-firewall-policy',
347
+ policy,
348
+ '--no-ingress-firewall-policy',
349
+ ]
350
+ verifylist = [
351
+ ('ingress_firewall_policy', policy),
352
+ ('no_ingress_firewall_policy', True),
353
+ ]
354
+ self.assertRaises(
355
+ test_utils.ParserException,
356
+ self.check_parser,
357
+ self.cmd,
358
+ arglist,
359
+ verifylist,
360
+ )
361
+
362
+ def test_create_with_egress_policy_and_no(self):
363
+ policy = 'my-policy'
364
+ arglist = [
365
+ '--egress-firewall-policy',
366
+ policy,
367
+ '--no-egress-firewall-policy',
368
+ ]
369
+ verifylist = [
370
+ ('egress_firewall_policy', policy),
371
+ ('no_egress_firewall_policy', True),
372
+ ]
373
+ self.assertRaises(
374
+ test_utils.ParserException,
375
+ self.check_parser,
376
+ self.cmd,
377
+ arglist,
378
+ verifylist,
379
+ )
380
+
381
+
382
+ class TestListFirewallGroup(TestFirewallGroup):
383
+ def setUp(self):
384
+ super().setUp()
385
+ self.network_client.firewall_groups.return_value = [self.resource]
386
+ self.mocked = self.network_client.firewall_groups
387
+ self.cmd = fwaas_group.ListFirewallGroup(self.app, None)
388
+
389
+ def test_list_with_no_option(self):
390
+ arglist = []
391
+ verifylist = []
392
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
393
+ headers, data = self.cmd.take_action(parsed_args)
394
+
395
+ self.mocked.assert_called_once_with()
396
+ self.assertEqual(list(self.list_headers), headers)
397
+ self.assertEqual([self.list_data], list(data))
398
+
399
+ def test_list_with_long_option(self):
400
+ arglist = ['--long']
401
+ verifylist = [('long', True)]
402
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
403
+ headers, _data = self.cmd.take_action(parsed_args)
404
+
405
+ self.mocked.assert_called_once_with()
406
+ self.assertEqual(list(self.headers), headers)
407
+
408
+
409
+ class TestShowFirewallGroup(TestFirewallGroup):
410
+ def setUp(self):
411
+ super().setUp()
412
+ self.network_client.get_firewall_group.return_value = self.resource
413
+ self.mocked = self.network_client.get_firewall_group
414
+ self.cmd = fwaas_group.ShowFirewallGroup(self.app, None)
415
+
416
+ def test_show_filtered_by_id_or_name(self):
417
+ target = self.resource['id']
418
+
419
+ def _mock_fwaas(*args, **kwargs):
420
+ return mock.Mock(id=args[0])
421
+
422
+ self.network_client.find_firewall_group.side_effect = _mock_fwaas
423
+
424
+ arglist = [target]
425
+ verifylist = [(self.res, target)]
426
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
427
+ headers, _data = self.cmd.take_action(parsed_args)
428
+
429
+ self.mocked.assert_called_once_with(target)
430
+ self.assertEqual(self.ordered_headers, headers)
431
+
432
+
433
+ class TestSetFirewallGroup(TestFirewallGroup):
434
+ def setUp(self):
435
+ super().setUp()
436
+ self.resource['ports'] = ['old_port']
437
+ self.network_client.update_firewall_group.return_value = {
438
+ self.res: self.resource
439
+ }
440
+ self.mocked = self.network_client.update_firewall_group
441
+
442
+ def _mock_find_port(*args, **kwargs):
443
+ return mock.Mock(id=args[0])
444
+
445
+ self.network_client.find_port.side_effect = _mock_find_port
446
+
447
+ self.cmd = fwaas_group.SetFirewallGroup(self.app, None)
448
+
449
+ def _update_expect_response(self, request, response):
450
+ """Set expected request and response
451
+
452
+ :param request
453
+ A dictionary of request body(dict of verifylist)
454
+ :param response
455
+ A OrderedDict of request body
456
+ """
457
+ # Update response(finally returns 'data')
458
+ self.data = _generate_response(source=response)
459
+ self.ordered_data = tuple(
460
+ response[column] for column in self.ordered_columns
461
+ )
462
+
463
+ def test_set_name(self):
464
+ target = self.resource['id']
465
+ update = 'change'
466
+ arglist = [target, '--name', update]
467
+ verifylist = [
468
+ (self.res, target),
469
+ ('name', update),
470
+ ]
471
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
472
+ result = self.cmd.take_action(parsed_args)
473
+
474
+ self.mocked.assert_called_once_with(target, **{'name': update})
475
+ self.assertIsNone(result)
476
+
477
+ def test_set_options(self):
478
+ target = self.resource['id']
479
+ updated_desc = 'change-desc'
480
+ arglist = [target, '--description', updated_desc, '--share']
481
+ verifylist = [
482
+ (self.res, target),
483
+ ('description', updated_desc),
484
+ ('shared', True),
485
+ ]
486
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
487
+ result = self.cmd.take_action(parsed_args)
488
+
489
+ self.mocked.assert_called_once_with(
490
+ target, shared=True, description=updated_desc
491
+ )
492
+ self.assertIsNone(result)
493
+
494
+ def test_set_ingress_policy_and_egress_policy(self):
495
+ target = self.resource['id']
496
+ ingress_policy = 'ingress_policy'
497
+ egress_policy = 'egress_policy'
498
+
499
+ def _mock_fwg_policy(*args, **kwargs):
500
+ return mock.Mock(id=args[0])
501
+
502
+ self.network_client.find_firewall_group.side_effect = _mock_fwg_policy
503
+ self.network_client.find_firewall_policy.side_effect = _mock_fwg_policy
504
+
505
+ arglist = [
506
+ target,
507
+ '--ingress-firewall-policy',
508
+ ingress_policy,
509
+ '--egress-firewall-policy',
510
+ egress_policy,
511
+ ]
512
+ verifylist = [
513
+ (self.res, target),
514
+ ('ingress_firewall_policy', ingress_policy),
515
+ ('egress_firewall_policy', egress_policy),
516
+ ]
517
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
518
+ result = self.cmd.take_action(parsed_args)
519
+
520
+ self.mocked.assert_called_once_with(
521
+ target,
522
+ **{
523
+ 'ingress_firewall_policy_id': ingress_policy,
524
+ 'egress_firewall_policy_id': egress_policy,
525
+ },
526
+ )
527
+ self.assertIsNone(result)
528
+
529
+ def test_set_port(self):
530
+ target = self.resource['id']
531
+ port1 = 'additional_port1'
532
+ port2 = 'additional_port2'
533
+
534
+ def _mock_port_fwg(*args, **kwargs):
535
+ return mock.Mock(id=args[0], ports=self.resource['ports'])
536
+
537
+ self.network_client.find_firewall_group.side_effect = _mock_port_fwg
538
+ self.network_client.find_port.side_effect = _mock_port_fwg
539
+
540
+ arglist = [
541
+ target,
542
+ '--port',
543
+ port1,
544
+ '--port',
545
+ port2,
546
+ ]
547
+ verifylist = [
548
+ (self.res, target),
549
+ ('port', [port1, port2]),
550
+ ]
551
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
552
+ result = self.cmd.take_action(parsed_args)
553
+
554
+ expect = {'ports': sorted(self.resource['ports'] + [port1, port2])}
555
+ self.mocked.assert_called_once_with(target, **expect)
556
+ self.assertEqual(2, self.network_client.find_firewall_group.call_count)
557
+ self.assertIsNone(result)
558
+
559
+ def test_set_no_port(self):
560
+ # firewall_group-update myid --policy newpolicy.
561
+ target = self.resource['id']
562
+ arglist = [target, '--no-port']
563
+ verifylist = [
564
+ (self.res, target),
565
+ ('no_port', True),
566
+ ]
567
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
568
+ result = self.cmd.take_action(parsed_args)
569
+
570
+ self.mocked.assert_called_once_with(target, **{'ports': []})
571
+ self.assertIsNone(result)
572
+
573
+ def test_set_admin_state(self):
574
+ target = self.resource['id']
575
+ arglist = [target, '--enable']
576
+ verifylist = [
577
+ (self.res, target),
578
+ ('admin_state_up', True),
579
+ ]
580
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
581
+ result = self.cmd.take_action(parsed_args)
582
+
583
+ self.mocked.assert_called_once_with(target, **{'admin_state_up': True})
584
+ self.assertIsNone(result)
585
+
586
+ def test_set_shared(self):
587
+ target = self.resource['id']
588
+ arglist = [target, '--share']
589
+ verifylist = [
590
+ (self.res, target),
591
+ ('shared', True),
592
+ ]
593
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
594
+ result = self.cmd.take_action(parsed_args)
595
+
596
+ self.mocked.assert_called_once_with(target, **{'shared': True})
597
+ self.assertIsNone(result)
598
+
599
+ def test_set_no_share(self):
600
+ target = self.resource['id']
601
+ arglist = [target, '--no-share']
602
+ verifylist = [
603
+ (self.res, target),
604
+ ('shared', False),
605
+ ]
606
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
607
+ result = self.cmd.take_action(parsed_args)
608
+
609
+ self.mocked.assert_called_once_with(target, **{'shared': False})
610
+ self.assertIsNone(result)
611
+
612
+ def test_set_egress_policy(self):
613
+ target = self.resource['id']
614
+ policy = 'egress_policy'
615
+
616
+ def _mock_find_policy(*args, **kwargs):
617
+ return mock.Mock(id=args[0])
618
+
619
+ self.network_client.find_firewall_policy.side_effect = (
620
+ _mock_find_policy
621
+ )
622
+
623
+ arglist = [target, '--egress-firewall-policy', policy]
624
+ verifylist = [
625
+ (self.res, target),
626
+ ('egress_firewall_policy', policy),
627
+ ]
628
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
629
+ result = self.cmd.take_action(parsed_args)
630
+
631
+ self.mocked.assert_called_once_with(
632
+ target, **{'egress_firewall_policy_id': policy}
633
+ )
634
+ self.assertIsNone(result)
635
+
636
+ def test_set_no_ingress_policies(self):
637
+ target = self.resource['id']
638
+ arglist = [target, '--no-ingress-firewall-policy']
639
+ verifylist = [
640
+ (self.res, target),
641
+ ('no_ingress_firewall_policy', True),
642
+ ]
643
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
644
+ result = self.cmd.take_action(parsed_args)
645
+
646
+ self.mocked.assert_called_once_with(
647
+ target, **{'ingress_firewall_policy_id': None}
648
+ )
649
+ self.assertIsNone(result)
650
+
651
+ def test_set_no_egress_policies(self):
652
+ target = self.resource['id']
653
+ arglist = [target, '--no-egress-firewall-policy']
654
+ verifylist = [
655
+ (self.res, target),
656
+ ('no_egress_firewall_policy', True),
657
+ ]
658
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
659
+ result = self.cmd.take_action(parsed_args)
660
+
661
+ self.mocked.assert_called_once_with(
662
+ target, **{'egress_firewall_policy_id': None}
663
+ )
664
+ self.assertIsNone(result)
665
+
666
+ def test_set_port_and_no_port(self):
667
+ target = self.resource['id']
668
+ port = 'my-port'
669
+ arglist = [
670
+ target,
671
+ '--port',
672
+ port,
673
+ '--no-port',
674
+ ]
675
+ verifylist = [
676
+ (self.res, target),
677
+ ('port', [port]),
678
+ ('no_port', True),
679
+ ]
680
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
681
+ result = self.cmd.take_action(parsed_args)
682
+ self.mocked.assert_called_once_with(target, **{'ports': [port]})
683
+ self.assertIsNone(result)
684
+
685
+ def test_set_ingress_policy_and_no_ingress_policy(self):
686
+ target = self.resource['id']
687
+ arglist = [
688
+ target,
689
+ '--ingress-firewall-policy',
690
+ 'my-ingress',
691
+ '--no-ingress-firewall-policy',
692
+ ]
693
+ verifylist = [
694
+ (self.res, target),
695
+ ('ingress_firewall_policy', 'my-ingress'),
696
+ ('no_ingress_firewall_policy', True),
697
+ ]
698
+ self.assertRaises(
699
+ test_utils.ParserException,
700
+ self.check_parser,
701
+ self.cmd,
702
+ arglist,
703
+ verifylist,
704
+ )
705
+
706
+ def test_set_egress_policy_and_no_egress_policy(self):
707
+ target = self.resource['id']
708
+ arglist = [
709
+ target,
710
+ '--egress-firewall-policy',
711
+ 'my-egress',
712
+ '--no-egress-firewall-policy',
713
+ ]
714
+ verifylist = [
715
+ (self.res, target),
716
+ ('egress_firewall_policy', 'my-egress'),
717
+ ('no_egress_firewall_policy', True),
718
+ ]
719
+ self.assertRaises(
720
+ test_utils.ParserException,
721
+ self.check_parser,
722
+ self.cmd,
723
+ arglist,
724
+ verifylist,
725
+ )
726
+
727
+ def test_set_and_raises(self):
728
+ self.network_client.update_firewall_group.side_effect = Exception
729
+ target = self.resource['id']
730
+ arglist = [target, '--name', 'my-name']
731
+ verifylist = [(self.res, target), ('name', 'my-name')]
732
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
733
+
734
+ self.assertRaises(
735
+ exceptions.CommandError, self.cmd.take_action, parsed_args
736
+ )
737
+
738
+
739
+ class TestDeleteFirewallGroup(TestFirewallGroup):
740
+ def setUp(self):
741
+ super().setUp()
742
+ # Mock objects
743
+ self.mocked = self.network_client.delete_firewall_group
744
+ self.cmd = fwaas_group.DeleteFirewallGroup(self.app, None)
745
+
746
+ def test_delete_with_one_resource(self):
747
+ target = self.resource['id']
748
+
749
+ def _mock_fwaas(*args, **kwargs):
750
+ return mock.Mock(id=args[0])
751
+
752
+ self.network_client.find_firewall_group.side_effect = _mock_fwaas
753
+
754
+ arglist = [target]
755
+ verifylist = [(self.res, [target])]
756
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
757
+ result = self.cmd.take_action(parsed_args)
758
+
759
+ self.mocked.assert_called_once_with(target)
760
+ self.assertIsNone(result)
761
+
762
+ def test_delete_with_multiple_resources(self):
763
+
764
+ def _mock_fwaas(*args, **kwargs):
765
+ return mock.Mock(id=args[0])
766
+
767
+ self.network_client.find_firewall_group.side_effect = _mock_fwaas
768
+
769
+ target1 = 'target1'
770
+ target2 = 'target2'
771
+ arglist = [target1, target2]
772
+ verifylist = [(self.res, [target1, target2])]
773
+
774
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
775
+ result = self.cmd.take_action(parsed_args)
776
+ self.assertIsNone(result)
777
+
778
+ self.assertEqual(2, self.mocked.call_count)
779
+ for idx, reference in enumerate([target1, target2]):
780
+ actual = ''.join(self.mocked.call_args_list[idx][0][0])
781
+ self.assertEqual(reference, actual)
782
+
783
+ def test_delete_multiple_with_exception(self):
784
+ target1 = 'target1'
785
+ target2 = 'target2'
786
+ arglist = [target1, target2]
787
+ verifylist = [(self.res, [target1, target2])]
788
+
789
+ def _mock_find(*args, **kwargs):
790
+ if args[0] == target2:
791
+ raise Exception('Not found')
792
+ return mock.Mock(id=args[0])
793
+
794
+ self.network_client.find_firewall_group.side_effect = _mock_find
795
+
796
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
797
+ self.assertRaises(
798
+ exceptions.CommandError, self.cmd.take_action, parsed_args
799
+ )
800
+
801
+
802
+ class TestUnsetFirewallGroup(TestFirewallGroup):
803
+ def setUp(self):
804
+ super().setUp()
805
+ self.resource['ports'] = ['old_port']
806
+ # Mock objects
807
+ self.mocked = self.network_client.update_firewall_group
808
+ self.cmd = fwaas_group.UnsetFirewallGroup(self.app, None)
809
+
810
+ def test_unset_shared(self):
811
+ target = self.resource['id']
812
+ arglist = [
813
+ target,
814
+ '--share',
815
+ ]
816
+ verifylist = [
817
+ (self.res, target),
818
+ ('share', True),
819
+ ]
820
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
821
+ with mock.patch.object(fwaas_group.LOG, 'warning') as mock_warning:
822
+ result = self.cmd.take_action(parsed_args)
823
+ mock_warning.assert_called_once_with(
824
+ 'The --share option is deprecated, please use '
825
+ '"firewall group set --no-share" instead.'
826
+ )
827
+ self.mocked.assert_called_once_with(target, **{'shared': False})
828
+ self.assertIsNone(result)
829
+
830
+ def test_unset_ingress_policy(self):
831
+ target = self.resource['id']
832
+ arglist = [
833
+ target,
834
+ '--ingress-firewall-policy',
835
+ ]
836
+ verifylist = [
837
+ (self.res, target),
838
+ ('ingress_firewall_policy', True),
839
+ ]
840
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
841
+ result = self.cmd.take_action(parsed_args)
842
+ self.mocked.assert_called_once_with(
843
+ target, **{'ingress_firewall_policy_id': None}
844
+ )
845
+ self.assertIsNone(result)
846
+
847
+ def test_unset_egress_policy(self):
848
+ target = self.resource['id']
849
+ arglist = [
850
+ target,
851
+ '--egress-firewall-policy',
852
+ ]
853
+ verifylist = [
854
+ (self.res, target),
855
+ ('egress_firewall_policy', True),
856
+ ]
857
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
858
+ result = self.cmd.take_action(parsed_args)
859
+ self.mocked.assert_called_once_with(
860
+ target, **{'egress_firewall_policy_id': None}
861
+ )
862
+ self.assertIsNone(result)
863
+
864
+ def test_unset_enable(self):
865
+ target = self.resource['id']
866
+ arglist = [
867
+ target,
868
+ '--enable',
869
+ ]
870
+ verifylist = [
871
+ (self.res, target),
872
+ ('enable', True),
873
+ ]
874
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
875
+ with mock.patch.object(fwaas_group.LOG, 'warning') as mock_warning:
876
+ result = self.cmd.take_action(parsed_args)
877
+ mock_warning.assert_called_once_with(
878
+ 'The --enable option is deprecated, please use '
879
+ '"firewall group set --disable" instead.'
880
+ )
881
+ self.mocked.assert_called_once_with(
882
+ target, **{'admin_state_up': False}
883
+ )
884
+ self.assertIsNone(result)
885
+
886
+ def test_unset_port(self):
887
+ target = self.resource['id']
888
+ port = 'old_port'
889
+
890
+ def _mock_port_fwg(*args, **kwargs):
891
+ return mock.Mock(id=args[0], ports=self.resource['ports'])
892
+
893
+ self.network_client.find_firewall_group.side_effect = _mock_port_fwg
894
+ self.network_client.find_port.side_effect = _mock_port_fwg
895
+
896
+ arglist = [
897
+ target,
898
+ '--port',
899
+ port,
900
+ ]
901
+ verifylist = [
902
+ (self.res, target),
903
+ ('port', [port]),
904
+ ]
905
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
906
+ result = self.cmd.take_action(parsed_args)
907
+ self.mocked.assert_called_once_with(target, **{'ports': []})
908
+ self.assertIsNone(result)
909
+
910
+ def test_unset_all_port(self):
911
+ target = self.resource['id']
912
+ arglist = [
913
+ target,
914
+ '--all-port',
915
+ ]
916
+ verifylist = [
917
+ (self.res, target),
918
+ ('all_port', True),
919
+ ]
920
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
921
+ result = self.cmd.take_action(parsed_args)
922
+ self.mocked.assert_called_once_with(target, **{'ports': []})
923
+ self.assertIsNone(result)