sdk.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. package v1
  2. import (
  3. "fmt"
  4. "git.sxidc.com/service-supports/dps-sdk"
  5. "git.sxidc.com/service-supports/dps-sdk/ports"
  6. "github.com/stretchr/testify/assert"
  7. "testing"
  8. )
  9. var clientInstance ports.Client
  10. func initClient(t *testing.T, address string) {
  11. client, err := dps.NewClient(address, "v1")
  12. if err != nil {
  13. t.Fatal(err)
  14. }
  15. clientInstance = client
  16. }
  17. func destroyClient(t *testing.T) {
  18. err := dps.DestroyClient("v1")
  19. if err != nil {
  20. t.Fatal(err)
  21. }
  22. clientInstance = nil
  23. }
  24. type ToolKit struct {
  25. t *testing.T
  26. }
  27. func newToolKit(t *testing.T) *ToolKit {
  28. return &ToolKit{t: t}
  29. }
  30. func (toolKit *ToolKit) autoMigrate(req *ports.AutoMigrateRequest) *ToolKit {
  31. err := clientInstance.AutoMigrate(req)
  32. if err != nil {
  33. toolKit.t.Fatal(err)
  34. }
  35. return toolKit
  36. }
  37. func (toolKit *ToolKit) transaction(databaseID string, txFunc ports.TransactionFunc) *ToolKit {
  38. err := clientInstance.Transaction(databaseID, txFunc)
  39. if err != nil {
  40. toolKit.t.Fatal(err)
  41. }
  42. return toolKit
  43. }
  44. func (toolKit *ToolKit) insert(req *ports.InsertRequest) *ToolKit {
  45. statement, err := clientInstance.Insert(req)
  46. if err != nil {
  47. toolKit.t.Fatal(err)
  48. }
  49. fmt.Println(statement)
  50. return toolKit
  51. }
  52. func (toolKit *ToolKit) insertBatch(req *ports.InsertBatchRequest) *ToolKit {
  53. statement, err := clientInstance.InsertBatch(req)
  54. if err != nil {
  55. toolKit.t.Fatal(err)
  56. }
  57. fmt.Println(statement)
  58. return toolKit
  59. }
  60. func (toolKit *ToolKit) delete(req *ports.DeleteRequest) *ToolKit {
  61. statement, err := clientInstance.Delete(req)
  62. if err != nil {
  63. toolKit.t.Fatal(err)
  64. }
  65. fmt.Println(statement)
  66. return toolKit
  67. }
  68. func (toolKit *ToolKit) deleteBatch(req *ports.DeleteBatchRequest) *ToolKit {
  69. statement, err := clientInstance.DeleteBatch(req)
  70. if err != nil {
  71. toolKit.t.Fatal(err)
  72. }
  73. fmt.Println(statement)
  74. return toolKit
  75. }
  76. func (toolKit *ToolKit) update(req *ports.UpdateRequest) *ToolKit {
  77. statement, err := clientInstance.Update(req)
  78. if err != nil {
  79. toolKit.t.Fatal(err)
  80. }
  81. fmt.Println(statement)
  82. return toolKit
  83. }
  84. func (toolKit *ToolKit) reply(req *ports.ReplayRequest) *ToolKit {
  85. statement, err := clientInstance.Replay(req)
  86. if err != nil {
  87. toolKit.t.Fatal(err)
  88. }
  89. fmt.Println(statement)
  90. return toolKit
  91. }
  92. func (toolKit *ToolKit) queryByWhereAndOrderBy(req *ports.QueryByWhereAndOrderByRequest, retInfosMap *[]map[string]any) *ToolKit {
  93. statement, infosMap, totalCount, err := clientInstance.QueryByWhereAndOrderBy(req)
  94. if err != nil {
  95. toolKit.t.Fatal(err)
  96. }
  97. toolKit.assertEqual(len(infosMap), int(totalCount), "总数不一致")
  98. fmt.Println(statement)
  99. if retInfosMap != nil {
  100. *retInfosMap = make([]map[string]any, 0)
  101. *retInfosMap = infosMap
  102. }
  103. return toolKit
  104. }
  105. func (toolKit *ToolKit) commonQuery(req *ports.CommonQueryRequest, retInfosMap *[]map[string]any) *ToolKit {
  106. statement, infosMap, totalCount, err := clientInstance.CommonQuery(req)
  107. if err != nil {
  108. toolKit.t.Fatal(err)
  109. }
  110. toolKit.assertEqual(len(infosMap), int(totalCount), "总数不一致")
  111. fmt.Println(statement)
  112. if retInfosMap != nil {
  113. *retInfosMap = make([]map[string]any, 0)
  114. *retInfosMap = infosMap
  115. }
  116. return toolKit
  117. }
  118. func (toolKit *ToolKit) queryByKeys(req *ports.QueryByKeysRequest, retInfoMap *map[string]any) *ToolKit {
  119. statement, infoMap, err := clientInstance.QueryByKeys(req)
  120. if err != nil {
  121. toolKit.t.Fatal(err)
  122. }
  123. fmt.Println(statement)
  124. if retInfoMap != nil {
  125. *retInfoMap = make(map[string]any)
  126. *retInfoMap = infoMap
  127. }
  128. return toolKit
  129. }
  130. func (toolKit *ToolKit) countWhere(req *ports.CountWhereRequest, retCount *int64) *ToolKit {
  131. statement, count, err := clientInstance.CountWhere(req)
  132. if err != nil {
  133. toolKit.t.Fatal(err)
  134. }
  135. fmt.Println(statement)
  136. if retCount != nil {
  137. *retCount = count
  138. }
  139. return toolKit
  140. }
  141. func (toolKit *ToolKit) commonCount(req *ports.CommonCountRequest, retCount *int64) *ToolKit {
  142. statement, count, err := clientInstance.CommonCount(req)
  143. if err != nil {
  144. toolKit.t.Fatal(err)
  145. }
  146. fmt.Println(statement)
  147. if retCount != nil {
  148. *retCount = count
  149. }
  150. return toolKit
  151. }
  152. func (toolKit *ToolKit) assertEqual(expected interface{}, actual interface{}, msgAndArgs ...interface{}) *ToolKit {
  153. assert.Equal(toolKit.t, expected, actual, msgAndArgs)
  154. return toolKit
  155. }
  156. func (toolKit *ToolKit) assertNotEqual(expected interface{}, actual interface{}, msgAndArgs ...interface{}) *ToolKit {
  157. assert.NotEqual(toolKit.t, expected, actual, msgAndArgs)
  158. return toolKit
  159. }
  160. func (toolKit *ToolKit) assertNotEmpty(object interface{}, msgAndArgs ...interface{}) *ToolKit {
  161. assert.NotEmpty(toolKit.t, object, msgAndArgs)
  162. return toolKit
  163. }