client_test.go 27 KB

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