/* * 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" "os" "path/filepath" "testing" "github.com/kr/pretty" ) var update = flag.Bool("update", false, "update .golden files") func TestMain(m *testing.M) { // 初始化 init BaseDir = DevPath err := ParseConfig("") LogIfError(err, "init ParseConfig") Log.Debug("mysql_test init") // 分割线 flag.Parse() m.Run() // 环境清理 // } func TestParseConfig(t *testing.T) { Log.Debug("Entering function: %s", GetFunctionName()) err := ParseConfig("") if err != nil { t.Error("sqlparser.Parse Error:", err) } Log.Debug("Exiting function: %s", GetFunctionName()) } func TestReadConfigFile(t *testing.T) { Log.Debug("Entering function: %s", GetFunctionName()) if Config == nil { Config = new(Configuration) } Config.readConfigFile(filepath.Join(DevPath, "etc/soar.yaml")) Log.Debug("Exiting function: %s", GetFunctionName()) } func TestParseDSN(t *testing.T) { Log.Debug("Entering function: %s", GetFunctionName()) var dsns = []string{ "", "user:password@hostname:3307/database", "user:password@hostname:3307", "user:password@hostname:/database", "user:password@:3307/database", "user@hostname/database", "user:pwd:pwd@pwd/pwd@hostname/database", "user:password@", "hostname:3307/database", "@hostname:3307/database", "@hostname", "hostname", "@/database", "@hostname:3307", "@:3307/database", ":3307/database", "/database", } err := GoldenDiff(func() { for _, dsn := range dsns { pretty.Println(parseDSN(dsn, nil)) } }, t.Name(), update) if nil != err { t.Fatal(err) } Log.Debug("Exiting function: %s", GetFunctionName()) } func TestListReportTypes(t *testing.T) { Log.Debug("Entering function: %s", GetFunctionName()) err := GoldenDiff(func() { ListReportTypes() }, t.Name(), update) if nil != err { t.Fatal(err) } Log.Debug("Exiting function: %s", GetFunctionName()) } func TestArgConfig(t *testing.T) { Log.Debug("Entering function: %s", GetFunctionName()) 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) } } Log.Debug("Exiting function: %s", GetFunctionName()) } func TestPrintConfiguration(t *testing.T) { Log.Debug("Entering function: %s", GetFunctionName()) 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 Log.Debug("Exiting function: %s", GetFunctionName()) }