api_test.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. package integration
  2. import (
  3. "github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests"
  4. "github.com/aliyun/alibaba-cloud-sdk-go/services/bssopenapi"
  5. "github.com/aliyun/alibaba-cloud-sdk-go/services/cdn"
  6. "github.com/aliyun/alibaba-cloud-sdk-go/services/cs"
  7. "github.com/aliyun/alibaba-cloud-sdk-go/services/ecs"
  8. "github.com/aliyun/alibaba-cloud-sdk-go/services/ram"
  9. "github.com/aliyun/alibaba-cloud-sdk-go/services/rds"
  10. "github.com/aliyun/alibaba-cloud-sdk-go/services/slb"
  11. "github.com/aliyun/alibaba-cloud-sdk-go/services/vpc"
  12. "github.com/stretchr/testify/assert"
  13. "net/http"
  14. "net/http/httptest"
  15. "os"
  16. "strings"
  17. "testing"
  18. )
  19. var (
  20. securityGroupId = ""
  21. flag = false
  22. )
  23. func Test_DescribeClusteWithROArequestWithXMLWithGet(t *testing.T) {
  24. client, err := cs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  25. assert.Nil(t, err)
  26. request := cs.CreateDescribeClusterDetailRequest()
  27. request.SetContentType("XML")
  28. request.SetScheme("HTTPS")
  29. response, err := client.DescribeClusterDetail(request)
  30. assert.NotNil(t, err)
  31. assert.Equal(t, 400, response.GetHttpStatus())
  32. assert.Contains(t, err.Error(), "Request url is invalid")
  33. }
  34. func Test_ScaleClusterWithROArequestWithXMLWithPUT(t *testing.T) {
  35. client, err := cs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  36. assert.Nil(t, err)
  37. request := cs.CreateScaleClusterRequest()
  38. request.SetContentType("XML")
  39. request.SetScheme("HTTPS")
  40. response, err := client.ScaleCluster(request)
  41. assert.NotNil(t, err)
  42. assert.Equal(t, 400, response.GetHttpStatus())
  43. assert.Contains(t, err.Error(), "Request url is invalid")
  44. }
  45. func Test_CreateClusterTokenWithROArequestWithXMLWithPOST(t *testing.T) {
  46. client, err := cs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  47. assert.Nil(t, err)
  48. request := cs.CreateCreateClusterTokenRequest()
  49. request.SetContentType("XML")
  50. request.SetScheme("HTTPS")
  51. response, err := client.CreateClusterToken(request)
  52. assert.NotNil(t, err)
  53. assert.Equal(t, 400, response.GetHttpStatus())
  54. assert.Contains(t, err.Error(), "Request url is invalid")
  55. }
  56. func Test_DeleteClusterWithROArequestWithXMLWithDelete(t *testing.T) {
  57. client, err := cs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  58. assert.Nil(t, err)
  59. request := cs.CreateDeleteClusterRequest()
  60. request.SetContentType("XML")
  61. request.SetScheme("HTTPS")
  62. response, err := client.DeleteCluster(request)
  63. assert.NotNil(t, err)
  64. assert.Equal(t, 400, response.GetHttpStatus())
  65. assert.Contains(t, err.Error(), "Request url is invalid")
  66. }
  67. func Test_DeleteClusterWithROArequestWithJSONWithDelete(t *testing.T) {
  68. client, err := cs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  69. assert.Nil(t, err)
  70. request := cs.CreateDeleteClusterRequest()
  71. request.SetContentType("JSON")
  72. request.SetScheme("HTTPS")
  73. response, err := client.DeleteCluster(request)
  74. assert.NotNil(t, err)
  75. assert.Equal(t, 400, response.GetHttpStatus())
  76. assert.Contains(t, err.Error(), "Request url is invalid")
  77. }
  78. func Test_ScaleClusterWithROArequestWithJSONWithPUT(t *testing.T) {
  79. client, err := cs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  80. assert.Nil(t, err)
  81. request := cs.CreateScaleClusterRequest()
  82. request.SetContentType("JSON")
  83. request.SetScheme("HTTPS")
  84. response, err := client.ScaleCluster(request)
  85. assert.NotNil(t, err)
  86. assert.Equal(t, 400, response.GetHttpStatus())
  87. assert.Contains(t, err.Error(), "Request url is invalid")
  88. }
  89. func Test_CreateSecurityGroupWithRPCrequestWithJSONWithNestingparametersWithPOST(t *testing.T) {
  90. client, err := ecs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  91. assert.Nil(t, err)
  92. request := ecs.CreateCreateSecurityGroupRequest()
  93. request.SetContentType("JSON")
  94. tag := ecs.CreateSecurityGroupTag{
  95. Key: "test",
  96. Value: "test",
  97. }
  98. request.Tag = &[]ecs.CreateSecurityGroupTag{tag}
  99. response, err := client.CreateSecurityGroup(request)
  100. assert.Nil(t, err)
  101. assert.True(t, response.IsSuccess())
  102. assert.Equal(t, 36, len(response.RequestId))
  103. assert.True(t, len(response.SecurityGroupId) > 0)
  104. securityGroupId = response.SecurityGroupId
  105. }
  106. func Test_ECS_DescribeSecurityGroupsWithRPCrequestWithJSONWithNestingparametersWithGET(t *testing.T) {
  107. client, err := ecs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  108. assert.Nil(t, err)
  109. request := ecs.CreateDescribeSecurityGroupsRequest()
  110. request.SetContentType("JSON")
  111. request.Method = requests.GET
  112. response, err := client.DescribeSecurityGroups(request)
  113. assert.Nil(t, err)
  114. assert.True(t, response.IsSuccess())
  115. for _, securitygroup := range response.SecurityGroups.SecurityGroup {
  116. if securitygroup.SecurityGroupId == securityGroupId {
  117. flag = true
  118. break
  119. }
  120. }
  121. assert.Equal(t, 36, len(response.RequestId))
  122. assert.True(t, flag)
  123. flag = false
  124. }
  125. func Test_ECS_DeleteSecurityGroupWithRPCrequestWithJSONWithPOST(t *testing.T) {
  126. client, err := ecs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  127. assert.Nil(t, err)
  128. request := ecs.CreateDeleteSecurityGroupRequest()
  129. request.SetContentType("JSON")
  130. request.SecurityGroupId = securityGroupId
  131. response, err := client.DeleteSecurityGroup(request)
  132. assert.Nil(t, err)
  133. assert.True(t, response.IsSuccess())
  134. assert.Equal(t, 36, len(response.RequestId))
  135. securityGroupId = ""
  136. }
  137. func Test_RDS_DescribeDBInstancesWithRPCrequest(t *testing.T) {
  138. client, err := rds.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  139. assert.Nil(t, err)
  140. assert.NotNil(t, client)
  141. request := rds.CreateDescribeDBInstancesRequest()
  142. request.SetContentType("JSON")
  143. response, err := client.DescribeDBInstances(request)
  144. assert.Nil(t, err)
  145. assert.NotNil(t, response)
  146. assert.Equal(t, 36, len(response.RequestId))
  147. }
  148. func Test_CDN_DescribeCdnDomainDetailWithRPCrequest(t *testing.T) {
  149. client, err := cdn.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  150. assert.Nil(t, err)
  151. assert.NotNil(t, client)
  152. request := cdn.CreateDescribeRefreshTasksRequest()
  153. response, err := client.DescribeRefreshTasks(request)
  154. assert.Nil(t, err)
  155. assert.NotNil(t, response)
  156. assert.Equal(t, 36, len(response.RequestId))
  157. }
  158. func Test_RAM_ListRolesWithRPCrequest(t *testing.T) {
  159. client, err := ram.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  160. assert.Nil(t, err)
  161. request := ram.CreateListRolesRequest()
  162. request.Scheme = "HTTPS"
  163. response, err := client.ListRoles(request)
  164. assert.Nil(t, err)
  165. assert.True(t, response.IsSuccess())
  166. assert.Equal(t, 36, len(response.RequestId))
  167. }
  168. func Test_SLB_DescribeRegionsWithRPCrequest(t *testing.T) {
  169. client, err := slb.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  170. assert.Nil(t, err)
  171. request := slb.CreateDescribeRegionsRequest()
  172. response, err := client.DescribeRegions(request)
  173. assert.Nil(t, err)
  174. assert.True(t, response.IsSuccess())
  175. assert.Equal(t, 36, len(response.RequestId))
  176. assert.True(t, len(response.Regions.Region) > 0)
  177. }
  178. func Test_VPC_DescribeRegionsWithRPCrequest(t *testing.T) {
  179. client, err := vpc.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  180. assert.Nil(t, err)
  181. request := vpc.CreateDescribeRegionsRequest()
  182. response, err := client.DescribeRegions(request)
  183. assert.Nil(t, err)
  184. assert.True(t, response.IsSuccess())
  185. assert.Equal(t, 36, len(response.RequestId))
  186. assert.True(t, len(response.Regions.Region) > 0)
  187. }
  188. func mockServer(status int, json string) (server *httptest.Server) {
  189. // Start a test server locally.
  190. ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
  191. w.WriteHeader(status)
  192. w.Write([]byte(json))
  193. return
  194. }))
  195. return ts
  196. }
  197. func Test_DescribeRegionsWithRPCrequestWithunicode(t *testing.T) {
  198. client, err := ecs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  199. assert.Nil(t, err)
  200. request := ecs.CreateDescribeRegionsRequest()
  201. request.Scheme = "HTTP"
  202. ts := mockServer(400, `{"Code": "&&&&杭州&&&"}`)
  203. defer ts.Close()
  204. domain := strings.Replace(ts.URL, "http://", "", 1)
  205. request.Domain = domain
  206. response, err := client.DescribeRegions(request)
  207. assert.NotNil(t, err)
  208. assert.Equal(t, 400, response.GetHttpStatus())
  209. assert.Equal(t, "{\"Code\": \"&&&&杭州&&&\"}", response.GetHttpContentString())
  210. }
  211. func Test_DescribeRegionsWithRPCrequestWithescape(t *testing.T) {
  212. client, err := ecs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  213. assert.Nil(t, err)
  214. request := ecs.CreateDescribeRegionsRequest()
  215. request.Scheme = "HTTP"
  216. ts := mockServer(400, `{"Code": "\t"}`)
  217. defer ts.Close()
  218. domain := strings.Replace(ts.URL, "http://", "", 1)
  219. request.Domain = domain
  220. response, err := client.DescribeRegions(request)
  221. assert.NotNil(t, err)
  222. assert.Equal(t, 400, response.GetHttpStatus())
  223. assert.Equal(t, "{\"Code\": \"\\t\"}", response.GetHttpContentString())
  224. }
  225. func Test_DescribeRegionsWithRPCrequestWith3XX(t *testing.T) {
  226. client, err := ecs.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  227. assert.Nil(t, err)
  228. request := ecs.CreateDescribeRegionsRequest()
  229. request.Scheme = "HTTP"
  230. ts := mockServer(307, `{"error"}`)
  231. defer ts.Close()
  232. domain := strings.Replace(ts.URL, "http://", "", 1)
  233. request.Domain = domain
  234. response, err := client.DescribeRegions(request)
  235. assert.NotNil(t, err)
  236. assert.Equal(t, 307, response.GetHttpStatus())
  237. assert.Equal(t, "{\"error\"}", response.GetHttpContentString())
  238. }
  239. func Test_QueryAvaliableInstances(t *testing.T) {
  240. client, err := bssopenapi.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  241. assert.Nil(t, err)
  242. request := bssopenapi.CreateQueryAvailableInstancesRequest()
  243. request.Domain = "business.aliyuncs.com"
  244. response, err := client.QueryAvailableInstances(request)
  245. assert.Nil(t, err)
  246. assert.True(t, response.IsSuccess())
  247. assert.Equal(t, 36, len(response.RequestId))
  248. }