config_test.go 3.6 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 24 25 26 27 28 29
	"testing"

	"github.com/kr/pretty"
)

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

30 31
func TestMain(m *testing.M) {
	// 初始化 init
martianzhang's avatar
martianzhang 已提交
32
	BaseDir = DevPath
martianzhang's avatar
martianzhang 已提交
33 34 35
	err := ParseConfig("")
	LogIfError(err, "init ParseConfig")
	Log.Debug("mysql_test init")
36 37 38 39 40 41 42

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

	// 环境清理
	//
martianzhang's avatar
martianzhang 已提交
43 44
}

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

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

func TestParseDSN(t *testing.T) {
martianzhang's avatar
martianzhang 已提交
64
	Log.Debug("Entering function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
65 66 67 68 69 70
	var dsns = []string{
		"",
		"user:password@hostname:3307/database",
		"user:password@hostname:3307",
		"user:password@hostname:/database",
		"user:password@:3307/database",
X
xiyangxixian 已提交
71 72
		"user@hostname/database",
		"user:pwd:pwd@pwd/pwd@hostname/database",
martianzhang's avatar
martianzhang 已提交
73 74 75 76 77 78 79 80 81 82 83 84
		"user:password@",
		"hostname:3307/database",
		"@hostname:3307/database",
		"@hostname",
		"hostname",
		"@/database",
		"@hostname:3307",
		"@:3307/database",
		":3307/database",
		"/database",
	}

martianzhang's avatar
martianzhang 已提交
85
	err := GoldenDiff(func() {
martianzhang's avatar
martianzhang 已提交
86 87 88 89
		for _, dsn := range dsns {
			pretty.Println(parseDSN(dsn, nil))
		}
	}, t.Name(), update)
martianzhang's avatar
martianzhang 已提交
90 91 92
	if nil != err {
		t.Fatal(err)
	}
martianzhang's avatar
martianzhang 已提交
93
	Log.Debug("Exiting function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
94 95 96
}

func TestListReportTypes(t *testing.T) {
martianzhang's avatar
martianzhang 已提交
97
	Log.Debug("Entering function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
98 99 100 101
	err := GoldenDiff(func() { ListReportTypes() }, t.Name(), update)
	if nil != err {
		t.Fatal(err)
	}
martianzhang's avatar
martianzhang 已提交
102
	Log.Debug("Exiting function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
103
}
martianzhang's avatar
martianzhang 已提交
104 105

func TestArgConfig(t *testing.T) {
martianzhang's avatar
martianzhang 已提交
106
	Log.Debug("Entering function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
	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 已提交
130
	Log.Debug("Exiting function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
131
}
132 133

func TestPrintConfiguration(t *testing.T) {
martianzhang's avatar
martianzhang 已提交
134
	Log.Debug("Entering function: %s", GetFunctionName())
martianzhang's avatar
martianzhang 已提交
135 136 137 138 139 140 141 142 143 144
	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 已提交
145
	Log.Debug("Exiting function: %s", GetFunctionName())
146
}