api_test.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  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. }
  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. endpoints.AddEndpointMapping(os.Getenv("REGION_ID"), "BssOpenApi", "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. }