summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLvbo163 <lv.bo163@zte.com.cn>2018-08-02 16:35:15 +0800
committerLvbo163 <lv.bo163@zte.com.cn>2018-08-02 16:35:15 +0800
commitced1de22c3fc25c6150042136ef27eaf4b297451 (patch)
treef244f7cb1a1f7776b06e423d8ed665e06edd81ea
parent8bbc7adaeab5df7c9e9a5e3ad2fa94f6d3a41c2a (diff)
add ut for consul and msb data convert
Issue-ID: MSB-251 Change-Id: I7ee51f893ffb7bf17dd14d5a0cabce27ecdd45a3 Signed-off-by: Lvbo163 <lv.bo163@zte.com.cn>
-rw-r--r--msb2pilot/src/msb2pilot/models/conversion_test.go115
1 files changed, 115 insertions, 0 deletions
diff --git a/msb2pilot/src/msb2pilot/models/conversion_test.go b/msb2pilot/src/msb2pilot/models/conversion_test.go
new file mode 100644
index 0000000..212e994
--- /dev/null
+++ b/msb2pilot/src/msb2pilot/models/conversion_test.go
@@ -0,0 +1,115 @@
+/**
+ * Copyright (c) 2018 ZTE Corporation.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * and the Apache License 2.0 which both accompany this distribution,
+ * and are available at http://www.eclipse.org/legal/epl-v10.html
+ * and http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Contributors:
+ * ZTE - initial Project
+ */
+package models
+
+import (
+ "reflect"
+ "testing"
+)
+
+func TestConvertBaseInfo(t *testing.T) {
+ cases := []struct{ in, want string }{
+ {
+ in: `{"enable_ssl":"true", "version":"v1","protocol":"REST","publish_port":"28012|28013","url":"/api/itm-pmadaptor/v1","is_manual":"false","visualRange":"0","appversion":"v1.18.20.04"}`,
+ want: `v1`,
+ },
+ {
+ in: `{"enable_ssl":"true", "version":"v2","protocol":"UI", "status":"1", "url":"/api/itm-pmadaptor/v1","is_manual":"false"}`,
+ want: `v2`,
+ },
+ {
+ in: `{"others":"other"}`,
+ want: ``,
+ },
+ {
+ in: ``,
+ want: ``,
+ },
+ }
+
+ for _, cas := range cases {
+ got, _ := convertBaseInfo(cas.in)
+ if got.Version != cas.want {
+ t.Errorf("convertBaseInfo(%s) => got %s, want %s", cas.in, got.AppVersion, cas.want)
+ }
+ }
+
+}
+
+func TestConvertNameSpace(t *testing.T) {
+ cases := []struct{ in, want string }{
+ {
+ in: `{"namespace":"test"}`,
+ want: `test`,
+ },
+ {
+ in: `{"namespace":"testwithother", "others":"other"}`,
+ want: `testwithother`,
+ },
+ {
+ in: `{"others":"other"}`,
+ want: ``,
+ },
+ {
+ in: ``,
+ want: ``,
+ },
+ }
+
+ for _, cas := range cases {
+ got, _ := convertNameSpace(cas.in)
+ if got.NameSpace != cas.want {
+ t.Errorf("convertNameSpace(%s) => got %s, want %s", cas.in, got.NameSpace, cas.want)
+ }
+ }
+
+}
+
+func TestConvertMsbLabel(t *testing.T) {
+ cases := []struct{ label, in, want string }{
+ {
+ label: "base",
+ in: `"base":{"enable_ssl":"true", "version":"v1","protocol":"REST","publish_port":"28012|28013","url":"/api/itm-pmadaptor/v1","is_manual":"false","visualRange":"0","appversion":"v1.18.20.04"}`,
+ want: `*models.BaseInfo`,
+ },
+ {
+ label: "ns",
+ in: `"ns":{"namespace":"test"}`,
+ want: `*models.NameSpace`,
+ },
+ {
+ label: "others",
+ in: `{"others":"other"}`,
+ want: ``,
+ },
+ {
+ label: "",
+ in: ``,
+ want: ``,
+ },
+ }
+
+ for _, cas := range cases {
+ got := convertMsbLabel(cas.label, cas.in)
+
+ if got == nil {
+ if cas.want != "" {
+ t.Errorf("convertMsbLabel(%s, %s) => got nil, want %s", cas.label, cas.in, cas.want)
+ }
+ } else {
+ if reflect.TypeOf(got).String() != cas.want {
+ t.Errorf("convertMsbLabel(%s, %s) => got %v, want %s", cas.label, cas.in, reflect.TypeOf(got), cas.want)
+ }
+ }
+ }
+
+}