edgex_source_test.go 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340
  1. // Copyright 2021 EMQ Technologies Co., Ltd.
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. // +build edgex
  15. package source
  16. import (
  17. "encoding/json"
  18. "fmt"
  19. v2 "github.com/edgexfoundry/go-mod-core-contracts/v2/common"
  20. "github.com/edgexfoundry/go-mod-core-contracts/v2/dtos"
  21. "github.com/edgexfoundry/go-mod-core-contracts/v2/models"
  22. "github.com/edgexfoundry/go-mod-messaging/v2/pkg/types"
  23. "github.com/lf-edge/ekuiper/internal/conf"
  24. "math"
  25. "reflect"
  26. "testing"
  27. )
  28. var (
  29. es = &EdgexSource{}
  30. typeMap = map[string]string{
  31. "b1": v2.ValueTypeBool,
  32. "i1": v2.ValueTypeInt8,
  33. "i2": v2.ValueTypeInt16,
  34. "i3": v2.ValueTypeInt32,
  35. "i4": v2.ValueTypeInt64,
  36. "i5": v2.ValueTypeUint8,
  37. "i6": v2.ValueTypeUint16,
  38. "i7": v2.ValueTypeUint32,
  39. "s1": v2.ValueTypeString,
  40. "f1": v2.ValueTypeFloat32,
  41. "f2": v2.ValueTypeFloat64,
  42. "i8": v2.ValueTypeUint64,
  43. "ba": v2.ValueTypeBoolArray,
  44. "ia1": v2.ValueTypeInt8Array,
  45. "ia2": v2.ValueTypeInt16Array,
  46. "ia3": v2.ValueTypeInt32Array,
  47. "ia4": v2.ValueTypeInt64Array,
  48. "ia5": v2.ValueTypeUint8Array,
  49. "ia6": v2.ValueTypeUint16Array,
  50. "ia7": v2.ValueTypeUint32Array,
  51. "ia8": v2.ValueTypeUint64Array,
  52. "fa1": v2.ValueTypeFloat32Array,
  53. "fa2": v2.ValueTypeFloat64Array,
  54. }
  55. )
  56. func TestGetValue_IntFloat(t *testing.T) {
  57. var testEvent = models.Event{DeviceName: "test"}
  58. for i := 1; i < 8; i++ {
  59. name := fmt.Sprintf("i%d", i)
  60. r1 := models.SimpleReading{
  61. BaseReading: models.BaseReading{
  62. ResourceName: name,
  63. ValueType: typeMap[name],
  64. },
  65. Value: "1",
  66. }
  67. testEvent.Readings = append(testEvent.Readings, r1)
  68. }
  69. dtoe := dtos.FromEventModelToDTO(testEvent)
  70. for _, r := range dtoe.Readings {
  71. if v, e := es.getValue(r, conf.Log); e != nil {
  72. t.Errorf("%s", e)
  73. } else {
  74. expectOne(t, v)
  75. }
  76. }
  77. r1 := dtos.BaseReading{ResourceName: "i8", ValueType: typeMap["i8"], SimpleReading: dtos.SimpleReading{Value: "10796529505058023104"}}
  78. if v, e := es.getValue(r1, conf.Log); e != nil {
  79. t.Errorf("%s", e)
  80. } else {
  81. if v1, ok := v.(uint64); ok {
  82. if v1 != 10796529505058023104 {
  83. t.Errorf("expected 10796529505058023104, but it's %d.", v1)
  84. }
  85. }
  86. }
  87. r2 := dtos.BaseReading{ResourceName: "f1", ValueType: typeMap["f1"], SimpleReading: dtos.SimpleReading{Value: "3.14"}}
  88. if v, e := es.getValue(r2, conf.Log); e != nil {
  89. t.Errorf("%s", e)
  90. } else {
  91. if v1, ok := v.(float64); ok {
  92. if !almostEqual(v1, 3.14) {
  93. t.Errorf("expected 3.14, but it's %f.", v1)
  94. }
  95. }
  96. }
  97. }
  98. func almostEqual(a, b float64) bool {
  99. return math.Abs(a-b) <= 1e-6
  100. }
  101. func TestGetValue_IntFloatArr(t *testing.T) {
  102. var testEvent = models.Event{DeviceName: "test"}
  103. for i := 1; i < 8; i++ {
  104. ia := []int{i, i * 2}
  105. jsonValue, _ := json.Marshal(ia)
  106. name := fmt.Sprintf("ia%d", i)
  107. r1 := models.SimpleReading{
  108. BaseReading: models.BaseReading{
  109. ResourceName: name,
  110. ValueType: typeMap[name],
  111. },
  112. Value: string(jsonValue),
  113. }
  114. testEvent.Readings = append(testEvent.Readings, r1)
  115. }
  116. dtoe := dtos.FromEventModelToDTO(testEvent)
  117. for i, r := range dtoe.Readings {
  118. if v, e := es.getValue(r, conf.Log); e != nil {
  119. t.Errorf("%s", e)
  120. } else {
  121. checkArray(t, i, v)
  122. }
  123. }
  124. r1 := dtos.BaseReading{ResourceName: "ia8", ValueType: typeMap["ia8"], SimpleReading: dtos.SimpleReading{Value: `[10796529505058023104, 10796529505058023105]`}}
  125. if v, e := es.getValue(r1, conf.Log); e != nil {
  126. t.Errorf("%s", e)
  127. } else {
  128. if v1, ok := v.([]uint64); ok {
  129. if v1[0] != 10796529505058023104 || v1[1] != 10796529505058023105 {
  130. t.Errorf("Failed, the array value is not correct %v.", v1)
  131. }
  132. } else {
  133. t.Errorf("expected uint64 array type, but it's %T.", v1)
  134. }
  135. }
  136. rf_00 := dtos.BaseReading{ResourceName: "fa1", ValueType: typeMap["fa1"], SimpleReading: dtos.SimpleReading{Value: `[3.14, 2.71828]`}}
  137. if v, e := es.getValue(rf_00, conf.Log); e != nil {
  138. t.Errorf("%s", e)
  139. } else {
  140. if v1, ok := v.([]float64); ok {
  141. if v1[0] != 3.14 || v1[1] != 2.71828 {
  142. t.Errorf("expected 3.14 & 2.71828, but it's %v.", v1)
  143. }
  144. } else {
  145. t.Errorf("expected float32 array type, but it's %T.", v)
  146. }
  147. }
  148. }
  149. func checkArray(t *testing.T, index int, val interface{}) {
  150. if v1, ok := val.([]int); ok {
  151. newIdx := index + 1
  152. if v1[0] != newIdx || v1[1] != newIdx*2 {
  153. t.Errorf("Failed, the array value is not correct %v.", v1)
  154. }
  155. } else {
  156. t.Errorf("expected int array type, but it's %T.", val)
  157. }
  158. }
  159. func expectOne(t *testing.T, expected interface{}) {
  160. if v1, ok := expected.(int); ok {
  161. if v1 != 1 {
  162. t.Errorf("expected 1, but it's %d.", v1)
  163. }
  164. } else {
  165. t.Errorf("expected int type, but it's %T.", expected)
  166. }
  167. }
  168. func TestGetValue_Float(t *testing.T) {
  169. var testEvent = models.Event{DeviceName: "test"}
  170. for i := 1; i < 3; i++ {
  171. name := fmt.Sprintf("f%d", i)
  172. r1 := models.SimpleReading{
  173. BaseReading: models.BaseReading{
  174. ResourceName: name,
  175. ValueType: typeMap[name],
  176. },
  177. Value: "3.14",
  178. }
  179. testEvent.Readings = append(testEvent.Readings, r1)
  180. }
  181. dtoe := dtos.FromEventModelToDTO(testEvent)
  182. for _, r := range dtoe.Readings {
  183. if v, e := es.getValue(r, conf.Log); e != nil {
  184. t.Errorf("%s", e)
  185. } else {
  186. expectPi(t, v)
  187. }
  188. }
  189. }
  190. func expectPi(t *testing.T, expected interface{}) {
  191. if v1, ok := expected.(float64); ok {
  192. if !almostEqual(v1, 3.14) {
  193. t.Errorf("expected 3.14, but it's %f.", v1)
  194. }
  195. } else {
  196. t.Errorf("expected float type, but it's %T.", expected)
  197. }
  198. }
  199. func TestGetValue_Bool(t *testing.T) {
  200. ///////////True
  201. trues := []string{"1", "t", "T", "true", "TRUE", "True"}
  202. for _, v := range trues {
  203. r1 := dtos.BaseReading{ResourceName: "b1", ValueType: typeMap["b1"], SimpleReading: dtos.SimpleReading{Value: v}}
  204. if v, e := es.getValue(r1, conf.Log); e != nil {
  205. t.Errorf("%s", e)
  206. } else {
  207. expectTrue(t, v)
  208. }
  209. }
  210. r1 := dtos.BaseReading{ResourceName: "b1", ValueType: typeMap["b1"], SimpleReading: dtos.SimpleReading{Value: "TRue"}}
  211. if _, e := es.getValue(r1, conf.Log); e == nil {
  212. t.Errorf("%s", e)
  213. }
  214. ///////////False
  215. falses := []string{"0", "f", "F", "false", "FALSE", "False"}
  216. for _, v := range falses {
  217. r1 := dtos.BaseReading{ResourceName: "b1", ValueType: typeMap["b1"], SimpleReading: dtos.SimpleReading{Value: v}}
  218. if v, e := es.getValue(r1, conf.Log); e != nil {
  219. t.Errorf("%s", e)
  220. } else {
  221. expectFalse(t, v)
  222. }
  223. }
  224. r1 = dtos.BaseReading{ResourceName: "b1", ValueType: typeMap["b1"], SimpleReading: dtos.SimpleReading{Value: "FAlse"}}
  225. if _, e := es.getValue(r1, conf.Log); e == nil {
  226. t.Errorf("%s", e)
  227. }
  228. }
  229. func expectTrue(t *testing.T, expected interface{}) {
  230. if v1, ok := expected.(bool); ok {
  231. if !v1 {
  232. t.Errorf("expected true, but it's false.")
  233. }
  234. } else {
  235. t.Errorf("expected boolean type, but it's %t.", expected)
  236. }
  237. }
  238. func expectFalse(t *testing.T, expected interface{}) {
  239. if v1, ok := expected.(bool); ok {
  240. if v1 {
  241. t.Errorf("expected false, but it's true.")
  242. }
  243. } else {
  244. t.Errorf("expected boolean type, but it's %t.", expected)
  245. }
  246. }
  247. func TestWrongType(t *testing.T) {
  248. r1 := dtos.BaseReading{ResourceName: "f", ValueType: "FLOAT", SimpleReading: dtos.SimpleReading{Value: "100"}}
  249. if v, _ := es.getValue(r1, conf.Log); v != "100" {
  250. t.Errorf("Expected 100, but it's %s!", v)
  251. }
  252. }
  253. func TestWrongValue(t *testing.T) {
  254. var testEvent = models.Event{DeviceName: "test"}
  255. //100 cannot be converted to a boolean value
  256. r1 := models.SimpleReading{
  257. BaseReading: models.BaseReading{
  258. ResourceName: "b1",
  259. ValueType: typeMap["b1"],
  260. },
  261. Value: "100",
  262. }
  263. //'int' string cannot be converted to int value
  264. r2 := models.SimpleReading{
  265. BaseReading: models.BaseReading{
  266. ResourceName: "i1",
  267. ValueType: typeMap["i1"],
  268. },
  269. Value: "int",
  270. }
  271. //'float' string cannot be converted to int value
  272. r3 := models.SimpleReading{
  273. BaseReading: models.BaseReading{
  274. ResourceName: "f1",
  275. ValueType: typeMap["f1"],
  276. },
  277. Value: "float",
  278. }
  279. testEvent.Readings = append(testEvent.Readings, r1, r2, r3)
  280. dtoe := dtos.FromEventModelToDTO(testEvent)
  281. for _, v := range dtoe.Readings {
  282. if _, e := es.getValue(v, conf.Log); e == nil {
  283. t.Errorf("Expected an error!")
  284. }
  285. }
  286. }
  287. func TestPrintConf(t *testing.T) {
  288. expMbconf := types.MessageBusConfig{SubscribeHost: types.HostInfo{Protocol: "tcp", Host: "127.0.0.1", Port: 6625}, Type: "mbus", Optional: map[string]string{
  289. "proa": "proa",
  290. "Password": "fafsadfsadf=",
  291. "Prob": "Prob",
  292. }}
  293. mbconf := types.MessageBusConfig{SubscribeHost: types.HostInfo{Protocol: "tcp", Host: "127.0.0.1", Port: 6625}, Type: "mbus", Optional: map[string]string{
  294. "proa": "proa",
  295. "Password": "fafsadfsadf=",
  296. "Prob": "Prob",
  297. }}
  298. printConf(mbconf)
  299. if !reflect.DeepEqual(expMbconf, mbconf) {
  300. t.Errorf("conf changed after printing")
  301. }
  302. }
  303. func TestGetValue_Binary(t *testing.T) {
  304. ev := []byte("Hello World")
  305. r1 := dtos.BaseReading{ResourceName: "bin", ValueType: v2.ValueTypeBinary, BinaryReading: dtos.BinaryReading{MediaType: "application/text", BinaryValue: ev}}
  306. if v, e := es.getValue(r1, conf.Log); e != nil {
  307. t.Errorf("%s", e)
  308. } else if !reflect.DeepEqual(ev, v) {
  309. t.Errorf("result mismatch, expect %v, but got %v", ev, v)
  310. }
  311. }