core_test.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324
  1. package integration
  2. import (
  3. "fmt"
  4. "github.com/goji/httpauth"
  5. "net/http"
  6. "net/http/httptest"
  7. "net/http/httputil"
  8. "net/url"
  9. "os"
  10. "strings"
  11. "testing"
  12. "time"
  13. "github.com/aliyun/alibaba-cloud-sdk-go/sdk"
  14. "github.com/aliyun/alibaba-cloud-sdk-go/sdk/errors"
  15. "github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests"
  16. "github.com/stretchr/testify/assert"
  17. )
  18. func Test_DescribeRegionsWithCommonRequestWithRPC(t *testing.T) {
  19. request := requests.NewCommonRequest()
  20. request.Version = "2014-05-26"
  21. request.Product = "Ecs"
  22. request.ApiName = "DescribeRegions"
  23. request.SetDomain("ecs.aliyuncs.com")
  24. request.TransToAcsRequest()
  25. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  26. assert.Nil(t, err)
  27. response, err := client.ProcessCommonRequest(request)
  28. assert.Nil(t, err)
  29. assert.True(t, response.IsSuccess())
  30. }
  31. func Test_DescribeRegionsWithCommonRequestWithSTStoken(t *testing.T) {
  32. assumeresponse, err := createAssumeRole()
  33. assert.Nil(t, err)
  34. credential := assumeresponse.Credentials
  35. request := requests.NewCommonRequest()
  36. request.Version = "2014-05-26"
  37. request.Product = "Ecs"
  38. request.ApiName = "DescribeRegions"
  39. request.SetDomain("ecs.aliyuncs.com")
  40. request.TransToAcsRequest()
  41. client, err := sdk.NewClientWithStsToken(os.Getenv("REGION_ID"), credential.AccessKeyId, credential.AccessKeySecret, credential.SecurityToken)
  42. assert.Nil(t, err)
  43. response, err := client.ProcessCommonRequest(request)
  44. assert.Nil(t, err)
  45. assert.True(t, response.IsSuccess())
  46. }
  47. func Test_DescribeRegionsWithCommonRequestWithHTTPS(t *testing.T) {
  48. request := requests.NewCommonRequest()
  49. request.Version = "2014-05-26"
  50. request.Product = "Ecs"
  51. request.ApiName = "DescribeRegions"
  52. request.SetDomain("ecs.aliyuncs.com")
  53. request.TransToAcsRequest()
  54. request.SetScheme("HTTPS")
  55. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  56. assert.Nil(t, err)
  57. response, err := client.ProcessCommonRequest(request)
  58. assert.Nil(t, err)
  59. assert.True(t, response.IsSuccess())
  60. }
  61. func Test_DescribeRegionsWithCommonRequestWithUnicodeSpecificParams(t *testing.T) {
  62. request := requests.NewCommonRequest()
  63. request.Version = "2014-05-26"
  64. request.Product = "Ecs"
  65. request.ApiName = "DescribeRegions"
  66. request.SetDomain("ecs.aliyuncs.com")
  67. request.TransToAcsRequest()
  68. request.SetContent([]byte("sdk&-杭&&&州-test"))
  69. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  70. assert.Nil(t, err)
  71. response, err := client.ProcessCommonRequest(request)
  72. assert.Nil(t, err)
  73. assert.True(t, response.IsSuccess())
  74. }
  75. func Test_DescribeRegionsWithCommonRequestWithError(t *testing.T) {
  76. request := requests.NewCommonRequest()
  77. request.Version = "2014-05-26"
  78. request.Product = "Ecs"
  79. request.ApiName = "Describe"
  80. request.SetDomain("ecs.aliyuncs.com")
  81. request.TransToAcsRequest()
  82. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  83. assert.Nil(t, err)
  84. _, err = client.ProcessCommonRequest(request)
  85. realerr := err.(errors.Error)
  86. assert.Equal(t, "InvalidParameter", realerr.ErrorCode())
  87. assert.Equal(t, "The specified parameter \"Action or Version\" is not valid.", realerr.Message())
  88. }
  89. func Test_DescribeRegionsWithCommonRequestWithIncompleteSignature(t *testing.T) {
  90. request := requests.NewCommonRequest()
  91. request.Version = "2014-05-26"
  92. request.AcceptFormat = "json"
  93. request.SetScheme("https")
  94. request.Method = "POST"
  95. request.ApiName = "DescribeRegions"
  96. request.SetDomain("ecs.aliyuncs.com")
  97. request.TransToAcsRequest()
  98. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), strings.ToUpper(os.Getenv("ACCESS_KEY_SECRET")))
  99. assert.Nil(t, err)
  100. _, err = client.ProcessCommonRequest(request)
  101. realerr := err.(*errors.ServerError)
  102. assert.Equal(t, "IncompleteSignature", realerr.ErrorCode())
  103. assert.Equal(t, "InvalidAccessKeySecret: Please check you AccessKeySecret", realerr.Recommend())
  104. }
  105. func Test_DescribeClustersWithCommonRequestWithROA(t *testing.T) {
  106. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  107. assert.Nil(t, err)
  108. request := requests.NewCommonRequest()
  109. request.Method = "GET"
  110. request.Domain = "cs.aliyuncs.com"
  111. request.Version = "2015-12-15"
  112. request.PathPattern = "/clusters/[ClusterId]"
  113. request.QueryParams["RegionId"] = os.Getenv("REGION_ID")
  114. request.TransToAcsRequest()
  115. _, err = client.ProcessCommonRequest(request)
  116. assert.NotNil(t, err)
  117. assert.Contains(t, err.Error(), "Request url is invalid")
  118. }
  119. func Test_DescribeClustersWithCommonRequestWithSignatureDostNotMatch(t *testing.T) {
  120. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), strings.ToUpper(os.Getenv("ACCESS_KEY_SECRET")))
  121. assert.Nil(t, err)
  122. request := requests.NewCommonRequest()
  123. request.Method = "GET"
  124. request.Domain = "cs.aliyuncs.com"
  125. request.Version = "2015-12-15"
  126. request.PathPattern = "/clusters/[ClusterId]"
  127. request.QueryParams["RegionId"] = os.Getenv("REGION_ID")
  128. request.TransToAcsRequest()
  129. _, err = client.ProcessCommonRequest(request)
  130. assert.NotNil(t, err)
  131. real, _ := err.(*errors.ServerError)
  132. assert.Contains(t, real.Recommend(), "InvalidAccessKeySecret: Please check you AccessKeySecret")
  133. assert.Equal(t, real.ErrorCode(), "SignatureDoesNotMatch")
  134. }
  135. func Test_DescribeClustersWithCommonRequestWithROAWithSTStoken(t *testing.T) {
  136. assumeresponse, err := createAssumeRole()
  137. assert.Nil(t, err)
  138. credential := assumeresponse.Credentials
  139. client, err := sdk.NewClientWithStsToken(os.Getenv("REGION_ID"), credential.AccessKeyId, credential.AccessKeySecret, credential.SecurityToken)
  140. assert.Nil(t, err)
  141. request := requests.NewCommonRequest()
  142. request.Method = "GET"
  143. request.Domain = "cs.aliyuncs.com"
  144. request.Version = "2015-12-15"
  145. request.PathPattern = "/clusters/[ClusterId]"
  146. request.QueryParams["RegionId"] = os.Getenv("REGION_ID")
  147. request.TransToAcsRequest()
  148. _, err = client.ProcessCommonRequest(request)
  149. assert.NotNil(t, err)
  150. assert.Contains(t, err.Error(), "Request url is invalid")
  151. }
  152. func Test_DescribeClusterDetailWithCommonRequestWithROAWithHTTPS(t *testing.T) {
  153. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  154. assert.Nil(t, err)
  155. request := requests.NewCommonRequest()
  156. request.Method = "GET"
  157. request.Domain = "cs.aliyuncs.com"
  158. request.Version = "2015-12-15"
  159. request.SetScheme("HTTPS")
  160. request.PathPattern = "/clusters/[ClusterId]"
  161. request.QueryParams["RegionId"] = os.Getenv("REGION_ID")
  162. request.TransToAcsRequest()
  163. _, err = client.ProcessCommonRequest(request)
  164. assert.NotNil(t, err)
  165. assert.Contains(t, err.Error(), "Request url is invalid")
  166. }
  167. func Test_DescribeClusterDetailWithCommonRequestWithTimeout(t *testing.T) {
  168. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  169. assert.Nil(t, err)
  170. request := requests.NewCommonRequest()
  171. request.Domain = "cs.aliyuncs.com"
  172. request.Version = "2015-12-15"
  173. request.SetScheme("HTTPS")
  174. request.PathPattern = "/clusters/[ClusterId]"
  175. request.QueryParams["RegionId"] = os.Getenv("REGION_ID")
  176. request.ReadTimeout = 1 * time.Millisecond
  177. request.ConnectTimeout = 1 * time.Millisecond
  178. request.TransToAcsRequest()
  179. _, err = client.ProcessCommonRequest(request)
  180. assert.NotNil(t, err)
  181. assert.Contains(t, err.Error(), "Connect timeout. Please set a valid ConnectTimeout.")
  182. request.ConnectTimeout = 1 * time.Second
  183. _, err = client.ProcessCommonRequest(request)
  184. assert.NotNil(t, err)
  185. assert.Contains(t, err.Error(), "Read timeout. Please set a valid ReadTimeout.")
  186. }
  187. func Test_CreateInstanceWithCommonRequestWithPolicy(t *testing.T) {
  188. err := createAttachPolicyToRole()
  189. assert.Nil(t, err)
  190. subaccesskeyid, subaccesskeysecret, err := createAccessKey()
  191. assert.Nil(t, err)
  192. client, err := sdk.NewClientWithRamRoleArnAndPolicy(os.Getenv("REGION_ID"), subaccesskeyid, subaccesskeysecret, rolearn, "alice_test", "")
  193. assert.Nil(t, err)
  194. request := requests.NewCommonRequest()
  195. request.Method = "POST"
  196. request.Product = "Ecs"
  197. request.Domain = "ecs.aliyuncs.com"
  198. request.Version = "2014-05-26"
  199. request.SetScheme("HTTPS")
  200. request.ApiName = "CreateInstance"
  201. request.QueryParams["ImageId"] = "win2008r2_64_ent_sp1_en-us_40G_alibase_20170915.vhd"
  202. request.QueryParams["InstanceType"] = "ecs.g5.large"
  203. request.TransToAcsRequest()
  204. _, err = client.ProcessCommonRequest(request)
  205. assert.NotNil(t, err)
  206. assert.Contains(t, err.Error(), "This resource type is not supported; please try other resource types.")
  207. policy := `{
  208. "Version": "1",
  209. "Statement": [
  210. {
  211. "Action": "rds:*",
  212. "Resource": "*",
  213. "Effect": "Allow"
  214. },
  215. {
  216. "Action": "dms:LoginDatabase",
  217. "Resource": "acs:rds:*:*:*",
  218. "Effect": "Allow"
  219. }
  220. ]
  221. }`
  222. client, err = sdk.NewClientWithRamRoleArnAndPolicy(os.Getenv("REGION_ID"), subaccesskeyid, subaccesskeysecret, rolearn, "alice_test", policy)
  223. assert.Nil(t, err)
  224. _, err = client.ProcessCommonRequest(request)
  225. assert.NotNil(t, err)
  226. assert.Contains(t, err.Error(), "User not authorized to operate on the specified resource, or this API doesn't support RAM.")
  227. }
  228. func handlerTrue(w http.ResponseWriter, r *http.Request) {
  229. w.WriteHeader(200)
  230. w.Write([]byte("test"))
  231. return
  232. }
  233. func handlerFake(w http.ResponseWriter, r *http.Request) {
  234. trueserver := handlerTrueServer()
  235. url, err := url.Parse(trueserver.URL)
  236. if err != nil {
  237. return
  238. }
  239. proxy := httputil.NewSingleHostReverseProxy(url)
  240. w.Write([]byte("sdk"))
  241. proxy.ServeHTTP(w, r)
  242. return
  243. }
  244. func handlerFakeServer() (server *httptest.Server) {
  245. handleFunc := httpauth.SimpleBasicAuth("someuser", "somepassword")(http.HandlerFunc(handlerFake))
  246. server = httptest.NewServer(handleFunc)
  247. return server
  248. }
  249. func handlerTrueServer() (server *httptest.Server) {
  250. server = httptest.NewServer(http.HandlerFunc(handlerTrue))
  251. return server
  252. }
  253. func Test_HTTPProxy(t *testing.T) {
  254. ts := handlerFakeServer()
  255. ts1 := handlerTrueServer()
  256. defer func() {
  257. ts.Close()
  258. ts1.Close()
  259. }()
  260. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  261. assert.Nil(t, err)
  262. request := requests.NewCommonRequest()
  263. domain := strings.Replace(ts1.URL, "http://", "", 1)
  264. request.Domain = domain
  265. request.Version = "2015-12-15"
  266. request.TransToAcsRequest()
  267. resp, err := client.ProcessCommonRequest(request)
  268. assert.Nil(t, err)
  269. assert.Equal(t, 200, resp.GetHttpStatus())
  270. assert.Equal(t, "test", resp.GetHttpContentString())
  271. originEnv := os.Getenv("HTTP_PROXY")
  272. domain = strings.Replace(ts.URL, "http://", "", 1)
  273. os.Setenv("HTTP_PROXY", fmt.Sprintf("http://someuser:somepassword@%s", domain))
  274. resp, err = client.ProcessCommonRequest(request)
  275. assert.Nil(t, err)
  276. assert.Equal(t, 200, resp.GetHttpStatus())
  277. assert.Equal(t, "sdktest", resp.GetHttpContentString())
  278. os.Setenv("HTTP_PROXY", originEnv)
  279. }
  280. func Test_DdoscooWithServiceCode(t *testing.T) {
  281. client, err := sdk.NewClientWithAccessKey(os.Getenv("REGION_ID"), os.Getenv("ACCESS_KEY_ID"), os.Getenv("ACCESS_KEY_SECRET"))
  282. assert.Nil(t, err)
  283. request := requests.NewCommonRequest()
  284. request.Version = "2017-12-28"
  285. request.Product = "ddoscoo"
  286. request.ServiceCode = "ddoscoo"
  287. request.ApiName = "DescribeInstanceSpecs"
  288. request.RegionId = os.Getenv("REGION_ID")
  289. _, err = client.ProcessCommonRequest(request)
  290. assert.NotNil(t, err)
  291. assert.Contains(t, err.Error(), "InstanceIds is mandatory for this action.")
  292. }