config_test.go 4.7 KB
Newer Older
martianzhang's avatar
martianzhang 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
/*
 * Copyright 2018 Xiaomi, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package common

import (
	"flag"
martianzhang's avatar
martianzhang 已提交
21
	"os"
martianzhang's avatar
martianzhang 已提交
22
	"path/filepath"
martianzhang's avatar
martianzhang 已提交
23
	"runtime"
martianzhang's avatar
martianzhang 已提交
24 25 26 27 28 29 30
	"testing"

	"github.com/kr/pretty"
)

var update = flag.Bool("update", false, "update .golden files")

31 32
func TestMain(m *testing.M) {
	// 初始化 init
martianzhang's avatar
martianzhang 已提交
33 34 35 36
	if DevPath == "" {
		_, file, _, _ := runtime.Caller(0)
		DevPath, _ = filepath.Abs(filepath.Dir(filepath.Join(file, ".."+string(filepath.Separator))))
	}
martianzhang's avatar
martianzhang 已提交
37
	BaseDir = DevPath
martianzhang's avatar
martianzhang 已提交
38 39 40
	err := ParseConfig("")
	LogIfError(err, "init ParseConfig")
	Log.Debug("mysql_test init")
41 42 43 44 45 46 47

	// 分割线
	flag.Parse()
	m.Run()

	// 环境清理
	//
martianzhang's avatar
martianzhang 已提交
48 49
}

martianzhang's avatar
martianzhang 已提交
50
func TestParseConfig(t *testing.T) {
martianzhang's avatar
martianzhang 已提交
51
	Log.Debug("Entering function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
52 53 54 55
	err := ParseConfig("")
	if err != nil {
		t.Error("sqlparser.Parse Error:", err)
	}
martianzhang's avatar
martianzhang 已提交
56
	Log.Debug("Exiting function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
57 58 59
}

func TestReadConfigFile(t *testing.T) {
martianzhang's avatar
martianzhang 已提交
60
	Log.Debug("Entering function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
61
	if Config == nil {
62
		Config = new(Configuration)
martianzhang's avatar
martianzhang 已提交
63
	}
martianzhang's avatar
martianzhang 已提交
64
	Config.readConfigFile(filepath.Join(DevPath, "etc/soar.yaml"))
martianzhang's avatar
martianzhang 已提交
65
	Log.Debug("Exiting function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
66 67 68
}

func TestParseDSN(t *testing.T) {
martianzhang's avatar
martianzhang 已提交
69
	Log.Debug("Entering function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
70
	var dsns = []string{
martianzhang's avatar
martianzhang 已提交
71
		// version < 0.11.0
martianzhang's avatar
martianzhang 已提交
72 73
		"",
		"user:password@hostname:3307/database",
martianzhang's avatar
martianzhang 已提交
74
		"user:password@hostname:3307/database?charset=utf8",
martianzhang's avatar
martianzhang 已提交
75 76 77
		"user:password@hostname:3307",
		"user:password@hostname:/database",
		"user:password@:3307/database",
X
xiyangxixian 已提交
78 79
		"user@hostname/database",
		"user:pwd:pwd@pwd/pwd@hostname/database",
martianzhang's avatar
martianzhang 已提交
80 81 82 83 84 85 86 87 88 89
		"user:password@",
		"hostname:3307/database",
		"@hostname:3307/database",
		"@hostname",
		"hostname",
		"@/database",
		"@hostname:3307",
		"@:3307/database",
		":3307/database",
		"/database",
martianzhang's avatar
martianzhang 已提交
90 91 92
		// go-sql-driver dsn
		"user@unix(/path/to/socket)/dbname",
		"root:pw@unix(/tmp/mysql.sock)/myDatabase?loc=Local",
martianzhang's avatar
martianzhang 已提交
93 94
		"user:password@tcp(localhost:5555)/dbname?tls=skip-verify",
		"user:password@tcp(localhost:5555)/dbname?autocommit=true",
martianzhang's avatar
martianzhang 已提交
95
		"user:password@/dbname?sql_mode=TRADITIONAL",
martianzhang's avatar
martianzhang 已提交
96 97
		"user:password@tcp([de:ad:be:ef::ca:fe]:80)/dbname?timeout=90s",
		"user:password@tcp([de:ad:be:ef::ca:fe]:80)/dbname?collation=utf8mb4_unicode_ci",
martianzhang's avatar
martianzhang 已提交
98 99 100
		"id:password@tcp(your-amazonaws-uri.com:3306)/dbname",
		"user@cloudsql(project-id:instance-name)/dbname",
		"user@cloudsql(project-id:regionname:instance-name)/dbname",
martianzhang's avatar
martianzhang 已提交
101 102
		//"user:password@tcp/dbname?charset=utf8mb4,utf8&sys_var=esc%40ped", multi key in map, pretty print in random order, by pass
		"user:password@tcp/dbname?sys_var=esc%40ped",
martianzhang's avatar
martianzhang 已提交
103 104
		"user:password@/dbname",
		"user:password@/",
martianzhang's avatar
martianzhang 已提交
105
		"user:password@tcp(localhost:3307)/database?timeout=5s",
martianzhang's avatar
martianzhang 已提交
106
	}
martianzhang's avatar
martianzhang 已提交
107
	err := GoldenDiff(func() {
martianzhang's avatar
martianzhang 已提交
108
		for _, dsn := range dsns {
martianzhang's avatar
martianzhang 已提交
109 110
			pretty.Println(dsn)
			pretty.Println(ParseDSN(dsn, nil))
martianzhang's avatar
martianzhang 已提交
111 112
		}
	}, t.Name(), update)
martianzhang's avatar
martianzhang 已提交
113 114 115
	if nil != err {
		t.Fatal(err)
	}
martianzhang's avatar
martianzhang 已提交
116
	Log.Debug("Exiting function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
117 118 119
}

func TestListReportTypes(t *testing.T) {
martianzhang's avatar
martianzhang 已提交
120
	Log.Debug("Entering function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
121 122 123 124
	err := GoldenDiff(func() { ListReportTypes() }, t.Name(), update)
	if nil != err {
		t.Fatal(err)
	}
martianzhang's avatar
martianzhang 已提交
125
	Log.Debug("Exiting function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
126
}
martianzhang's avatar
martianzhang 已提交
127 128

func TestArgConfig(t *testing.T) {
martianzhang's avatar
martianzhang 已提交
129
	Log.Debug("Entering function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152
	testArgs1 := [][]string{
		{"soar", "-config", "=", "soar.yaml"},
		{"soar", "-print-config", "-config", "soar.yaml"},
	}
	testArgs2 := [][]string{
		{"soar", "-config", "soar.yaml"},
		{"soar", "-config", "=soar.yaml"},
		{"soar", "-config=soar.yaml"},
	}
	for _, args := range testArgs1 {
		os.Args = args
		configFile := ArgConfig()
		if configFile != "" {
			t.Errorf("should return '', but got %s", configFile)
		}
	}
	for _, args := range testArgs2 {
		os.Args = args
		configFile := ArgConfig()
		if configFile != "soar.yaml" {
			t.Errorf("should return soar.yaml, but got %s", configFile)
		}
	}
martianzhang's avatar
martianzhang 已提交
153
	Log.Debug("Exiting function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
154
}
155 156

func TestPrintConfiguration(t *testing.T) {
martianzhang's avatar
martianzhang 已提交
157
	Log.Debug("Entering function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
158 159 160 161 162 163 164 165 166 167
	Config.readConfigFile(filepath.Join(DevPath, "etc/soar.yaml"))
	oldLogOutput := Config.LogOutput
	Config.LogOutput = "soar.log"
	err := GoldenDiff(func() {
		PrintConfiguration()
	}, t.Name(), update)
	if err != nil {
		t.Error(err)
	}
	Config.LogOutput = oldLogOutput
martianzhang's avatar
martianzhang 已提交
168
	Log.Debug("Exiting function: %s", GetFunctionName())
169
}