api_test.go 10 KB

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