コード例 #1
0
ファイル: server.go プロジェクト: blackgold/FailOverResolver
func check(conf *config.ServiceConfig, i int, cli *http.Client, dataStore *datastore.DataStore) {
	for {
		start := time.Now()
		resp, err := cli.Get(conf.Servers[i].Uri)
		if resp != nil {
			defer resp.Body.Close()
		}
		duration := time.Since(start)
		var ds datastore.ServerData
		if err != nil {
			log.Println("Error :", err)
			ds.Serverstatus = false
		} else {
			if resp.StatusCode != 200 {
				log.Println("Error : response code for " + conf.Servicename + " " + resp.Status)
				ds.Serverstatus = false
			} else {
				ds.Serverstatus = true
			}
			ds.DurationInNs = duration.Nanoseconds()
		}
		dataStore.Update(conf.Servicename, conf.Servers[i].Host, &ds)
		time.Sleep(time.Duration(conf.Algorithm.Ttl) * time.Second)
	}
}
コード例 #2
0
ファイル: for.go プロジェクト: blackgold/FailOverResolver
func main() {
	var conf config.Config
	err := conf.ParseDir("config")
	if err != nil {
		log.Fatal(err)
	}
	var dataStore datastore.DataStore
	dataStore.Init()
	go server.Run(&conf, &dataStore)

	select {}
}
コード例 #3
0
func TestUpdate(t *testing.T) {
	tmp := datastore.DataStore{}
	tmp.Init()
	err := tmp.Update("test", &datastore.ServiceData{Servicestatus: true})
	if err != nil {
		t.Error(err.Error())
	}

	if sqd, ok := tmp.ServiceMap["test"]; !ok {
		t.Error("Test key missing")
	} else {
		if !sqd.Front().Servicestatus {
			t.Error("Expected Servicestatus to be true but got it false")
		}
	}
}