knife-ionoscloud 6.1.0 → 6.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (552) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/build.yml +17 -0
  3. data/.rubocop.yml +72 -0
  4. data/README.md +17 -15
  5. data/docs/README.md +16 -14
  6. data/docs/changelog.md +17 -0
  7. data/docs/docs_generator.rb +22 -24
  8. data/docs/subcommands/application-loadbalancer/applicationloadbalancer_create.md +60 -0
  9. data/docs/subcommands/application-loadbalancer/applicationloadbalancer_delete.md +41 -0
  10. data/docs/subcommands/application-loadbalancer/applicationloadbalancer_get.md +45 -0
  11. data/docs/subcommands/application-loadbalancer/applicationloadbalancer_list.md +41 -0
  12. data/docs/subcommands/application-loadbalancer/applicationloadbalancer_rule_add.md +69 -0
  13. data/docs/subcommands/application-loadbalancer/applicationloadbalancer_rule_httprule_add.md +78 -0
  14. data/docs/subcommands/application-loadbalancer/applicationloadbalancer_rule_httprule_remove.md +49 -0
  15. data/docs/subcommands/application-loadbalancer/applicationloadbalancer_rule_remove.md +45 -0
  16. data/docs/subcommands/application-loadbalancer/applicationloadbalancer_rule_update.md +70 -0
  17. data/docs/subcommands/application-loadbalancer/applicationloadbalancer_update.md +60 -0
  18. data/docs/subcommands/application-loadbalancer/targetgroup_create.md +79 -0
  19. data/docs/subcommands/application-loadbalancer/targetgroup_delete.md +37 -0
  20. data/docs/subcommands/application-loadbalancer/targetgroup_get.md +41 -0
  21. data/docs/subcommands/application-loadbalancer/targetgroup_list.md +37 -0
  22. data/docs/subcommands/application-loadbalancer/targetgroup_target_add.md +59 -0
  23. data/docs/subcommands/application-loadbalancer/targetgroup_target_remove.md +49 -0
  24. data/docs/subcommands/application-loadbalancer/targetgroup_update.md +80 -0
  25. data/docs/subcommands/backup/backupunit_create.md +8 -7
  26. data/docs/subcommands/backup/backupunit_delete.md +8 -7
  27. data/docs/subcommands/backup/backupunit_get.md +8 -7
  28. data/docs/subcommands/backup/backupunit_list.md +8 -7
  29. data/docs/subcommands/backup/backupunit_ssourl.md +8 -7
  30. data/docs/subcommands/backup/backupunit_update.md +8 -7
  31. data/docs/subcommands/compute-engine/composite_server_create.md +8 -7
  32. data/docs/subcommands/compute-engine/cube_server_create.md +8 -7
  33. data/docs/subcommands/compute-engine/datacenter_create.md +8 -7
  34. data/docs/subcommands/compute-engine/datacenter_delete.md +8 -7
  35. data/docs/subcommands/compute-engine/datacenter_get.md +8 -7
  36. data/docs/subcommands/compute-engine/datacenter_list.md +8 -7
  37. data/docs/subcommands/compute-engine/datacenter_update.md +8 -7
  38. data/docs/subcommands/compute-engine/firewall_create.md +8 -7
  39. data/docs/subcommands/compute-engine/firewall_delete.md +7 -6
  40. data/docs/subcommands/compute-engine/firewall_get.md +8 -7
  41. data/docs/subcommands/compute-engine/firewall_list.md +8 -7
  42. data/docs/subcommands/compute-engine/firewall_update.md +8 -7
  43. data/docs/subcommands/compute-engine/flowlog_create.md +8 -7
  44. data/docs/subcommands/compute-engine/flowlog_delete.md +7 -6
  45. data/docs/subcommands/compute-engine/flowlog_get.md +8 -7
  46. data/docs/subcommands/compute-engine/flowlog_list.md +8 -7
  47. data/docs/subcommands/compute-engine/flowlog_update.md +8 -7
  48. data/docs/subcommands/compute-engine/image_list.md +8 -7
  49. data/docs/subcommands/compute-engine/ipblock_create.md +8 -7
  50. data/docs/subcommands/compute-engine/ipblock_delete.md +8 -7
  51. data/docs/subcommands/compute-engine/ipblock_get.md +8 -7
  52. data/docs/subcommands/compute-engine/ipblock_list.md +8 -7
  53. data/docs/subcommands/compute-engine/ipblock_update.md +8 -7
  54. data/docs/subcommands/compute-engine/ipfailover_add.md +8 -7
  55. data/docs/subcommands/compute-engine/ipfailover_remove.md +8 -7
  56. data/docs/subcommands/compute-engine/label_add.md +8 -7
  57. data/docs/subcommands/compute-engine/label_list.md +8 -7
  58. data/docs/subcommands/compute-engine/label_remove.md +7 -6
  59. data/docs/subcommands/compute-engine/lan_create.md +8 -7
  60. data/docs/subcommands/compute-engine/lan_delete.md +7 -6
  61. data/docs/subcommands/compute-engine/lan_get.md +8 -7
  62. data/docs/subcommands/compute-engine/lan_list.md +8 -7
  63. data/docs/subcommands/compute-engine/lan_update.md +8 -7
  64. data/docs/subcommands/compute-engine/loadbalancer_create.md +8 -7
  65. data/docs/subcommands/compute-engine/loadbalancer_delete.md +7 -6
  66. data/docs/subcommands/compute-engine/loadbalancer_get.md +8 -7
  67. data/docs/subcommands/compute-engine/loadbalancer_list.md +8 -7
  68. data/docs/subcommands/compute-engine/loadbalancer_nic_add.md +7 -6
  69. data/docs/subcommands/compute-engine/loadbalancer_nic_remove.md +7 -6
  70. data/docs/subcommands/compute-engine/loadbalancer_update.md +8 -7
  71. data/docs/subcommands/compute-engine/location_list.md +8 -7
  72. data/docs/subcommands/compute-engine/natgateway_create.md +8 -7
  73. data/docs/subcommands/compute-engine/natgateway_delete.md +7 -6
  74. data/docs/subcommands/compute-engine/natgateway_get.md +8 -7
  75. data/docs/subcommands/compute-engine/natgateway_lan_add.md +8 -7
  76. data/docs/subcommands/compute-engine/natgateway_lan_remove.md +7 -6
  77. data/docs/subcommands/compute-engine/natgateway_list.md +8 -7
  78. data/docs/subcommands/compute-engine/natgateway_rule_add.md +8 -7
  79. data/docs/subcommands/compute-engine/natgateway_rule_list.md +8 -7
  80. data/docs/subcommands/compute-engine/natgateway_rule_remove.md +7 -6
  81. data/docs/subcommands/compute-engine/natgateway_rule_update.md +8 -7
  82. data/docs/subcommands/compute-engine/natgateway_update.md +8 -7
  83. data/docs/subcommands/compute-engine/networkloadbalancer_create.md +8 -7
  84. data/docs/subcommands/compute-engine/networkloadbalancer_delete.md +7 -6
  85. data/docs/subcommands/compute-engine/networkloadbalancer_get.md +8 -7
  86. data/docs/subcommands/compute-engine/networkloadbalancer_list.md +8 -7
  87. data/docs/subcommands/compute-engine/networkloadbalancer_rule_add.md +8 -7
  88. data/docs/subcommands/compute-engine/networkloadbalancer_rule_list.md +8 -7
  89. data/docs/subcommands/compute-engine/networkloadbalancer_rule_remove.md +7 -6
  90. data/docs/subcommands/compute-engine/networkloadbalancer_rule_target_add.md +8 -7
  91. data/docs/subcommands/compute-engine/networkloadbalancer_rule_target_list.md +8 -7
  92. data/docs/subcommands/compute-engine/networkloadbalancer_rule_target_remove.md +8 -7
  93. data/docs/subcommands/compute-engine/networkloadbalancer_rule_update.md +8 -7
  94. data/docs/subcommands/compute-engine/networkloadbalancer_update.md +8 -7
  95. data/docs/subcommands/compute-engine/nic_create.md +8 -7
  96. data/docs/subcommands/compute-engine/nic_delete.md +7 -6
  97. data/docs/subcommands/compute-engine/nic_get.md +8 -7
  98. data/docs/subcommands/compute-engine/nic_list.md +8 -7
  99. data/docs/subcommands/compute-engine/nic_update.md +8 -7
  100. data/docs/subcommands/compute-engine/pcc_create.md +8 -7
  101. data/docs/subcommands/compute-engine/pcc_delete.md +8 -7
  102. data/docs/subcommands/compute-engine/pcc_get.md +8 -7
  103. data/docs/subcommands/compute-engine/pcc_list.md +8 -7
  104. data/docs/subcommands/compute-engine/pcc_update.md +8 -7
  105. data/docs/subcommands/compute-engine/request_get.md +8 -7
  106. data/docs/subcommands/compute-engine/request_list.md +8 -7
  107. data/docs/subcommands/compute-engine/request_status.md +8 -7
  108. data/docs/subcommands/compute-engine/request_wait.md +8 -7
  109. data/docs/subcommands/compute-engine/server_console.md +8 -7
  110. data/docs/subcommands/compute-engine/server_create.md +8 -7
  111. data/docs/subcommands/compute-engine/server_delete.md +7 -6
  112. data/docs/subcommands/compute-engine/server_get.md +8 -7
  113. data/docs/subcommands/compute-engine/server_list.md +8 -7
  114. data/docs/subcommands/compute-engine/server_reboot.md +7 -6
  115. data/docs/subcommands/compute-engine/server_resume.md +7 -6
  116. data/docs/subcommands/compute-engine/server_start.md +7 -6
  117. data/docs/subcommands/compute-engine/server_stop.md +7 -6
  118. data/docs/subcommands/compute-engine/server_suspend.md +7 -6
  119. data/docs/subcommands/compute-engine/server_token.md +8 -7
  120. data/docs/subcommands/compute-engine/server_update.md +8 -7
  121. data/docs/subcommands/compute-engine/server_upgrade.md +8 -7
  122. data/docs/subcommands/compute-engine/snapshot_create.md +8 -7
  123. data/docs/subcommands/compute-engine/snapshot_delete.md +8 -7
  124. data/docs/subcommands/compute-engine/snapshot_get.md +8 -7
  125. data/docs/subcommands/compute-engine/snapshot_list.md +8 -7
  126. data/docs/subcommands/compute-engine/snapshot_restore.md +8 -7
  127. data/docs/subcommands/compute-engine/snapshot_update.md +8 -7
  128. data/docs/subcommands/compute-engine/template_list.md +8 -7
  129. data/docs/subcommands/compute-engine/volume_attach.md +7 -6
  130. data/docs/subcommands/compute-engine/volume_create.md +8 -7
  131. data/docs/subcommands/compute-engine/volume_delete.md +7 -6
  132. data/docs/subcommands/compute-engine/volume_detach.md +7 -6
  133. data/docs/subcommands/compute-engine/volume_get.md +8 -7
  134. data/docs/subcommands/compute-engine/volume_list.md +8 -7
  135. data/docs/subcommands/compute-engine/volume_update.md +8 -7
  136. data/docs/subcommands/dbaas-postgres/dbaas_postgres_backup_get.md +9 -8
  137. data/docs/subcommands/dbaas-postgres/dbaas_postgres_backup_list.md +9 -9
  138. data/docs/subcommands/dbaas-postgres/dbaas_postgres_cluster_create.md +13 -9
  139. data/docs/subcommands/dbaas-postgres/dbaas_postgres_cluster_delete.md +9 -8
  140. data/docs/subcommands/dbaas-postgres/dbaas_postgres_cluster_get.md +9 -8
  141. data/docs/subcommands/dbaas-postgres/dbaas_postgres_cluster_list.md +9 -8
  142. data/docs/subcommands/dbaas-postgres/dbaas_postgres_cluster_restore.md +9 -8
  143. data/docs/subcommands/dbaas-postgres/dbaas_postgres_cluster_update.md +9 -8
  144. data/docs/subcommands/dbaas-postgres/dbaas_postgres_logs_get.md +20 -10
  145. data/docs/subcommands/dbaas-postgres/dbaas_postgres_version_list.md +9 -9
  146. data/docs/subcommands/kubernetes/k8s_create.md +8 -7
  147. data/docs/subcommands/kubernetes/k8s_delete.md +8 -7
  148. data/docs/subcommands/kubernetes/k8s_get.md +8 -7
  149. data/docs/subcommands/kubernetes/k8s_list.md +8 -7
  150. data/docs/subcommands/kubernetes/k8s_update.md +8 -7
  151. data/docs/subcommands/kubernetes/kubeconfig_get.md +8 -7
  152. data/docs/subcommands/kubernetes/node_delete.md +7 -6
  153. data/docs/subcommands/kubernetes/node_get.md +8 -7
  154. data/docs/subcommands/kubernetes/node_list.md +8 -7
  155. data/docs/subcommands/kubernetes/node_replace.md +7 -6
  156. data/docs/subcommands/kubernetes/nodepool_create.md +8 -7
  157. data/docs/subcommands/kubernetes/nodepool_delete.md +7 -6
  158. data/docs/subcommands/kubernetes/nodepool_get.md +8 -7
  159. data/docs/subcommands/kubernetes/nodepool_lan_add.md +8 -7
  160. data/docs/subcommands/kubernetes/nodepool_lan_remove.md +7 -6
  161. data/docs/subcommands/kubernetes/nodepool_list.md +8 -7
  162. data/docs/subcommands/kubernetes/nodepool_update.md +8 -7
  163. data/docs/subcommands/user/contract_list.md +8 -7
  164. data/docs/subcommands/user/group_create.md +8 -7
  165. data/docs/subcommands/user/group_delete.md +8 -7
  166. data/docs/subcommands/user/group_get.md +8 -7
  167. data/docs/subcommands/user/group_list.md +8 -7
  168. data/docs/subcommands/user/group_update.md +8 -7
  169. data/docs/subcommands/user/group_user_add.md +7 -6
  170. data/docs/subcommands/user/group_user_remove.md +7 -6
  171. data/docs/subcommands/user/resource_list.md +8 -7
  172. data/docs/subcommands/user/s3key_create.md +8 -7
  173. data/docs/subcommands/user/s3key_delete.md +7 -6
  174. data/docs/subcommands/user/s3key_get.md +8 -7
  175. data/docs/subcommands/user/s3key_list.md +8 -7
  176. data/docs/subcommands/user/share_create.md +8 -7
  177. data/docs/subcommands/user/share_delete.md +7 -6
  178. data/docs/subcommands/user/share_get.md +8 -7
  179. data/docs/subcommands/user/share_list.md +8 -7
  180. data/docs/subcommands/user/share_update.md +8 -7
  181. data/docs/subcommands/user/user_create.md +8 -7
  182. data/docs/subcommands/user/user_delete.md +8 -7
  183. data/docs/subcommands/user/user_get.md +8 -7
  184. data/docs/subcommands/user/user_list.md +8 -7
  185. data/docs/subcommands/user/user_ssourl.md +8 -7
  186. data/docs/subcommands/user/user_update.md +8 -7
  187. data/docs/summary.md +150 -132
  188. data/knife-ionoscloud.gemspec +3 -2
  189. data/lib/chef/knife/ionoscloud_applicationloadbalancer_create.rb +85 -0
  190. data/lib/chef/knife/ionoscloud_applicationloadbalancer_delete.rb +64 -0
  191. data/lib/chef/knife/ionoscloud_applicationloadbalancer_get.rb +45 -0
  192. data/lib/chef/knife/ionoscloud_applicationloadbalancer_list.rb +56 -0
  193. data/lib/chef/knife/ionoscloud_applicationloadbalancer_rule_add.rb +129 -0
  194. data/lib/chef/knife/ionoscloud_applicationloadbalancer_rule_httprule_add.rb +159 -0
  195. data/lib/chef/knife/ionoscloud_applicationloadbalancer_rule_httprule_remove.rb +89 -0
  196. data/lib/chef/knife/ionoscloud_applicationloadbalancer_rule_remove.rb +70 -0
  197. data/lib/chef/knife/ionoscloud_applicationloadbalancer_rule_update.rb +137 -0
  198. data/lib/chef/knife/ionoscloud_applicationloadbalancer_update.rb +96 -0
  199. data/lib/chef/knife/ionoscloud_backupunit_create.rb +1 -1
  200. data/lib/chef/knife/ionoscloud_backupunit_delete.rb +1 -2
  201. data/lib/chef/knife/ionoscloud_backupunit_get.rb +1 -1
  202. data/lib/chef/knife/ionoscloud_backupunit_list.rb +0 -1
  203. data/lib/chef/knife/ionoscloud_backupunit_ssourl.rb +1 -1
  204. data/lib/chef/knife/ionoscloud_backupunit_update.rb +2 -2
  205. data/lib/chef/knife/ionoscloud_base.rb +161 -11
  206. data/lib/chef/knife/ionoscloud_composite_server_create.rb +3 -3
  207. data/lib/chef/knife/ionoscloud_contract_list.rb +1 -3
  208. data/lib/chef/knife/ionoscloud_cube_server_create.rb +4 -4
  209. data/lib/chef/knife/ionoscloud_datacenter_create.rb +3 -3
  210. data/lib/chef/knife/ionoscloud_datacenter_delete.rb +1 -2
  211. data/lib/chef/knife/ionoscloud_datacenter_get.rb +1 -1
  212. data/lib/chef/knife/ionoscloud_datacenter_list.rb +0 -1
  213. data/lib/chef/knife/ionoscloud_datacenter_update.rb +3 -3
  214. data/lib/chef/knife/ionoscloud_dbaas_postgres_backup_get.rb +3 -3
  215. data/lib/chef/knife/ionoscloud_dbaas_postgres_backup_list.rb +2 -3
  216. data/lib/chef/knife/ionoscloud_dbaas_postgres_cluster_create.rb +12 -8
  217. data/lib/chef/knife/ionoscloud_dbaas_postgres_cluster_delete.rb +2 -3
  218. data/lib/chef/knife/ionoscloud_dbaas_postgres_cluster_get.rb +4 -4
  219. data/lib/chef/knife/ionoscloud_dbaas_postgres_cluster_list.rb +3 -2
  220. data/lib/chef/knife/ionoscloud_dbaas_postgres_cluster_restore.rb +1 -1
  221. data/lib/chef/knife/ionoscloud_dbaas_postgres_cluster_update.rb +3 -5
  222. data/lib/chef/knife/ionoscloud_dbaas_postgres_logs_get.rb +38 -7
  223. data/lib/chef/knife/ionoscloud_dbaas_postgres_version_list.rb +3 -3
  224. data/lib/chef/knife/ionoscloud_firewall_create.rb +2 -2
  225. data/lib/chef/knife/ionoscloud_firewall_delete.rb +2 -2
  226. data/lib/chef/knife/ionoscloud_firewall_get.rb +1 -1
  227. data/lib/chef/knife/ionoscloud_firewall_list.rb +2 -2
  228. data/lib/chef/knife/ionoscloud_firewall_update.rb +1 -1
  229. data/lib/chef/knife/ionoscloud_flowlog_create.rb +1 -1
  230. data/lib/chef/knife/ionoscloud_flowlog_delete.rb +2 -4
  231. data/lib/chef/knife/ionoscloud_flowlog_get.rb +1 -1
  232. data/lib/chef/knife/ionoscloud_flowlog_list.rb +4 -6
  233. data/lib/chef/knife/ionoscloud_flowlog_update.rb +1 -1
  234. data/lib/chef/knife/ionoscloud_group_create.rb +1 -1
  235. data/lib/chef/knife/ionoscloud_group_delete.rb +1 -2
  236. data/lib/chef/knife/ionoscloud_group_get.rb +1 -1
  237. data/lib/chef/knife/ionoscloud_group_list.rb +0 -1
  238. data/lib/chef/knife/ionoscloud_group_update.rb +2 -2
  239. data/lib/chef/knife/ionoscloud_group_user_add.rb +1 -1
  240. data/lib/chef/knife/ionoscloud_group_user_remove.rb +1 -1
  241. data/lib/chef/knife/ionoscloud_image_list.rb +0 -1
  242. data/lib/chef/knife/ionoscloud_ipblock_create.rb +1 -1
  243. data/lib/chef/knife/ionoscloud_ipblock_delete.rb +1 -2
  244. data/lib/chef/knife/ionoscloud_ipblock_get.rb +1 -1
  245. data/lib/chef/knife/ionoscloud_ipblock_list.rb +0 -1
  246. data/lib/chef/knife/ionoscloud_ipblock_update.rb +1 -1
  247. data/lib/chef/knife/ionoscloud_ipfailover_add.rb +1 -1
  248. data/lib/chef/knife/ionoscloud_ipfailover_remove.rb +1 -1
  249. data/lib/chef/knife/ionoscloud_k8s_create.rb +1 -1
  250. data/lib/chef/knife/ionoscloud_k8s_delete.rb +2 -3
  251. data/lib/chef/knife/ionoscloud_k8s_get.rb +1 -1
  252. data/lib/chef/knife/ionoscloud_k8s_list.rb +0 -1
  253. data/lib/chef/knife/ionoscloud_k8s_update.rb +3 -7
  254. data/lib/chef/knife/ionoscloud_kubeconfig_get.rb +1 -1
  255. data/lib/chef/knife/ionoscloud_label_add.rb +1 -1
  256. data/lib/chef/knife/ionoscloud_label_list.rb +1 -4
  257. data/lib/chef/knife/ionoscloud_label_remove.rb +1 -1
  258. data/lib/chef/knife/ionoscloud_lan_create.rb +1 -1
  259. data/lib/chef/knife/ionoscloud_lan_delete.rb +2 -2
  260. data/lib/chef/knife/ionoscloud_lan_get.rb +1 -1
  261. data/lib/chef/knife/ionoscloud_lan_list.rb +1 -1
  262. data/lib/chef/knife/ionoscloud_lan_update.rb +1 -1
  263. data/lib/chef/knife/ionoscloud_loadbalancer_create.rb +1 -1
  264. data/lib/chef/knife/ionoscloud_loadbalancer_delete.rb +2 -2
  265. data/lib/chef/knife/ionoscloud_loadbalancer_get.rb +1 -1
  266. data/lib/chef/knife/ionoscloud_loadbalancer_list.rb +1 -1
  267. data/lib/chef/knife/ionoscloud_loadbalancer_nic_add.rb +1 -1
  268. data/lib/chef/knife/ionoscloud_loadbalancer_nic_remove.rb +1 -1
  269. data/lib/chef/knife/ionoscloud_loadbalancer_update.rb +1 -1
  270. data/lib/chef/knife/ionoscloud_location_list.rb +0 -1
  271. data/lib/chef/knife/ionoscloud_natgateway_create.rb +2 -2
  272. data/lib/chef/knife/ionoscloud_natgateway_delete.rb +2 -2
  273. data/lib/chef/knife/ionoscloud_natgateway_get.rb +1 -1
  274. data/lib/chef/knife/ionoscloud_natgateway_lan_add.rb +1 -1
  275. data/lib/chef/knife/ionoscloud_natgateway_lan_remove.rb +1 -1
  276. data/lib/chef/knife/ionoscloud_natgateway_list.rb +1 -1
  277. data/lib/chef/knife/ionoscloud_natgateway_rule_add.rb +2 -2
  278. data/lib/chef/knife/ionoscloud_natgateway_rule_list.rb +1 -1
  279. data/lib/chef/knife/ionoscloud_natgateway_rule_remove.rb +1 -1
  280. data/lib/chef/knife/ionoscloud_natgateway_rule_update.rb +2 -2
  281. data/lib/chef/knife/ionoscloud_natgateway_update.rb +2 -3
  282. data/lib/chef/knife/ionoscloud_networkloadbalancer_create.rb +1 -1
  283. data/lib/chef/knife/ionoscloud_networkloadbalancer_delete.rb +2 -2
  284. data/lib/chef/knife/ionoscloud_networkloadbalancer_get.rb +1 -1
  285. data/lib/chef/knife/ionoscloud_networkloadbalancer_list.rb +1 -1
  286. data/lib/chef/knife/ionoscloud_networkloadbalancer_rule_add.rb +2 -3
  287. data/lib/chef/knife/ionoscloud_networkloadbalancer_rule_list.rb +1 -1
  288. data/lib/chef/knife/ionoscloud_networkloadbalancer_rule_remove.rb +1 -1
  289. data/lib/chef/knife/ionoscloud_networkloadbalancer_rule_target_add.rb +1 -1
  290. data/lib/chef/knife/ionoscloud_networkloadbalancer_rule_target_list.rb +1 -1
  291. data/lib/chef/knife/ionoscloud_networkloadbalancer_rule_target_remove.rb +2 -3
  292. data/lib/chef/knife/ionoscloud_networkloadbalancer_rule_update.rb +2 -3
  293. data/lib/chef/knife/ionoscloud_networkloadbalancer_update.rb +1 -1
  294. data/lib/chef/knife/ionoscloud_nic_create.rb +4 -4
  295. data/lib/chef/knife/ionoscloud_nic_delete.rb +2 -2
  296. data/lib/chef/knife/ionoscloud_nic_get.rb +1 -1
  297. data/lib/chef/knife/ionoscloud_nic_list.rb +1 -1
  298. data/lib/chef/knife/ionoscloud_nic_update.rb +1 -1
  299. data/lib/chef/knife/ionoscloud_node_delete.rb +2 -2
  300. data/lib/chef/knife/ionoscloud_node_get.rb +1 -1
  301. data/lib/chef/knife/ionoscloud_node_list.rb +1 -1
  302. data/lib/chef/knife/ionoscloud_node_replace.rb +4 -4
  303. data/lib/chef/knife/ionoscloud_nodepool_create.rb +3 -3
  304. data/lib/chef/knife/ionoscloud_nodepool_delete.rb +2 -2
  305. data/lib/chef/knife/ionoscloud_nodepool_get.rb +1 -1
  306. data/lib/chef/knife/ionoscloud_nodepool_lan_add.rb +1 -1
  307. data/lib/chef/knife/ionoscloud_nodepool_lan_remove.rb +1 -1
  308. data/lib/chef/knife/ionoscloud_nodepool_list.rb +1 -1
  309. data/lib/chef/knife/ionoscloud_nodepool_update.rb +1 -1
  310. data/lib/chef/knife/ionoscloud_pcc_create.rb +0 -1
  311. data/lib/chef/knife/ionoscloud_pcc_delete.rb +1 -2
  312. data/lib/chef/knife/ionoscloud_pcc_get.rb +1 -1
  313. data/lib/chef/knife/ionoscloud_pcc_list.rb +0 -1
  314. data/lib/chef/knife/ionoscloud_pcc_update.rb +2 -2
  315. data/lib/chef/knife/ionoscloud_request_get.rb +1 -1
  316. data/lib/chef/knife/ionoscloud_request_list.rb +6 -19
  317. data/lib/chef/knife/ionoscloud_request_status.rb +1 -1
  318. data/lib/chef/knife/ionoscloud_request_wait.rb +1 -1
  319. data/lib/chef/knife/ionoscloud_resource_list.rb +10 -13
  320. data/lib/chef/knife/ionoscloud_s3key_create.rb +1 -1
  321. data/lib/chef/knife/ionoscloud_s3key_delete.rb +2 -2
  322. data/lib/chef/knife/ionoscloud_s3key_get.rb +1 -1
  323. data/lib/chef/knife/ionoscloud_s3key_list.rb +1 -1
  324. data/lib/chef/knife/ionoscloud_server_console.rb +1 -1
  325. data/lib/chef/knife/ionoscloud_server_create.rb +4 -4
  326. data/lib/chef/knife/ionoscloud_server_delete.rb +4 -4
  327. data/lib/chef/knife/ionoscloud_server_get.rb +1 -1
  328. data/lib/chef/knife/ionoscloud_server_list.rb +1 -1
  329. data/lib/chef/knife/ionoscloud_server_reboot.rb +1 -1
  330. data/lib/chef/knife/ionoscloud_server_resume.rb +1 -1
  331. data/lib/chef/knife/ionoscloud_server_start.rb +1 -1
  332. data/lib/chef/knife/ionoscloud_server_stop.rb +1 -1
  333. data/lib/chef/knife/ionoscloud_server_suspend.rb +1 -1
  334. data/lib/chef/knife/ionoscloud_server_token.rb +1 -1
  335. data/lib/chef/knife/ionoscloud_server_update.rb +1 -1
  336. data/lib/chef/knife/ionoscloud_server_upgrade.rb +2 -2
  337. data/lib/chef/knife/ionoscloud_share_create.rb +1 -1
  338. data/lib/chef/knife/ionoscloud_share_delete.rb +2 -2
  339. data/lib/chef/knife/ionoscloud_share_get.rb +1 -1
  340. data/lib/chef/knife/ionoscloud_share_list.rb +1 -1
  341. data/lib/chef/knife/ionoscloud_share_update.rb +1 -1
  342. data/lib/chef/knife/ionoscloud_snapshot_create.rb +1 -1
  343. data/lib/chef/knife/ionoscloud_snapshot_delete.rb +1 -2
  344. data/lib/chef/knife/ionoscloud_snapshot_get.rb +1 -1
  345. data/lib/chef/knife/ionoscloud_snapshot_list.rb +1 -2
  346. data/lib/chef/knife/ionoscloud_snapshot_restore.rb +1 -1
  347. data/lib/chef/knife/ionoscloud_snapshot_update.rb +1 -1
  348. data/lib/chef/knife/ionoscloud_targetgroup_create.rb +140 -0
  349. data/lib/chef/knife/ionoscloud_targetgroup_delete.rb +50 -0
  350. data/lib/chef/knife/ionoscloud_targetgroup_get.rb +34 -0
  351. data/lib/chef/knife/ionoscloud_targetgroup_list.rb +45 -0
  352. data/lib/chef/knife/ionoscloud_targetgroup_target_add.rb +93 -0
  353. data/lib/chef/knife/ionoscloud_targetgroup_target_remove.rb +66 -0
  354. data/lib/chef/knife/ionoscloud_targetgroup_update.rb +151 -0
  355. data/lib/chef/knife/ionoscloud_template_list.rb +0 -1
  356. data/lib/chef/knife/ionoscloud_user_create.rb +1 -1
  357. data/lib/chef/knife/ionoscloud_user_delete.rb +1 -2
  358. data/lib/chef/knife/ionoscloud_user_get.rb +1 -1
  359. data/lib/chef/knife/ionoscloud_user_list.rb +0 -1
  360. data/lib/chef/knife/ionoscloud_user_ssourl.rb +1 -1
  361. data/lib/chef/knife/ionoscloud_user_update.rb +1 -1
  362. data/lib/chef/knife/ionoscloud_volume_attach.rb +1 -1
  363. data/lib/chef/knife/ionoscloud_volume_create.rb +1 -1
  364. data/lib/chef/knife/ionoscloud_volume_delete.rb +2 -2
  365. data/lib/chef/knife/ionoscloud_volume_detach.rb +5 -5
  366. data/lib/chef/knife/ionoscloud_volume_get.rb +1 -1
  367. data/lib/chef/knife/ionoscloud_volume_list.rb +1 -1
  368. data/lib/chef/knife/ionoscloud_volume_update.rb +1 -1
  369. data/lib/knife-ionoscloud/version.rb +1 -1
  370. data/sonar-project.properties +3 -0
  371. data/spec/chef/knife/ionoscloud_applicationloadbalancer_create_spec.rb +82 -0
  372. data/spec/chef/knife/ionoscloud_applicationloadbalancer_delete_spec.rb +110 -0
  373. data/spec/chef/knife/ionoscloud_applicationloadbalancer_get_spec.rb +70 -0
  374. data/spec/chef/knife/ionoscloud_applicationloadbalancer_list_spec.rb +87 -0
  375. data/spec/chef/knife/ionoscloud_applicationloadbalancer_rule_add_spec.rb +140 -0
  376. data/spec/chef/knife/ionoscloud_applicationloadbalancer_rule_httprule_add_spec.rb +238 -0
  377. data/spec/chef/knife/ionoscloud_applicationloadbalancer_rule_httprule_remove_spec.rb +204 -0
  378. data/spec/chef/knife/ionoscloud_applicationloadbalancer_rule_remove_spec.rb +127 -0
  379. data/spec/chef/knife/ionoscloud_applicationloadbalancer_rule_update_spec.rb +219 -0
  380. data/spec/chef/knife/ionoscloud_applicationloadbalancer_update_spec.rb +97 -0
  381. data/spec/chef/knife/ionoscloud_backupunit_create_spec.rb +11 -9
  382. data/spec/chef/knife/ionoscloud_backupunit_delete_spec.rb +10 -8
  383. data/spec/chef/knife/ionoscloud_backupunit_get_spec.rb +10 -8
  384. data/spec/chef/knife/ionoscloud_backupunit_list_spec.rb +10 -8
  385. data/spec/chef/knife/ionoscloud_backupunit_ssourl_spec.rb +11 -12
  386. data/spec/chef/knife/ionoscloud_backupunit_update_spec.rb +10 -8
  387. data/spec/chef/knife/ionoscloud_base_spec.rb +52 -4
  388. data/spec/chef/knife/ionoscloud_composite_server_create_spec.rb +10 -8
  389. data/spec/chef/knife/ionoscloud_contract_list_spec.rb +10 -8
  390. data/spec/chef/knife/ionoscloud_cube_server_create_spec.rb +12 -10
  391. data/spec/chef/knife/ionoscloud_datacenter_create_spec.rb +10 -8
  392. data/spec/chef/knife/ionoscloud_datacenter_delete_spec.rb +10 -8
  393. data/spec/chef/knife/ionoscloud_datacenter_get_spec.rb +10 -8
  394. data/spec/chef/knife/ionoscloud_datacenter_list_spec.rb +10 -8
  395. data/spec/chef/knife/ionoscloud_datacenter_update_spec.rb +10 -8
  396. data/spec/chef/knife/ionoscloud_dbaas_postgres_backup_get_spec.rb +10 -8
  397. data/spec/chef/knife/ionoscloud_dbaas_postgres_backup_list_spec.rb +11 -9
  398. data/spec/chef/knife/ionoscloud_dbaas_postgres_cluster_create_spec.rb +14 -10
  399. data/spec/chef/knife/ionoscloud_dbaas_postgres_cluster_delete_spec.rb +11 -8
  400. data/spec/chef/knife/ionoscloud_dbaas_postgres_cluster_get_spec.rb +11 -8
  401. data/spec/chef/knife/ionoscloud_dbaas_postgres_cluster_list_spec.rb +13 -9
  402. data/spec/chef/knife/ionoscloud_dbaas_postgres_cluster_restore_spec.rb +10 -8
  403. data/spec/chef/knife/ionoscloud_dbaas_postgres_cluster_update_spec.rb +11 -8
  404. data/spec/chef/knife/ionoscloud_dbaas_postgres_logs_get_spec.rb +85 -11
  405. data/spec/chef/knife/ionoscloud_dbaas_postgres_version_list_spec.rb +12 -10
  406. data/spec/chef/knife/ionoscloud_firewall_create_spec.rb +10 -8
  407. data/spec/chef/knife/ionoscloud_firewall_delete_spec.rb +10 -8
  408. data/spec/chef/knife/ionoscloud_firewall_get_spec.rb +10 -8
  409. data/spec/chef/knife/ionoscloud_firewall_list_spec.rb +10 -8
  410. data/spec/chef/knife/ionoscloud_firewall_update_spec.rb +12 -10
  411. data/spec/chef/knife/ionoscloud_flowlog_create_spec.rb +10 -8
  412. data/spec/chef/knife/ionoscloud_flowlog_delete_spec.rb +10 -8
  413. data/spec/chef/knife/ionoscloud_flowlog_get_spec.rb +10 -9
  414. data/spec/chef/knife/ionoscloud_flowlog_list_spec.rb +10 -8
  415. data/spec/chef/knife/ionoscloud_flowlog_update_spec.rb +10 -9
  416. data/spec/chef/knife/ionoscloud_group_create_spec.rb +10 -8
  417. data/spec/chef/knife/ionoscloud_group_delete_spec.rb +10 -8
  418. data/spec/chef/knife/ionoscloud_group_get_spec.rb +10 -8
  419. data/spec/chef/knife/ionoscloud_group_list_spec.rb +12 -10
  420. data/spec/chef/knife/ionoscloud_group_update_spec.rb +10 -8
  421. data/spec/chef/knife/ionoscloud_group_user_add_spec.rb +10 -8
  422. data/spec/chef/knife/ionoscloud_group_user_remove_spec.rb +10 -8
  423. data/spec/chef/knife/ionoscloud_image_list_spec.rb +10 -8
  424. data/spec/chef/knife/ionoscloud_ipblock_create_spec.rb +10 -8
  425. data/spec/chef/knife/ionoscloud_ipblock_delete_spec.rb +10 -8
  426. data/spec/chef/knife/ionoscloud_ipblock_get_spec.rb +10 -8
  427. data/spec/chef/knife/ionoscloud_ipblock_list_spec.rb +10 -8
  428. data/spec/chef/knife/ionoscloud_ipblock_update_spec.rb +10 -8
  429. data/spec/chef/knife/ionoscloud_ipfailover_add_spec.rb +10 -8
  430. data/spec/chef/knife/ionoscloud_ipfailover_remove_spec.rb +10 -8
  431. data/spec/chef/knife/ionoscloud_k8s_create_spec.rb +10 -8
  432. data/spec/chef/knife/ionoscloud_k8s_delete_spec.rb +13 -11
  433. data/spec/chef/knife/ionoscloud_k8s_get_spec.rb +10 -8
  434. data/spec/chef/knife/ionoscloud_k8s_list_spec.rb +10 -8
  435. data/spec/chef/knife/ionoscloud_k8s_update_spec.rb +12 -10
  436. data/spec/chef/knife/ionoscloud_kubeconfig_get_spec.rb +11 -12
  437. data/spec/chef/knife/ionoscloud_label_add_spec.rb +11 -9
  438. data/spec/chef/knife/ionoscloud_label_list_spec.rb +14 -12
  439. data/spec/chef/knife/ionoscloud_label_remove_spec.rb +11 -9
  440. data/spec/chef/knife/ionoscloud_lan_create_spec.rb +10 -8
  441. data/spec/chef/knife/ionoscloud_lan_delete_spec.rb +10 -8
  442. data/spec/chef/knife/ionoscloud_lan_get_spec.rb +10 -8
  443. data/spec/chef/knife/ionoscloud_lan_list_spec.rb +10 -8
  444. data/spec/chef/knife/ionoscloud_lan_update_spec.rb +10 -8
  445. data/spec/chef/knife/ionoscloud_loadbalancer_create_spec.rb +10 -8
  446. data/spec/chef/knife/ionoscloud_loadbalancer_delete_spec.rb +10 -8
  447. data/spec/chef/knife/ionoscloud_loadbalancer_get_spec.rb +10 -8
  448. data/spec/chef/knife/ionoscloud_loadbalancer_list_spec.rb +10 -8
  449. data/spec/chef/knife/ionoscloud_loadbalancer_nic_add_spec.rb +10 -8
  450. data/spec/chef/knife/ionoscloud_loadbalancer_nic_remove_spec.rb +10 -8
  451. data/spec/chef/knife/ionoscloud_loadbalancer_update_spec.rb +11 -9
  452. data/spec/chef/knife/ionoscloud_location_list_spec.rb +11 -9
  453. data/spec/chef/knife/ionoscloud_natgateway_create_spec.rb +10 -8
  454. data/spec/chef/knife/ionoscloud_natgateway_delete_spec.rb +10 -8
  455. data/spec/chef/knife/ionoscloud_natgateway_get_spec.rb +10 -8
  456. data/spec/chef/knife/ionoscloud_natgateway_lan_add_spec.rb +12 -10
  457. data/spec/chef/knife/ionoscloud_natgateway_lan_remove_spec.rb +10 -8
  458. data/spec/chef/knife/ionoscloud_natgateway_list_spec.rb +10 -8
  459. data/spec/chef/knife/ionoscloud_natgateway_rule_add_spec.rb +10 -8
  460. data/spec/chef/knife/ionoscloud_natgateway_rule_list_spec.rb +10 -8
  461. data/spec/chef/knife/ionoscloud_natgateway_rule_remove_spec.rb +10 -8
  462. data/spec/chef/knife/ionoscloud_natgateway_rule_update_spec.rb +14 -12
  463. data/spec/chef/knife/ionoscloud_natgateway_update_spec.rb +14 -13
  464. data/spec/chef/knife/ionoscloud_networkloadbalancer_create_spec.rb +10 -8
  465. data/spec/chef/knife/ionoscloud_networkloadbalancer_delete_spec.rb +10 -8
  466. data/spec/chef/knife/ionoscloud_networkloadbalancer_get_spec.rb +10 -8
  467. data/spec/chef/knife/ionoscloud_networkloadbalancer_list_spec.rb +10 -8
  468. data/spec/chef/knife/ionoscloud_networkloadbalancer_rule_add_spec.rb +10 -8
  469. data/spec/chef/knife/ionoscloud_networkloadbalancer_rule_list_spec.rb +10 -8
  470. data/spec/chef/knife/ionoscloud_networkloadbalancer_rule_remove_spec.rb +10 -8
  471. data/spec/chef/knife/ionoscloud_networkloadbalancer_rule_target_add_spec.rb +11 -9
  472. data/spec/chef/knife/ionoscloud_networkloadbalancer_rule_target_list_spec.rb +10 -8
  473. data/spec/chef/knife/ionoscloud_networkloadbalancer_rule_target_remove_spec.rb +22 -22
  474. data/spec/chef/knife/ionoscloud_networkloadbalancer_rule_update_spec.rb +14 -13
  475. data/spec/chef/knife/ionoscloud_networkloadbalancer_update_spec.rb +12 -10
  476. data/spec/chef/knife/ionoscloud_nic_create_spec.rb +10 -8
  477. data/spec/chef/knife/ionoscloud_nic_delete_spec.rb +10 -8
  478. data/spec/chef/knife/ionoscloud_nic_get_spec.rb +10 -8
  479. data/spec/chef/knife/ionoscloud_nic_list_spec.rb +10 -8
  480. data/spec/chef/knife/ionoscloud_nic_update_spec.rb +11 -9
  481. data/spec/chef/knife/ionoscloud_node_delete_spec.rb +10 -8
  482. data/spec/chef/knife/ionoscloud_node_get_spec.rb +10 -8
  483. data/spec/chef/knife/ionoscloud_node_list_spec.rb +10 -8
  484. data/spec/chef/knife/ionoscloud_node_replace_spec.rb +10 -8
  485. data/spec/chef/knife/ionoscloud_nodepool_create_spec.rb +11 -8
  486. data/spec/chef/knife/ionoscloud_nodepool_delete_spec.rb +11 -8
  487. data/spec/chef/knife/ionoscloud_nodepool_get_spec.rb +10 -8
  488. data/spec/chef/knife/ionoscloud_nodepool_lan_add_spec.rb +11 -10
  489. data/spec/chef/knife/{ionoscloud_nodepool_lan_remove.rb → ionoscloud_nodepool_lan_remove_spec.rb} +22 -24
  490. data/spec/chef/knife/ionoscloud_nodepool_list_spec.rb +10 -8
  491. data/spec/chef/knife/ionoscloud_nodepool_update_spec.rb +12 -10
  492. data/spec/chef/knife/ionoscloud_pcc_create_spec.rb +10 -8
  493. data/spec/chef/knife/ionoscloud_pcc_delete_spec.rb +10 -8
  494. data/spec/chef/knife/ionoscloud_pcc_get_spec.rb +10 -8
  495. data/spec/chef/knife/ionoscloud_pcc_list_spec.rb +10 -8
  496. data/spec/chef/knife/ionoscloud_pcc_update_spec.rb +10 -8
  497. data/spec/chef/knife/ionoscloud_request_get_spec.rb +10 -8
  498. data/spec/chef/knife/ionoscloud_request_list_spec.rb +11 -10
  499. data/spec/chef/knife/ionoscloud_request_status_spec.rb +11 -12
  500. data/spec/chef/knife/ionoscloud_request_wait_spec.rb +11 -13
  501. data/spec/chef/knife/ionoscloud_resource_list_spec.rb +11 -10
  502. data/spec/chef/knife/ionoscloud_s3key_create_spec.rb +10 -8
  503. data/spec/chef/knife/ionoscloud_s3key_delete_spec.rb +10 -8
  504. data/spec/chef/knife/ionoscloud_s3key_get_spec.rb +10 -8
  505. data/spec/chef/knife/ionoscloud_s3key_list_spec.rb +10 -8
  506. data/spec/chef/knife/ionoscloud_server_console_spec.rb +11 -12
  507. data/spec/chef/knife/ionoscloud_server_create_spec.rb +10 -8
  508. data/spec/chef/knife/ionoscloud_server_delete_spec.rb +10 -8
  509. data/spec/chef/knife/ionoscloud_server_get_spec.rb +10 -8
  510. data/spec/chef/knife/ionoscloud_server_list_spec.rb +10 -8
  511. data/spec/chef/knife/ionoscloud_server_reboot_spec.rb +10 -8
  512. data/spec/chef/knife/ionoscloud_server_resume_spec.rb +10 -8
  513. data/spec/chef/knife/ionoscloud_server_start_spec.rb +10 -8
  514. data/spec/chef/knife/ionoscloud_server_stop_spec.rb +10 -8
  515. data/spec/chef/knife/ionoscloud_server_suspend_spec.rb +10 -8
  516. data/spec/chef/knife/ionoscloud_server_token_spec.rb +11 -12
  517. data/spec/chef/knife/ionoscloud_server_update_spec.rb +10 -8
  518. data/spec/chef/knife/ionoscloud_server_upgrade_spec.rb +10 -8
  519. data/spec/chef/knife/ionoscloud_share_create_spec.rb +10 -8
  520. data/spec/chef/knife/ionoscloud_share_delete_spec.rb +10 -8
  521. data/spec/chef/knife/ionoscloud_share_get_spec.rb +10 -8
  522. data/spec/chef/knife/ionoscloud_share_list_spec.rb +10 -8
  523. data/spec/chef/knife/ionoscloud_share_update_spec.rb +10 -8
  524. data/spec/chef/knife/ionoscloud_snapshot_create_spec.rb +10 -8
  525. data/spec/chef/knife/ionoscloud_snapshot_delete_spec.rb +10 -8
  526. data/spec/chef/knife/ionoscloud_snapshot_get_spec.rb +10 -8
  527. data/spec/chef/knife/ionoscloud_snapshot_list_spec.rb +10 -8
  528. data/spec/chef/knife/ionoscloud_snapshot_restore_spec.rb +10 -8
  529. data/spec/chef/knife/ionoscloud_snapshot_update_spec.rb +10 -8
  530. data/spec/chef/knife/ionoscloud_targetgroup_create_spec.rb +109 -0
  531. data/spec/chef/knife/ionoscloud_targetgroup_delete_spec.rb +111 -0
  532. data/spec/chef/knife/ionoscloud_targetgroup_get_spec.rb +71 -0
  533. data/spec/chef/knife/ionoscloud_targetgroup_list_spec.rb +78 -0
  534. data/spec/chef/knife/ionoscloud_targetgroup_target_add_spec.rb +164 -0
  535. data/spec/chef/knife/ionoscloud_targetgroup_target_remove_spec.rb +139 -0
  536. data/spec/chef/knife/ionoscloud_targetgroup_update_spec.rb +144 -0
  537. data/spec/chef/knife/ionoscloud_template_list_spec.rb +10 -8
  538. data/spec/chef/knife/ionoscloud_user_create_spec.rb +10 -8
  539. data/spec/chef/knife/ionoscloud_user_delete_spec.rb +10 -8
  540. data/spec/chef/knife/ionoscloud_user_get_spec.rb +10 -8
  541. data/spec/chef/knife/ionoscloud_user_list_spec.rb +12 -10
  542. data/spec/chef/knife/ionoscloud_user_ssourl_spec.rb +11 -12
  543. data/spec/chef/knife/ionoscloud_user_update_spec.rb +10 -8
  544. data/spec/chef/knife/ionoscloud_volume_attach_spec.rb +10 -8
  545. data/spec/chef/knife/ionoscloud_volume_create_spec.rb +10 -8
  546. data/spec/chef/knife/ionoscloud_volume_delete_spec.rb +10 -8
  547. data/spec/chef/knife/ionoscloud_volume_detach_spec.rb +10 -8
  548. data/spec/chef/knife/ionoscloud_volume_get_spec.rb +10 -8
  549. data/spec/chef/knife/ionoscloud_volume_list_spec.rb +12 -10
  550. data/spec/chef/knife/ionoscloud_volume_update_spec.rb +10 -8
  551. data/spec/spec_helper.rb +145 -34
  552. metadata +81 -13
@@ -0,0 +1,238 @@
1
+ require 'spec_helper'
2
+ require 'ionoscloud_applicationloadbalancer_rule_httprule_add'
3
+
4
+ Chef::Knife::IonoscloudApplicationloadbalancerRuleHttpruleAdd.load_deps
5
+
6
+ describe Chef::Knife::IonoscloudApplicationloadbalancerRuleHttpruleAdd do
7
+ before :each do
8
+ subject { Chef::Knife::IonoscloudApplicationloadbalancerRuleHttpruleAdd.new }
9
+
10
+ allow(subject).to receive(:puts)
11
+ allow(subject).to receive(:print)
12
+ end
13
+
14
+ describe '#run' do
15
+ it 'should call ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_patch_with_http_info '\
16
+ 'and add a new Http Rule' do
17
+ application_loadbalancer = application_loadbalancer_mock
18
+ application_loadbalancer_rule_httprule = application_loadbalancer_rule_httprule_mock(name: 'test')
19
+ subject_config = {
20
+ ionoscloud_username: 'email',
21
+ ionoscloud_password: 'password',
22
+ datacenter_id: 'datacenter_id',
23
+ application_loadbalancer_id: application_loadbalancer.id,
24
+ forwarding_rule_id: application_loadbalancer.entities.forwardingrules.items.first.id,
25
+ name: application_loadbalancer_rule_httprule.name,
26
+ type: application_loadbalancer_rule_httprule.type,
27
+ target_group: application_loadbalancer_rule_httprule.target_group,
28
+ drop_query: application_loadbalancer_rule_httprule.drop_query,
29
+ location: application_loadbalancer_rule_httprule.location,
30
+ status_code: application_loadbalancer_rule_httprule.status_code,
31
+ response_message: application_loadbalancer_rule_httprule.response_message,
32
+ content_type: application_loadbalancer_rule_httprule.content_type,
33
+ conditions: application_loadbalancer_rule_httprule.conditions.map { |el| el.to_hash.collect { |k, v| [k.to_s, v] }.to_h },
34
+ yes: true,
35
+ }
36
+
37
+ subject_config.each { |key, value| subject.config[key] = value }
38
+
39
+ forwarding_rule = application_loadbalancer.entities.forwardingrules.items.first
40
+
41
+ expected_rule_print = {
42
+ name: application_loadbalancer_rule_httprule.name,
43
+ type: application_loadbalancer_rule_httprule.type,
44
+ target_group: application_loadbalancer_rule_httprule.target_group,
45
+ drop_query: application_loadbalancer_rule_httprule.drop_query,
46
+ location: application_loadbalancer_rule_httprule.location,
47
+ status_code: application_loadbalancer_rule_httprule.status_code,
48
+ response_message: application_loadbalancer_rule_httprule.response_message,
49
+ content_type: application_loadbalancer_rule_httprule.content_type,
50
+ conditions: application_loadbalancer_rule_httprule.conditions.map { |el| el.to_hash },
51
+ }
52
+ expect(subject).to receive(:puts).with("ID: #{application_loadbalancer.id}")
53
+ expect(subject).to receive(:puts).with("Name: #{application_loadbalancer.properties.name}")
54
+ expect(subject).to receive(:puts).with("Listener LAN: #{application_loadbalancer.properties.listener_lan}")
55
+ expect(subject).to receive(:puts).with("IPS: #{application_loadbalancer.properties.ips}")
56
+ expect(subject).to receive(:puts).with("Target LAN: #{application_loadbalancer.properties.target_lan}")
57
+ expect(subject).to receive(:puts).with("Lb Private IPS: #{application_loadbalancer.properties.lb_private_ips}")
58
+ expect(subject).to receive(:puts).with("Rules: #{[{
59
+ id: forwarding_rule.id,
60
+ name: forwarding_rule.properties.name,
61
+ protocol: forwarding_rule.properties.protocol,
62
+ listener_ip: forwarding_rule.properties.listener_ip,
63
+ listener_port: forwarding_rule.properties.listener_port,
64
+ client_timeout: forwarding_rule.properties.client_timeout,
65
+ server_certificates: forwarding_rule.properties.server_certificates,
66
+ http_rules: forwarding_rule.properties.http_rules.map do |http_rule|
67
+ {
68
+ name: http_rule.name,
69
+ type: http_rule.type,
70
+ target_group: http_rule.target_group,
71
+ drop_query: http_rule.drop_query,
72
+ location: http_rule.location,
73
+ status_code: http_rule.status_code,
74
+ response_message: http_rule.response_message,
75
+ content_type: http_rule.content_type,
76
+ conditions: http_rule.conditions.nil? ? [] : http_rule.conditions.map do |condition|
77
+ {
78
+ type: condition.type,
79
+ condition: condition.condition,
80
+ negate: condition.negate,
81
+ key: condition.key,
82
+ value: condition.value,
83
+ }
84
+ end,
85
+ }
86
+ end + [expected_rule_print],
87
+ }, subject.get_application_loadbalancer_extended_properties(application_loadbalancer)[1],]}")
88
+
89
+ expected_added_httprule_body = application_loadbalancer_rule_httprule.to_hash
90
+
91
+ mock_wait_for(subject)
92
+ mock_call_api(
93
+ subject,
94
+ [
95
+ {
96
+ method: 'GET',
97
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/"\
98
+ "#{subject_config[:application_loadbalancer_id]}/forwardingrules/#{subject_config[:forwarding_rule_id]}",
99
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_find_by_forwarding_rule_id',
100
+ return_type: 'ApplicationLoadBalancerForwardingRule',
101
+ result: application_loadbalancer.entities.forwardingrules.items.first,
102
+ },
103
+ {
104
+ method: 'PATCH',
105
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/"\
106
+ "#{subject_config[:application_loadbalancer_id]}/forwardingrules/#{subject_config[:forwarding_rule_id]}",
107
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_patch',
108
+ body: {
109
+ httpRules: application_loadbalancer.entities.forwardingrules.items.first.properties.http_rules.map(&:to_hash) + [expected_added_httprule_body],
110
+ },
111
+ return_type: 'ApplicationLoadBalancerForwardingRule',
112
+ },
113
+ {
114
+ method: 'GET',
115
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/#{subject_config[:application_loadbalancer_id]}",
116
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_find_by_application_load_balancer_id',
117
+ return_type: 'ApplicationLoadBalancer',
118
+ result: application_loadbalancer,
119
+ },
120
+ ],
121
+ )
122
+
123
+ expect { subject.run }.not_to raise_error(Exception)
124
+ end
125
+
126
+ it 'should call ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_patch_with_http_info '\
127
+ 'and update an existing Http Rule' do
128
+ application_loadbalancer = application_loadbalancer_mock
129
+ application_loadbalancer_rule_httprule = application_loadbalancer_rule_httprule_mock(location: 'www.not-ionos.com', message: 'new_message')
130
+ subject_config = {
131
+ ionoscloud_username: 'email',
132
+ ionoscloud_password: 'password',
133
+ datacenter_id: 'datacenter_id',
134
+ application_loadbalancer_id: application_loadbalancer.id,
135
+ forwarding_rule_id: application_loadbalancer.entities.forwardingrules.items.first.id,
136
+ name: application_loadbalancer_rule_httprule.name,
137
+ type: application_loadbalancer_rule_httprule.type,
138
+ location: application_loadbalancer_rule_httprule.location,
139
+ response_message: application_loadbalancer_rule_httprule.response_message,
140
+ conditions: '[' + JSON[application_loadbalancer_rule_httprule.conditions.first.to_hash] +
141
+ ',' + JSON[application_loadbalancer_rule_httprule.conditions.first.to_hash] + ']',
142
+ yes: true,
143
+ }
144
+
145
+ subject_config.each { |key, value| subject.config[key] = value }
146
+
147
+ forwarding_rule = application_loadbalancer.entities.forwardingrules.items.first
148
+
149
+ expect(subject).to receive(:puts).with("ID: #{application_loadbalancer.id}")
150
+ expect(subject).to receive(:puts).with("Name: #{application_loadbalancer.properties.name}")
151
+ expect(subject).to receive(:puts).with("Listener LAN: #{application_loadbalancer.properties.listener_lan}")
152
+ expect(subject).to receive(:puts).with("IPS: #{application_loadbalancer.properties.ips}")
153
+ expect(subject).to receive(:puts).with("Target LAN: #{application_loadbalancer.properties.target_lan}")
154
+ expect(subject).to receive(:puts).with("Lb Private IPS: #{application_loadbalancer.properties.lb_private_ips}")
155
+ expect(subject).to receive(:puts).with("Rules: #{[{
156
+ id: forwarding_rule.id,
157
+ name: forwarding_rule.properties.name,
158
+ protocol: forwarding_rule.properties.protocol,
159
+ listener_ip: forwarding_rule.properties.listener_ip,
160
+ listener_port: forwarding_rule.properties.listener_port,
161
+ client_timeout: forwarding_rule.properties.client_timeout,
162
+ server_certificates: forwarding_rule.properties.server_certificates,
163
+ http_rules: [{
164
+ name: application_loadbalancer_rule_httprule.name,
165
+ type: application_loadbalancer_rule_httprule.type,
166
+ target_group: application_loadbalancer.entities.forwardingrules.items.first.properties.http_rules.first.target_group,
167
+ drop_query: application_loadbalancer_rule_httprule.drop_query,
168
+ location: application_loadbalancer_rule_httprule.location,
169
+ status_code: application_loadbalancer_rule_httprule.status_code,
170
+ response_message: application_loadbalancer_rule_httprule.response_message,
171
+ content_type: application_loadbalancer_rule_httprule.content_type,
172
+ conditions: [
173
+ application_loadbalancer_rule_httprule.conditions.first.to_hash,
174
+ application_loadbalancer_rule_httprule.conditions.first.to_hash,
175
+ ],
176
+ }],
177
+ }, subject.get_application_loadbalancer_extended_properties(application_loadbalancer)[1],]}")
178
+
179
+ expected_added_httprule_body = application_loadbalancer_rule_httprule.to_hash
180
+ expected_added_httprule_body[:targetGroup] = application_loadbalancer.entities.forwardingrules.items.first.properties.http_rules.first.target_group
181
+ expected_added_httprule_body[:conditions] << application_loadbalancer_rule_httprule.conditions.first.to_hash
182
+
183
+ mock_wait_for(subject)
184
+ mock_call_api(
185
+ subject,
186
+ [
187
+ {
188
+ method: 'GET',
189
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/"\
190
+ "#{subject_config[:application_loadbalancer_id]}/forwardingrules/#{subject_config[:forwarding_rule_id]}",
191
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_find_by_forwarding_rule_id',
192
+ return_type: 'ApplicationLoadBalancerForwardingRule',
193
+ result: application_loadbalancer.entities.forwardingrules.items.first,
194
+ },
195
+ {
196
+ method: 'PATCH',
197
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/"\
198
+ "#{subject_config[:application_loadbalancer_id]}/forwardingrules/#{subject_config[:forwarding_rule_id]}",
199
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_patch',
200
+ body: {
201
+ httpRules: [expected_added_httprule_body],
202
+ },
203
+ return_type: 'ApplicationLoadBalancerForwardingRule',
204
+ },
205
+ {
206
+ method: 'GET',
207
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/#{subject_config[:application_loadbalancer_id]}",
208
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_find_by_application_load_balancer_id',
209
+ return_type: 'ApplicationLoadBalancer',
210
+ result: application_loadbalancer,
211
+ },
212
+ ],
213
+ )
214
+
215
+ expect { subject.run }.not_to raise_error(Exception)
216
+ end
217
+
218
+ it 'should not make any call if any required option is missing' do
219
+ required_options = subject.instance_variable_get(:@required_options)
220
+
221
+ if required_options.length > 0
222
+ arrays_without_one_element(required_options).each do |test_case|
223
+ subject.config[:ionoscloud_token] = 'token'
224
+ test_case[:array].each { |value| subject.config[value] = 'test' }
225
+
226
+ expect(subject).to receive(:puts).with("Missing required parameters #{test_case[:removed]}")
227
+ expect(subject.api_client).not_to receive(:call_api)
228
+
229
+ expect { subject.run }.to raise_error(SystemExit) do |error|
230
+ expect(error.status).to eq(1)
231
+ end
232
+
233
+ required_options.each { |value| subject.config[value] = nil }
234
+ end
235
+ end
236
+ end
237
+ end
238
+ end
@@ -0,0 +1,204 @@
1
+ require 'spec_helper'
2
+ require 'ionoscloud_applicationloadbalancer_rule_httprule_remove'
3
+
4
+ Chef::Knife::IonoscloudApplicationloadbalancerRuleHttpruleRemove.load_deps
5
+
6
+ describe Chef::Knife::IonoscloudApplicationloadbalancerRuleHttpruleRemove do
7
+ before :each do
8
+ subject { Chef::Knife::IonoscloudApplicationloadbalancerRuleHttpruleRemove.new }
9
+
10
+ allow(subject).to receive(:puts)
11
+ allow(subject).to receive(:print)
12
+ end
13
+
14
+ describe '#run' do
15
+ it 'should call ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_patch_with_http_info '\
16
+ 'when the ID is valid' do
17
+ application_loadbalancer = application_loadbalancer_mock
18
+ subject_config = {
19
+ ionoscloud_username: 'email',
20
+ ionoscloud_password: 'password',
21
+ datacenter_id: 'datacenter_id',
22
+ application_loadbalancer_id: application_loadbalancer.id,
23
+ forwarding_rule_id: application_loadbalancer.entities.forwardingrules.items.first.id,
24
+ yes: true,
25
+ }
26
+
27
+ subject_config.each { |key, value| subject.config[key] = value }
28
+ subject.name_args = [application_loadbalancer.entities.forwardingrules.items.first.properties.http_rules.first.name, 'invalid_name']
29
+
30
+ forwarding_rule = application_loadbalancer.entities.forwardingrules.items.first
31
+
32
+ expect(subject).to receive(:puts).with("ID: #{application_loadbalancer.id}")
33
+ expect(subject).to receive(:puts).with("Name: #{application_loadbalancer.properties.name}")
34
+ expect(subject).to receive(:puts).with("Listener LAN: #{application_loadbalancer.properties.listener_lan}")
35
+ expect(subject).to receive(:puts).with("IPS: #{application_loadbalancer.properties.ips}")
36
+ expect(subject).to receive(:puts).with("Target LAN: #{application_loadbalancer.properties.target_lan}")
37
+ expect(subject).to receive(:puts).with("Lb Private IPS: #{application_loadbalancer.properties.lb_private_ips}")
38
+ expect(subject).to receive(:puts).with("Rules: #{[{
39
+ id: forwarding_rule.id,
40
+ name: forwarding_rule.properties.name,
41
+ protocol: forwarding_rule.properties.protocol,
42
+ listener_ip: forwarding_rule.properties.listener_ip,
43
+ listener_port: forwarding_rule.properties.listener_port,
44
+ client_timeout: forwarding_rule.properties.client_timeout,
45
+ server_certificates: forwarding_rule.properties.server_certificates,
46
+ http_rules: [],
47
+ }, subject.get_application_loadbalancer_extended_properties(application_loadbalancer)[1],]}")
48
+ expect(subject).to receive(:print).with("Removing the Http Rules #{[subject.name_args.first]} from the Application Loadbalancer Forwarding Rule...")
49
+
50
+ mock_wait_for(subject)
51
+ mock_call_api(
52
+ subject,
53
+ [
54
+ {
55
+ method: 'GET',
56
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/"\
57
+ "#{subject_config[:application_loadbalancer_id]}/forwardingrules/#{subject_config[:forwarding_rule_id]}",
58
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_find_by_forwarding_rule_id',
59
+ return_type: 'ApplicationLoadBalancerForwardingRule',
60
+ result: application_loadbalancer.entities.forwardingrules.items.first,
61
+ },
62
+ {
63
+ method: 'PATCH',
64
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/"\
65
+ "#{subject_config[:application_loadbalancer_id]}/forwardingrules/#{subject_config[:forwarding_rule_id]}",
66
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_patch',
67
+ body: {
68
+ httpRules: [],
69
+ },
70
+ return_type: 'ApplicationLoadBalancerForwardingRule',
71
+ },
72
+ {
73
+ method: 'GET',
74
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/#{application_loadbalancer.id}",
75
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_find_by_application_load_balancer_id',
76
+ return_type: 'ApplicationLoadBalancer',
77
+ result: application_loadbalancer,
78
+ },
79
+ ],
80
+ )
81
+
82
+ expect { subject.run }.not_to raise_error(Exception)
83
+ end
84
+
85
+ it 'should not call ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_patch_with_http_info '\
86
+ 'when the ID is not valid' do
87
+ application_loadbalancer = application_loadbalancer_mock
88
+ subject_config = {
89
+ ionoscloud_username: 'email',
90
+ ionoscloud_password: 'password',
91
+ datacenter_id: 'datacenter_id',
92
+ application_loadbalancer_id: application_loadbalancer.id,
93
+ forwarding_rule_id: application_loadbalancer.entities.forwardingrules.items.first.id,
94
+ }
95
+
96
+ subject_config.each { |key, value| subject.config[key] = value }
97
+ subject.name_args = ['invalid_id', 'invalid_id2']
98
+
99
+ expect(subject).to receive(:puts).with("ID: #{application_loadbalancer.id}")
100
+ expect(subject).to receive(:puts).with("Name: #{application_loadbalancer.properties.name}")
101
+ expect(subject).to receive(:puts).with("Listener LAN: #{application_loadbalancer.properties.listener_lan}")
102
+ expect(subject).to receive(:puts).with("IPS: #{application_loadbalancer.properties.ips}")
103
+ expect(subject).to receive(:puts).with("Target LAN: #{application_loadbalancer.properties.target_lan}")
104
+ expect(subject).to receive(:puts).with("Lb Private IPS: #{application_loadbalancer.properties.lb_private_ips}")
105
+ expect(subject).to receive(:puts).with("Rules: #{subject.get_application_loadbalancer_extended_properties(application_loadbalancer)}")
106
+
107
+ expect(subject.ui).to receive(:warn).with('No name of an existing Http Rule was given.')
108
+
109
+ expect(subject.api_client).not_to receive(:wait_for)
110
+ mock_call_api(
111
+ subject,
112
+ [
113
+ {
114
+ method: 'GET',
115
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/"\
116
+ "#{subject_config[:application_loadbalancer_id]}/forwardingrules/#{subject_config[:forwarding_rule_id]}",
117
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_find_by_forwarding_rule_id',
118
+ return_type: 'ApplicationLoadBalancerForwardingRule',
119
+ result: application_loadbalancer.entities.forwardingrules.items.first,
120
+ },
121
+ {
122
+ method: 'GET',
123
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/#{application_loadbalancer.id}",
124
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_find_by_application_load_balancer_id',
125
+ return_type: 'ApplicationLoadBalancer',
126
+ result: application_loadbalancer,
127
+ },
128
+ ],
129
+ )
130
+
131
+ expect { subject.run }.not_to raise_error(Exception)
132
+ end
133
+
134
+ it 'should not call ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_patch_with_http_info '\
135
+ 'when the rules has to existing Http Rule' do
136
+ application_loadbalancer = application_loadbalancer_mock
137
+ application_loadbalancer.entities.forwardingrules.items.first.properties.http_rules = nil
138
+ subject_config = {
139
+ ionoscloud_username: 'email',
140
+ ionoscloud_password: 'password',
141
+ datacenter_id: 'datacenter_id',
142
+ application_loadbalancer_id: application_loadbalancer.id,
143
+ forwarding_rule_id: application_loadbalancer.entities.forwardingrules.items.first.id,
144
+ }
145
+
146
+ subject_config.each { |key, value| subject.config[key] = value }
147
+ subject.name_args = ['invalid_id', 'invalid_id2']
148
+
149
+ expect(subject).to receive(:puts).with("ID: #{application_loadbalancer.id}")
150
+ expect(subject).to receive(:puts).with("Name: #{application_loadbalancer.properties.name}")
151
+ expect(subject).to receive(:puts).with("Listener LAN: #{application_loadbalancer.properties.listener_lan}")
152
+ expect(subject).to receive(:puts).with("IPS: #{application_loadbalancer.properties.ips}")
153
+ expect(subject).to receive(:puts).with("Target LAN: #{application_loadbalancer.properties.target_lan}")
154
+ expect(subject).to receive(:puts).with("Lb Private IPS: #{application_loadbalancer.properties.lb_private_ips}")
155
+ expect(subject).to receive(:puts).with("Rules: #{subject.get_application_loadbalancer_extended_properties(application_loadbalancer)}")
156
+
157
+ expect(subject.ui).to receive(:warn).with("The Forwarding Rule #{subject_config[:forwarding_rule_id]} has no Http Rules.")
158
+
159
+ expect(subject.api_client).not_to receive(:wait_for)
160
+ mock_call_api(
161
+ subject,
162
+ [
163
+ {
164
+ method: 'GET',
165
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/"\
166
+ "#{subject_config[:application_loadbalancer_id]}/forwardingrules/#{subject_config[:forwarding_rule_id]}",
167
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_find_by_forwarding_rule_id',
168
+ return_type: 'ApplicationLoadBalancerForwardingRule',
169
+ result: application_loadbalancer.entities.forwardingrules.items.first,
170
+ },
171
+ {
172
+ method: 'GET',
173
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/#{application_loadbalancer.id}",
174
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_find_by_application_load_balancer_id',
175
+ return_type: 'ApplicationLoadBalancer',
176
+ result: application_loadbalancer,
177
+ },
178
+ ],
179
+ )
180
+
181
+ expect { subject.run }.not_to raise_error(Exception)
182
+ end
183
+
184
+ it 'should not make any call if any required option is missing' do
185
+ required_options = subject.instance_variable_get(:@required_options)
186
+
187
+ if required_options.length > 0
188
+ arrays_without_one_element(required_options).each do |test_case|
189
+ subject.config[:ionoscloud_token] = 'token'
190
+ test_case[:array].each { |value| subject.config[value] = 'test' }
191
+
192
+ expect(subject).to receive(:puts).with("Missing required parameters #{test_case[:removed]}")
193
+ expect(subject.api_client).not_to receive(:call_api)
194
+
195
+ expect { subject.run }.to raise_error(SystemExit) do |error|
196
+ expect(error.status).to eq(1)
197
+ end
198
+
199
+ required_options.each { |value| subject.config[value] = nil }
200
+ end
201
+ end
202
+ end
203
+ end
204
+ end
@@ -0,0 +1,127 @@
1
+ require 'spec_helper'
2
+ require 'ionoscloud_applicationloadbalancer_rule_remove'
3
+
4
+ Chef::Knife::IonoscloudApplicationloadbalancerRuleRemove.load_deps
5
+
6
+ describe Chef::Knife::IonoscloudApplicationloadbalancerRuleRemove do
7
+ before :each do
8
+ subject { Chef::Knife::IonoscloudApplicationloadbalancerRuleRemove.new }
9
+
10
+ allow(subject).to receive(:puts)
11
+ allow(subject).to receive(:print)
12
+ end
13
+
14
+ describe '#run' do
15
+ it 'should call ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_delete when the ID is valid' do
16
+ application_loadbalancer = application_loadbalancer_mock
17
+ application_loadbalancer_rule = application_loadbalancer_rule_mock
18
+ subject_config = {
19
+ ionoscloud_username: 'email',
20
+ ionoscloud_password: 'password',
21
+ datacenter_id: 'datacenter_id',
22
+ application_loadbalancer_id: application_loadbalancer.id,
23
+ yes: true,
24
+ }
25
+
26
+ subject_config.each { |key, value| subject.config[key] = value }
27
+ subject.name_args = [application_loadbalancer_rule.id]
28
+
29
+ expect(subject).to receive(:puts).with("ID: #{application_loadbalancer.id}")
30
+ expect(subject).to receive(:puts).with("Name: #{application_loadbalancer.properties.name}")
31
+ expect(subject).to receive(:puts).with("Listener LAN: #{application_loadbalancer.properties.listener_lan}")
32
+ expect(subject).to receive(:puts).with("IPS: #{application_loadbalancer.properties.ips}")
33
+ expect(subject).to receive(:puts).with("Target LAN: #{application_loadbalancer.properties.target_lan}")
34
+ expect(subject).to receive(:puts).with("Lb Private IPS: #{application_loadbalancer.properties.lb_private_ips}")
35
+ expect(subject).to receive(:puts).with("Rules: #{subject.get_application_loadbalancer_extended_properties(application_loadbalancer)}")
36
+ expect(subject).to receive(:print).with("Removing rules #{subject.name_args} from the Application Loadbalancer...")
37
+
38
+ mock_wait_for(subject)
39
+ mock_call_api(
40
+ subject,
41
+ [
42
+ {
43
+ method: 'DELETE',
44
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/#{application_loadbalancer.id}/forwardingrules/#{application_loadbalancer_rule.id}",
45
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_delete',
46
+ },
47
+ {
48
+ method: 'GET',
49
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/#{application_loadbalancer.id}",
50
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_find_by_application_load_balancer_id',
51
+ return_type: 'ApplicationLoadBalancer',
52
+ result: application_loadbalancer,
53
+ },
54
+ ],
55
+ )
56
+
57
+ expect { subject.run }.not_to raise_error(Exception)
58
+ end
59
+
60
+ it 'should not call ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_delete when the ID is not valid' do
61
+ application_loadbalancer = application_loadbalancer_mock
62
+ rule_id = 'invalid_id'
63
+ subject_config = {
64
+ ionoscloud_username: 'email',
65
+ ionoscloud_password: 'password',
66
+ datacenter_id: 'datacenter_id',
67
+ application_loadbalancer_id: application_loadbalancer.id,
68
+ }
69
+
70
+ subject_config.each { |key, value| subject.config[key] = value }
71
+ subject.name_args = [rule_id]
72
+
73
+ expect(subject).to receive(:puts).with("ID: #{application_loadbalancer.id}")
74
+ expect(subject).to receive(:puts).with("Name: #{application_loadbalancer.properties.name}")
75
+ expect(subject).to receive(:puts).with("Listener LAN: #{application_loadbalancer.properties.listener_lan}")
76
+ expect(subject).to receive(:puts).with("IPS: #{application_loadbalancer.properties.ips}")
77
+ expect(subject).to receive(:puts).with("Target LAN: #{application_loadbalancer.properties.target_lan}")
78
+ expect(subject).to receive(:puts).with("Lb Private IPS: #{application_loadbalancer.properties.lb_private_ips}")
79
+ expect(subject).to receive(:puts).with("Rules: #{subject.get_application_loadbalancer_extended_properties(application_loadbalancer)}")
80
+
81
+ expect(subject.ui).to receive(:warn).with("Error removing Forwarding Rule #{rule_id}. Skipping.")
82
+ expect(subject.ui).to receive(:warn).with('No valid rules to remove.')
83
+
84
+ expect(subject.api_client).not_to receive(:wait_for)
85
+ mock_call_api(
86
+ subject,
87
+ [
88
+ {
89
+ method: 'DELETE',
90
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/#{subject_config[:application_loadbalancer_id]}/forwardingrules/#{rule_id}",
91
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_forwardingrules_delete',
92
+ exception: Ionoscloud::ApiError.new(code: 404),
93
+ },
94
+ {
95
+ method: 'GET',
96
+ path: "/datacenters/#{subject_config[:datacenter_id]}/applicationloadbalancers/#{application_loadbalancer.id}",
97
+ operation: :'ApplicationLoadBalancersApi.datacenters_applicationloadbalancers_find_by_application_load_balancer_id',
98
+ return_type: 'ApplicationLoadBalancer',
99
+ result: application_loadbalancer,
100
+ },
101
+ ],
102
+ )
103
+
104
+ expect { subject.run }.not_to raise_error(Exception)
105
+ end
106
+
107
+ it 'should not make any call if any required option is missing' do
108
+ required_options = subject.instance_variable_get(:@required_options)
109
+
110
+ if required_options.length > 0
111
+ arrays_without_one_element(required_options).each do |test_case|
112
+ subject.config[:ionoscloud_token] = 'token'
113
+ test_case[:array].each { |value| subject.config[value] = 'test' }
114
+
115
+ expect(subject).to receive(:puts).with("Missing required parameters #{test_case[:removed]}")
116
+ expect(subject.api_client).not_to receive(:call_api)
117
+
118
+ expect { subject.run }.to raise_error(SystemExit) do |error|
119
+ expect(error.status).to eq(1)
120
+ end
121
+
122
+ required_options.each { |value| subject.config[value] = nil }
123
+ end
124
+ end
125
+ end
126
+ end
127
+ end