client_test.go 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814
  1. /*
  2. * Licensed under the Apache License, Version 2.0 (the "License");
  3. * you may not use this file except in compliance with the License.
  4. * You may obtain a copy of the License at
  5. *
  6. * http://www.apache.org/licenses/LICENSE-2.0
  7. *
  8. * Unless required by applicable law or agreed to in writing, software
  9. * distributed under the License is distributed on an "AS IS" BASIS,
  10. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. * See the License for the specific language governing permissions and
  12. * limitations under the License.
  13. */
  14. package sdk
  15. import (
  16. "bytes"
  17. "errors"
  18. "fmt"
  19. "io/ioutil"
  20. "net/http"
  21. "net/http/httptest"
  22. "os"
  23. "strconv"
  24. "strings"
  25. "testing"
  26. "time"
  27. "github.com/aliyun/alibaba-cloud-sdk-go/sdk/auth/credentials/provider"
  28. "github.com/aliyun/alibaba-cloud-sdk-go/sdk/responses"
  29. "github.com/aliyun/alibaba-cloud-sdk-go/sdk/auth/credentials"
  30. "github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests"
  31. "github.com/stretchr/testify/assert"
  32. )
  33. type signertest struct {
  34. name string
  35. }
  36. func (s *signertest) GetName() string {
  37. return ""
  38. }
  39. func (s *signertest) GetType() string {
  40. return ""
  41. }
  42. func (s *signertest) GetVersion() string {
  43. return ""
  44. }
  45. func (s *signertest) GetAccessKeyId() (string, error) {
  46. return "", nil
  47. }
  48. func (s *signertest) GetExtraParam() map[string]string {
  49. return nil
  50. }
  51. func (s *signertest) Sign(stringToSign, secretSuffix string) string {
  52. return ""
  53. }
  54. func Test_Client(t *testing.T) {
  55. defer func() {
  56. err := recover()
  57. assert.NotNil(t, err)
  58. assert.Equal(t, "not support yet", err)
  59. }()
  60. NewClient()
  61. }
  62. func Test_NewClientWithOptions(t *testing.T) {
  63. c := NewConfig()
  64. c.HttpTransport = &http.Transport{
  65. IdleConnTimeout: time.Duration(10 * time.Second),
  66. }
  67. c.EnableAsync = true
  68. c.GoRoutinePoolSize = 1
  69. c.MaxTaskQueueSize = 1
  70. c.Timeout = 10 * time.Second
  71. credential := credentials.NewAccessKeyCredential("acesskeyid", "accesskeysecret")
  72. client, err := NewClientWithOptions("regionid", c, credential)
  73. assert.Nil(t, err)
  74. assert.NotNil(t, client)
  75. }
  76. func Test_NewClientWithPolicy(t *testing.T) {
  77. client, err := NewClientWithRamRoleArnAndPolicy("regionid", "acesskeyid", "accesskeysecret", "roleArn", "sessionName", "policy")
  78. assert.Nil(t, err)
  79. assert.NotNil(t, client)
  80. }
  81. func Test_NewClientWithAccessKey(t *testing.T) {
  82. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  83. assert.Nil(t, err)
  84. assert.NotNil(t, client)
  85. }
  86. func Test_NewClientWithStsToken(t *testing.T) {
  87. client, err := NewClientWithStsToken("regionid", "acesskeyid", "accesskeysecret", "token")
  88. assert.Nil(t, err)
  89. assert.NotNil(t, client)
  90. }
  91. func Test_NewClientWithRamRoleArn(t *testing.T) {
  92. client, err := NewClientWithRamRoleArn("regionid", "acesskeyid", "accesskeysecret", "roleArn", "roleSessionName")
  93. assert.Nil(t, err)
  94. assert.NotNil(t, client)
  95. config := client.InitClientConfig()
  96. assert.NotNil(t, config)
  97. }
  98. func Test_NewClientWithEcsRamRole(t *testing.T) {
  99. client, err := NewClientWithEcsRamRole("regionid", "roleName")
  100. assert.Nil(t, err)
  101. assert.NotNil(t, client)
  102. }
  103. func Test_NewClientWithRsaKeyPair(t *testing.T) {
  104. client, err := NewClientWithRsaKeyPair("regionid", "publicKey", "privateKey", 3600)
  105. assert.Nil(t, err)
  106. assert.NotNil(t, client)
  107. }
  108. func mockResponse(statusCode int, content string, mockerr error) (res *http.Response, err error) {
  109. status := strconv.Itoa(statusCode)
  110. res = &http.Response{
  111. Proto: "HTTP/1.1",
  112. ProtoMajor: 1,
  113. Header: make(http.Header),
  114. StatusCode: statusCode,
  115. Status: status + " " + http.StatusText(statusCode),
  116. }
  117. res.Body = ioutil.NopCloser(bytes.NewReader([]byte(content)))
  118. err = mockerr
  119. return
  120. }
  121. func Test_DoActionWithProxy(t *testing.T) {
  122. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  123. assert.Nil(t, err)
  124. assert.NotNil(t, client)
  125. assert.Equal(t, true, client.isRunning)
  126. request := requests.NewCommonRequest()
  127. request.Domain = "ecs.aliyuncs.com"
  128. request.Version = "2014-05-26"
  129. request.ApiName = "DescribeInstanceStatus"
  130. request.QueryParams["PageNumber"] = "1"
  131. request.QueryParams["PageSize"] = "30"
  132. request.TransToAcsRequest()
  133. response := responses.NewCommonResponse()
  134. origTestHookDo := hookDo
  135. defer func() { hookDo = origTestHookDo }()
  136. hookDo = func(fn func(req *http.Request) (*http.Response, error)) func(req *http.Request) (*http.Response, error) {
  137. return func(req *http.Request) (*http.Response, error) {
  138. return mockResponse(200, "", nil)
  139. }
  140. }
  141. err = client.DoAction(request, response)
  142. assert.Nil(t, err)
  143. assert.Equal(t, 200, response.GetHttpStatus())
  144. assert.Equal(t, "", response.GetHttpContentString())
  145. // Test when scheme is http, only http proxy is valid.
  146. envHttpsProxy := os.Getenv("https_proxy")
  147. os.Setenv("https_proxy", "https://127.0.0.1:9000")
  148. err = client.DoAction(request, response)
  149. assert.Nil(t, err)
  150. trans, _ := client.httpClient.Transport.(*http.Transport)
  151. assert.Nil(t, trans.Proxy)
  152. // Test when host is in no_proxy, proxy is invalid
  153. envNoProxy := os.Getenv("no_proxy")
  154. os.Setenv("no_proxy", "ecs.aliyuncs.com")
  155. envHttpProxy := os.Getenv("http_proxy")
  156. os.Setenv("http_proxy", "http://127.0.0.1:8888")
  157. err = client.DoAction(request, response)
  158. assert.Nil(t, err)
  159. trans, _ = client.httpClient.Transport.(*http.Transport)
  160. assert.Nil(t, trans.Proxy)
  161. client.SetNoProxy("ecs.testaliyuncs.com")
  162. err = client.DoAction(request, response)
  163. assert.Nil(t, err)
  164. trans, _ = client.httpClient.Transport.(*http.Transport)
  165. url, _ := trans.Proxy(nil)
  166. assert.Equal(t, url.Scheme, "http")
  167. assert.Equal(t, url.Host, "127.0.0.1:8888")
  168. // Test when setting http proxy, client has a high priority than environment variable
  169. client.SetHttpProxy("http://127.0.0.1:8080")
  170. err = client.DoAction(request, response)
  171. assert.Nil(t, err)
  172. trans, _ = client.httpClient.Transport.(*http.Transport)
  173. url, _ = trans.Proxy(nil)
  174. assert.Equal(t, url.Scheme, "http")
  175. assert.Equal(t, url.Host, "127.0.0.1:8080")
  176. // Test when scheme is https, only https proxy is valid
  177. request.Scheme = "https"
  178. err = client.DoAction(request, response)
  179. assert.Nil(t, err)
  180. trans, _ = client.httpClient.Transport.(*http.Transport)
  181. url, _ = trans.Proxy(nil)
  182. assert.Equal(t, url.Scheme, "https")
  183. assert.Equal(t, url.Host, "127.0.0.1:9000")
  184. // Test when setting https proxy, client has a high priority than environment variable
  185. client.SetHttpsProxy("https://username:password@127.0.0.1:6666")
  186. err = client.DoAction(request, response)
  187. assert.Nil(t, err)
  188. trans, _ = client.httpClient.Transport.(*http.Transport)
  189. url, _ = trans.Proxy(nil)
  190. assert.Equal(t, url.Scheme, "https")
  191. assert.Equal(t, url.Host, "127.0.0.1:6666")
  192. assert.Equal(t, url.User.Username(), "username")
  193. client.Shutdown()
  194. os.Setenv("https_proxy", envHttpsProxy)
  195. os.Setenv("http_proxy", envHttpProxy)
  196. os.Setenv("no_proxy", envNoProxy)
  197. assert.Equal(t, false, client.isRunning)
  198. }
  199. func Test_DoAction_HTTPSInsecure(t *testing.T) {
  200. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  201. assert.Nil(t, err)
  202. assert.NotNil(t, client)
  203. client.SetHTTPSInsecure(true)
  204. request := requests.NewCommonRequest()
  205. request.Product = "Ram"
  206. request.Version = "2015-05-01"
  207. request.ApiName = "CreateRole"
  208. request.Domain = "ecs.aliyuncs.com"
  209. request.QueryParams["RegionId"] = os.Getenv("REGION_ID")
  210. request.TransToAcsRequest()
  211. response := responses.NewCommonResponse()
  212. origTestHookDo := hookDo
  213. defer func() { hookDo = origTestHookDo }()
  214. hookDo = func(fn func(req *http.Request) (*http.Response, error)) func(req *http.Request) (*http.Response, error) {
  215. return func(req *http.Request) (*http.Response, error) {
  216. return mockResponse(200, "", nil)
  217. }
  218. }
  219. err = client.DoAction(request, response)
  220. assert.Nil(t, err)
  221. assert.Equal(t, 200, response.GetHttpStatus())
  222. assert.Equal(t, "", response.GetHttpContentString())
  223. trans := client.httpClient.Transport.(*http.Transport)
  224. assert.Equal(t, true, trans.TLSClientConfig.InsecureSkipVerify)
  225. request.SetHTTPSInsecure(false)
  226. err = client.DoAction(request, response)
  227. assert.Nil(t, err)
  228. trans = client.httpClient.Transport.(*http.Transport)
  229. assert.Equal(t, false, trans.TLSClientConfig.InsecureSkipVerify)
  230. // Test when scheme is http, only http proxy is valid.
  231. envHttpsProxy := os.Getenv("HTTPS_PROXY")
  232. os.Setenv("HTTPS_PROXY", "https://127.0.0.1:9000")
  233. err = client.DoAction(request, response)
  234. assert.Nil(t, err)
  235. trans, _ = client.httpClient.Transport.(*http.Transport)
  236. assert.Nil(t, trans.Proxy)
  237. // Test when host is in no_proxy, proxy is invalid
  238. envNoProxy := os.Getenv("NO_PROXY")
  239. os.Setenv("NO_PROXY", "ecs.aliyuncs.com")
  240. envHttpProxy := os.Getenv("HTTP_PROXY")
  241. os.Setenv("HTTP_PROXY", "http://127.0.0.1:8888")
  242. err = client.DoAction(request, response)
  243. assert.Nil(t, err)
  244. trans, _ = client.httpClient.Transport.(*http.Transport)
  245. assert.Nil(t, trans.Proxy)
  246. client.SetNoProxy("ecs.testaliyuncs.com")
  247. err = client.DoAction(request, response)
  248. assert.Nil(t, err)
  249. trans, _ = client.httpClient.Transport.(*http.Transport)
  250. url, _ := trans.Proxy(nil)
  251. assert.Equal(t, url.Scheme, "http")
  252. assert.Equal(t, url.Host, "127.0.0.1:8888")
  253. // Test when setting http proxy, client has a high priority than environment variable
  254. client.SetHttpProxy("http://127.0.0.1:8080")
  255. err = client.DoAction(request, response)
  256. assert.Nil(t, err)
  257. trans, _ = client.httpClient.Transport.(*http.Transport)
  258. url, _ = trans.Proxy(nil)
  259. assert.Equal(t, url.Scheme, "http")
  260. assert.Equal(t, url.Host, "127.0.0.1:8080")
  261. // Test when scheme is https, only https proxy is valid
  262. request.Scheme = "https"
  263. err = client.DoAction(request, response)
  264. assert.Nil(t, err)
  265. trans, _ = client.httpClient.Transport.(*http.Transport)
  266. url, _ = trans.Proxy(nil)
  267. assert.Equal(t, url.Scheme, "https")
  268. assert.Equal(t, url.Host, "127.0.0.1:9000")
  269. // Test when setting https proxy, client has a high priority than environment variable
  270. client.SetHttpsProxy("https://127.0.0.1:6666")
  271. err = client.DoAction(request, response)
  272. assert.Nil(t, err)
  273. trans, _ = client.httpClient.Transport.(*http.Transport)
  274. url, _ = trans.Proxy(nil)
  275. assert.Equal(t, url.Scheme, "https")
  276. assert.Equal(t, url.Host, "127.0.0.1:6666")
  277. hookDo = func(fn func(req *http.Request) (*http.Response, error)) func(req *http.Request) (*http.Response, error) {
  278. return func(req *http.Request) (*http.Response, error) {
  279. return mockResponse(400, "", errors.New("x509: certificate signed by unknown authority"))
  280. }
  281. }
  282. response = responses.NewCommonResponse()
  283. err = client.DoAction(request, response)
  284. assert.NotNil(t, err)
  285. assert.Equal(t, 0, response.GetHttpStatus())
  286. assert.Equal(t, "x509: certificate signed by unknown authority", err.Error())
  287. client.Shutdown()
  288. os.Setenv("HTTPS_PROXY", envHttpsProxy)
  289. os.Setenv("HTTP_PROXY", envHttpProxy)
  290. os.Setenv("NO_PROXY", envNoProxy)
  291. assert.Equal(t, false, client.isRunning)
  292. }
  293. func Test_DoAction_Timeout(t *testing.T) {
  294. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  295. assert.Nil(t, err)
  296. assert.NotNil(t, client)
  297. assert.Equal(t, true, client.isRunning)
  298. request := requests.NewCommonRequest()
  299. request.Domain = "ecs.aliyuncs.com"
  300. request.Version = "2014-05-26"
  301. request.Product = "ecs"
  302. request.ApiName = "DescribeInstanceStatus"
  303. request.QueryParams["PageNumber"] = "1"
  304. request.QueryParams["PageSize"] = "30"
  305. request.TransToAcsRequest()
  306. response := responses.NewCommonResponse()
  307. origTestHookDo := hookDo
  308. defer func() { hookDo = origTestHookDo }()
  309. hookDo = func(fn func(req *http.Request) (*http.Response, error)) func(req *http.Request) (*http.Response, error) {
  310. return func(req *http.Request) (*http.Response, error) {
  311. return mockResponse(400, "Server Internel Error", fmt.Errorf("read tcp"))
  312. }
  313. }
  314. err = client.DoAction(request, response)
  315. assert.NotNil(t, err)
  316. assert.Equal(t, 0, response.GetHttpStatus())
  317. assert.Equal(t, "", response.GetHttpContentString())
  318. client.httpClient.Timeout = 15 * time.Second
  319. err = client.DoAction(request, response)
  320. assert.NotNil(t, err)
  321. assert.Equal(t, 0, response.GetHttpStatus())
  322. assert.Equal(t, "", response.GetHttpContentString())
  323. // Test set client timeout
  324. client.SetReadTimeout(1 * time.Millisecond)
  325. client.SetConnectTimeout(1 * time.Millisecond)
  326. assert.Equal(t, 1*time.Millisecond, client.GetConnectTimeout())
  327. assert.Equal(t, 1*time.Millisecond, client.GetReadTimeout())
  328. client.config.AutoRetry = false
  329. err = client.DoAction(request, response)
  330. assert.NotNil(t, err)
  331. assert.Equal(t, 0, response.GetHttpStatus())
  332. assert.Equal(t, "", response.GetHttpContentString())
  333. // Test set request timeout
  334. request.SetReadTimeout(1 * time.Millisecond)
  335. request.SetConnectTimeout(1 * time.Millisecond)
  336. err = client.DoAction(request, response)
  337. assert.NotNil(t, err)
  338. assert.Equal(t, 0, response.GetHttpStatus())
  339. assert.Equal(t, "", response.GetHttpContentString())
  340. client.Shutdown()
  341. assert.Equal(t, false, client.isRunning)
  342. }
  343. func Test_ProcessCommonRequest(t *testing.T) {
  344. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  345. assert.Nil(t, err)
  346. assert.NotNil(t, client)
  347. request := requests.NewCommonRequest()
  348. request.Domain = "ecs.aliyuncs.com"
  349. request.Version = "2014-05-26"
  350. request.ApiName = "DescribeInstanceStatus"
  351. request.QueryParams["PageNumber"] = "1"
  352. request.QueryParams["PageSize"] = "30"
  353. origTestHookDo := hookDo
  354. defer func() { hookDo = origTestHookDo }()
  355. hookDo = func(fn func(req *http.Request) (*http.Response, error)) func(req *http.Request) (*http.Response, error) {
  356. return func(req *http.Request) (*http.Response, error) {
  357. return mockResponse(400, "", fmt.Errorf("test error"))
  358. }
  359. }
  360. resp, err := client.ProcessCommonRequest(request)
  361. assert.NotNil(t, err)
  362. assert.Contains(t, err.Error(), "test error")
  363. assert.Equal(t, 0, resp.GetHttpStatus())
  364. assert.Equal(t, "", resp.GetHttpContentString())
  365. }
  366. func mockServer(status int, json string) (server *httptest.Server) {
  367. // Start a test server locally.
  368. ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
  369. w.WriteHeader(status)
  370. w.Write([]byte(json))
  371. return
  372. }))
  373. return ts
  374. }
  375. func Test_DoAction_With500(t *testing.T) {
  376. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  377. assert.Nil(t, err)
  378. assert.NotNil(t, client)
  379. assert.Equal(t, true, client.isRunning)
  380. request := requests.NewCommonRequest()
  381. request.Version = "2014-05-26"
  382. request.ApiName = "DescribeInstanceStatus"
  383. request.QueryParams["PageNumber"] = "1"
  384. request.QueryParams["PageSize"] = "30"
  385. request.TransToAcsRequest()
  386. response := responses.NewCommonResponse()
  387. ts := mockServer(500, "Server Internel Error")
  388. defer ts.Close()
  389. domain := strings.Replace(ts.URL, "http://", "", 1)
  390. request.Domain = domain
  391. err = client.DoAction(request, response)
  392. assert.NotNil(t, err)
  393. assert.Equal(t, 500, response.GetHttpStatus())
  394. assert.Equal(t, "Server Internel Error", response.GetHttpContentString())
  395. }
  396. func Test_DoAction_WithLogger(t *testing.T) {
  397. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  398. assert.Nil(t, err)
  399. assert.NotNil(t, client)
  400. assert.Equal(t, true, client.isRunning)
  401. request := requests.NewCommonRequest()
  402. request.Version = "2014-05-26"
  403. request.ApiName = "DescribeInstanceStatus"
  404. request.TransToAcsRequest()
  405. response := responses.NewCommonResponse()
  406. ts := mockServer(500, "Server Internel Error")
  407. defer ts.Close()
  408. domain := strings.Replace(ts.URL, "http://", "", 1)
  409. request.Domain = domain
  410. f1, err := os.Create("test.txt")
  411. defer os.Remove("test.txt")
  412. assert.Nil(t, err)
  413. // Test when set logger, it will create a new client logger.
  414. client.SetLogger("error", "Alibaba", f1, "")
  415. err = client.DoAction(request, response)
  416. assert.NotNil(t, err)
  417. log := client.GetLogger()
  418. assert.Contains(t, client.GetLoggerMsg(), "Alibaba: \"GET /?AccessKeyId=acesskeyid&Action=DescribeInstanceStatus&Format=JSON&RegionId=regionid")
  419. assert.Equal(t, 500, response.GetHttpStatus())
  420. assert.Equal(t, true, log.isOpen)
  421. assert.Equal(t, "Server Internel Error", response.GetHttpContentString())
  422. // Test when close logger, it will not print log.
  423. client.CloseLogger()
  424. err = client.DoAction(request, response)
  425. assert.NotNil(t, err)
  426. log = client.GetLogger()
  427. assert.Equal(t, 500, response.GetHttpStatus())
  428. assert.Equal(t, false, log.isOpen)
  429. assert.Equal(t, "{time} {channel}: \"{method} {uri} HTTP/{version}\" {code} {cost} {hostname}", client.GetTemplate())
  430. assert.Contains(t, client.GetLoggerMsg(), `GET /?AccessKeyId=acesskeyid&Action=DescribeInstanceStatus&Format=JSON&RegionId=regionid`)
  431. assert.Equal(t, "Server Internel Error", response.GetHttpContentString())
  432. // Test when open logger, it will print log.
  433. client.OpenLogger()
  434. template := "{channel}: \"{method} {code} {res_body}"
  435. client.SetTemplate(template)
  436. err = client.DoAction(request, response)
  437. assert.NotNil(t, err)
  438. log = client.GetLogger()
  439. assert.Equal(t, 500, response.GetHttpStatus())
  440. assert.Equal(t, true, log.isOpen)
  441. assert.Equal(t, "{channel}: \"{method} {code} {res_body}", client.GetTemplate())
  442. assert.Equal(t, client.GetLoggerMsg(), `Alibaba: "GET 500 Server Internel Error`)
  443. }
  444. func TestClient_BuildRequestWithSigner(t *testing.T) {
  445. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  446. assert.Nil(t, err)
  447. assert.NotNil(t, client)
  448. assert.Equal(t, true, client.isRunning)
  449. request := requests.NewCommonRequest()
  450. request.Domain = "ecs.aliyuncs.com"
  451. request.Version = "2014-05-26"
  452. request.ApiName = "DescribeInstanceStatus"
  453. request.QueryParams["PageNumber"] = "1"
  454. request.QueryParams["PageSize"] = "30"
  455. request.RegionId = "regionid"
  456. request.TransToAcsRequest()
  457. client.config.UserAgent = "user_agent"
  458. err = client.BuildRequestWithSigner(request, nil)
  459. assert.Nil(t, err)
  460. }
  461. func TestClient_BuildRequestWithSigner1(t *testing.T) {
  462. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  463. assert.Nil(t, err)
  464. assert.NotNil(t, client)
  465. assert.Equal(t, true, client.isRunning)
  466. request := requests.NewCommonRequest()
  467. request.Version = "2014-05-26"
  468. request.ApiName = "DescribeInstanceStatus"
  469. request.QueryParams["PageNumber"] = "1"
  470. request.QueryParams["PageSize"] = "30"
  471. request.RegionId = "regionid"
  472. request.TransToAcsRequest()
  473. signer := &signertest{
  474. name: "signer",
  475. }
  476. err = client.BuildRequestWithSigner(request, signer)
  477. assert.NotNil(t, err)
  478. assert.Contains(t, err.Error(), "SDK.CanNotResolveEndpoint] Can not resolve endpoint")
  479. }
  480. func TestClient_BuildRequestWithSigner2(t *testing.T) {
  481. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  482. assert.Nil(t, err)
  483. assert.NotNil(t, client)
  484. assert.Equal(t, true, client.isRunning)
  485. request := requests.NewCommonRequest()
  486. request.Version = "2014-05-26"
  487. request.ApiName = "DescribeInstanceStatus"
  488. request.QueryParams["PageNumber"] = "1"
  489. request.QueryParams["PageSize"] = "30"
  490. request.Product = "Ecs"
  491. request.TransToAcsRequest()
  492. signer := &signertest{
  493. name: "signer",
  494. }
  495. //Test: regional rule
  496. client.EndpointType = "regional"
  497. httprequest, err := client.buildRequestWithSigner(request, signer)
  498. assert.Nil(t, err)
  499. assert.Equal(t, "ecs.regionid.aliyuncs.com", httprequest.URL.Host)
  500. client.regionId = ""
  501. request.Domain = ""
  502. httprequest, err = client.buildRequestWithSigner(request, signer)
  503. assert.Nil(t, httprequest)
  504. assert.Equal(t, "RegionId is empty, please set a valid RegionId.", err.Error())
  505. //Test: exceptional rule
  506. client.regionId = "regionid"
  507. client.EndpointMap = map[string]string{
  508. "regionid": "ecs.test.com",
  509. }
  510. httprequest, err = client.buildRequestWithSigner(request, signer)
  511. assert.Nil(t, err)
  512. assert.Equal(t, "ecs.test.com", httprequest.URL.Host)
  513. //Test: no valid exceptional rule
  514. request.Domain = ""
  515. client.EndpointMap = map[string]string{
  516. "regiontest": "ecs.test.com",
  517. }
  518. httprequest, err = client.buildRequestWithSigner(request, signer)
  519. assert.Nil(t, err)
  520. assert.Equal(t, "ecs.regionid.aliyuncs.com", httprequest.URL.Host)
  521. //Test: center rule
  522. request.Domain = ""
  523. client.EndpointType = "centeral"
  524. client.Network = "share"
  525. httprequest, err = client.buildRequestWithSigner(request, signer)
  526. assert.Nil(t, err)
  527. assert.Equal(t, "ecs-share.aliyuncs.com", httprequest.URL.Host)
  528. client.SetEndpointRules(client.EndpointMap, "regional", "vpc")
  529. assert.Equal(t, "regional", client.EndpointType)
  530. assert.Equal(t, "vpc", client.Network)
  531. assert.Equal(t, map[string]string{"regiontest": "ecs.test.com"}, client.EndpointMap)
  532. client.Domain = "ecs-client.aliyuncs.com"
  533. request.Domain = ""
  534. httprequest, err = client.buildRequestWithSigner(request, signer)
  535. assert.Nil(t, err)
  536. assert.Equal(t, "ecs-client.aliyuncs.com", httprequest.URL.Host)
  537. request.Domain = "ecs-request.aliyuncs.com"
  538. httprequest, err = client.buildRequestWithSigner(request, signer)
  539. assert.Nil(t, err)
  540. assert.Equal(t, "ecs-request.aliyuncs.com", httprequest.URL.Host)
  541. }
  542. func TestClient_ProcessCommonRequestWithSigner(t *testing.T) {
  543. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  544. assert.Nil(t, err)
  545. assert.NotNil(t, client)
  546. assert.Equal(t, true, client.isRunning)
  547. request := requests.NewCommonRequest()
  548. request.Domain = "ecs.aliyuncs.com"
  549. request.Version = "2014-05-26"
  550. request.ApiName = "DescribeInstanceStatus"
  551. request.QueryParams["PageNumber"] = "1"
  552. request.QueryParams["PageSize"] = "30"
  553. request.RegionId = "regionid"
  554. signer := &signertest{
  555. name: "signer",
  556. }
  557. origTestHookDo := hookDo
  558. defer func() { hookDo = origTestHookDo }()
  559. hookDo = func(fn func(req *http.Request) (*http.Response, error)) func(req *http.Request) (*http.Response, error) {
  560. return func(req *http.Request) (*http.Response, error) {
  561. return mockResponse(500, "Server Internel Error", fmt.Errorf("test error"))
  562. }
  563. }
  564. resp, err := client.ProcessCommonRequestWithSigner(request, signer)
  565. assert.NotNil(t, err)
  566. assert.Contains(t, err.Error(), "test error")
  567. assert.Equal(t, resp.GetHttpContentString(), "")
  568. }
  569. func TestClient_AppendUserAgent(t *testing.T) {
  570. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  571. assert.Nil(t, err)
  572. assert.NotNil(t, client)
  573. assert.Equal(t, true, client.isRunning)
  574. request := requests.NewCommonRequest()
  575. request.Domain = "ecs.aliyuncs.com"
  576. request.Version = "2014-05-26"
  577. request.ApiName = "DescribeInstanceStatus"
  578. request.RegionId = "regionid"
  579. signer := &signertest{
  580. name: "signer",
  581. }
  582. request.TransToAcsRequest()
  583. httpRequest, err := client.buildRequestWithSigner(request, signer)
  584. assert.Nil(t, err)
  585. assert.Equal(t, DefaultUserAgent, httpRequest.Header.Get("User-Agent"))
  586. // Test set client useragent.
  587. client.AppendUserAgent("test", "1.01")
  588. httpRequest, err = client.buildRequestWithSigner(request, signer)
  589. assert.Equal(t, DefaultUserAgent+" test/1.01", httpRequest.Header.Get("User-Agent"))
  590. // Test set request useragent. And request useragent has a higner priority than client's.
  591. request.AppendUserAgent("test", "2.01")
  592. httpRequest, err = client.buildRequestWithSigner(request, signer)
  593. assert.Equal(t, DefaultUserAgent+" test/2.01", httpRequest.Header.Get("User-Agent"))
  594. client.AppendUserAgent("test", "2.02")
  595. httpRequest, err = client.buildRequestWithSigner(request, signer)
  596. assert.Equal(t, DefaultUserAgent+" test/2.01", httpRequest.Header.Get("User-Agent"))
  597. // Test update request useragent.
  598. request.AppendUserAgent("test", "2.02")
  599. httpRequest, err = client.buildRequestWithSigner(request, signer)
  600. assert.Equal(t, DefaultUserAgent+" test/2.02", httpRequest.Header.Get("User-Agent"))
  601. // Test client can't modify DefaultUserAgent.
  602. client.AppendUserAgent("core", "1.01")
  603. httpRequest, err = client.buildRequestWithSigner(request, signer)
  604. assert.Equal(t, DefaultUserAgent+" test/2.02", httpRequest.Header.Get("User-Agent"))
  605. // Test request can't modify DefaultUserAgent.
  606. request.AppendUserAgent("core", "1.01")
  607. httpRequest, err = client.buildRequestWithSigner(request, signer)
  608. assert.Equal(t, DefaultUserAgent+" test/2.02", httpRequest.Header.Get("User-Agent"))
  609. request1 := requests.NewCommonRequest()
  610. request1.Domain = "ecs.aliyuncs.com"
  611. request1.Version = "2014-05-26"
  612. request1.ApiName = "DescribeRegions"
  613. request1.RegionId = "regionid"
  614. request1.AppendUserAgent("sys", "1.01")
  615. request1.TransToAcsRequest()
  616. httpRequest, err = client.buildRequestWithSigner(request1, signer)
  617. assert.Nil(t, err)
  618. assert.Equal(t, DefaultUserAgent+" test/2.02 sys/1.01", httpRequest.Header.Get("User-Agent"))
  619. }
  620. func TestClient_ProcessCommonRequestWithSigner_Error(t *testing.T) {
  621. client, err := NewClientWithAccessKey("regionid", "acesskeyid", "accesskeysecret")
  622. assert.Nil(t, err)
  623. assert.NotNil(t, client)
  624. assert.Equal(t, true, client.isRunning)
  625. request := requests.NewCommonRequest()
  626. request.Domain = "ecs.aliyuncs.com"
  627. request.Version = "2014-05-26"
  628. request.ApiName = "DescribeInstanceStatus"
  629. request.QueryParams["PageNumber"] = "1"
  630. request.QueryParams["PageSize"] = "30"
  631. request.RegionId = "regionid"
  632. origTestHookDo := hookDo
  633. defer func() {
  634. hookDo = origTestHookDo
  635. err := recover()
  636. assert.NotNil(t, err)
  637. }()
  638. hookDo = func(fn func(req *http.Request) (*http.Response, error)) func(req *http.Request) (*http.Response, error) {
  639. return func(req *http.Request) (*http.Response, error) {
  640. return mockResponse(500, "Server Internel Error", fmt.Errorf("test error"))
  641. }
  642. }
  643. resp, err := client.ProcessCommonRequestWithSigner(request, nil)
  644. assert.NotNil(t, err)
  645. assert.Contains(t, err.Error(), "test error")
  646. assert.Equal(t, resp.GetHttpContentString(), "Server Internel Error")
  647. }
  648. func TestClient_NewClientWithStsRoleNameOnEcs(t *testing.T) {
  649. client, err := NewClientWithStsRoleNameOnEcs("regionid", "rolename")
  650. assert.Nil(t, err)
  651. assert.NotNil(t, client)
  652. assert.Equal(t, true, client.isRunning)
  653. config := client.GetConfig()
  654. assert.NotNil(t, config)
  655. err = client.AddAsyncTask(nil)
  656. assert.NotNil(t, err)
  657. }
  658. func TestClient_NewClientWithStsRoleArn(t *testing.T) {
  659. client, err := NewClientWithStsRoleArn("regionid", "acesskeyid", "accesskeysecret", "rolearn", "rolesessionname")
  660. assert.Nil(t, err)
  661. assert.NotNil(t, client)
  662. assert.Equal(t, true, client.isRunning)
  663. task := func() {}
  664. client.asyncTaskQueue = make(chan func(), 1)
  665. err = client.AddAsyncTask(task)
  666. assert.Nil(t, err)
  667. client.Shutdown()
  668. assert.Equal(t, false, client.isRunning)
  669. }
  670. func TestInitWithProviderChain(t *testing.T) {
  671. //testcase1: No any environment variable
  672. c, err := NewClientWithProvider("cn-hangzhou")
  673. assert.Empty(t, c)
  674. assert.EqualError(t, err, "No credential found")
  675. //testcase2: AK
  676. os.Setenv(provider.ENVAccessKeyID, "AccessKeyId")
  677. os.Setenv(provider.ENVAccessKeySecret, "AccessKeySecret")
  678. c, err = NewClientWithProvider("cn-hangzhou")
  679. assert.Nil(t, err)
  680. expC, err := NewClientWithAccessKey("cn-hangzhou", "AccessKeyId", "AccessKeySecret")
  681. assert.Nil(t, err)
  682. assert.Equal(t, expC, c)
  683. //testcase3:AK value is ""
  684. os.Setenv(provider.ENVAccessKeyID, "")
  685. os.Setenv(provider.ENVAccessKeySecret, "bbbb")
  686. c, err = NewClientWithProvider("cn-hangzhou")
  687. assert.EqualError(t, err, "Environmental variable (ALIBABACLOUD_ACCESS_KEY_ID or ALIBABACLOUD_ACCESS_KEY_SECRET) is empty")
  688. assert.Empty(t, c)
  689. //testcase4: Profile value is ""
  690. os.Unsetenv(provider.ENVAccessKeyID)
  691. os.Unsetenv(provider.ENVAccessKeySecret)
  692. os.Setenv(provider.ENVCredentialFile, "")
  693. c, err = NewClientWithProvider("cn-hangzhou")
  694. assert.Empty(t, c)
  695. assert.EqualError(t, err, "Environment variable 'ALIBABA_CLOUD_CREDENTIALS_FILE' cannot be empty")
  696. //testcase5: Profile
  697. os.Setenv(provider.ENVCredentialFile, "./profile")
  698. c, err = NewClientWithProvider("cn-hangzhou")
  699. assert.Empty(t, c)
  700. assert.NotNil(t, err)
  701. //testcase6:Instances
  702. os.Unsetenv(provider.ENVCredentialFile)
  703. os.Setenv(provider.ENVEcsMetadata, "")
  704. c, err = NewClientWithProvider("cn-hangzhou")
  705. assert.Empty(t, c)
  706. assert.EqualError(t, err, "Environmental variable 'ALIBABA_CLOUD_ECS_METADATA' are empty")
  707. //testcase7: Custom Providers
  708. c, err = NewClientWithProvider("cn-hangzhou", provider.ProviderProfile, provider.ProviderEnv)
  709. assert.Empty(t, c)
  710. assert.EqualError(t, err, "No credential found")
  711. }
  712. func TestNewClientWithBearerToken(t *testing.T) {
  713. client, err := NewClientWithBearerToken("cn-hangzhou", "Bearer.Token")
  714. assert.Nil(t, err)
  715. assert.NotNil(t, client)
  716. }