mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-14 07:26:47 +00:00
* engine: GetSubsystemsStatus fix * engine: force map literal to stop doubling up on keys, expanded test coverage * engine: Deploy default for migration requirement. * glorious: nits addr * glorious: suggestion * tests: fix
207 lines
4.8 KiB
Go
207 lines
4.8 KiB
Go
package engine
|
|
|
|
import (
|
|
"errors"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/thrasher-corp/gocryptotrader/config"
|
|
)
|
|
|
|
func TestSetupNTPManager(t *testing.T) {
|
|
_, err := setupNTPManager(nil, false)
|
|
if !errors.Is(err, errNilConfig) {
|
|
t.Errorf("error '%v', expected '%v'", err, errNilConfig)
|
|
}
|
|
_, err = setupNTPManager(&config.NTPClientConfig{}, false)
|
|
if !errors.Is(err, errNilNTPConfigValues) {
|
|
t.Errorf("error '%v', expected '%v'", err, errNilNTPConfigValues)
|
|
}
|
|
sec := time.Second
|
|
cfg := &config.NTPClientConfig{
|
|
AllowedDifference: &sec,
|
|
AllowedNegativeDifference: &sec,
|
|
}
|
|
m, err := setupNTPManager(cfg, false)
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
if m == nil {
|
|
t.Error("expected manager")
|
|
}
|
|
}
|
|
|
|
func TestNTPManagerIsRunning(t *testing.T) {
|
|
var m *ntpManager
|
|
if m.IsRunning() {
|
|
t.Error("expected false")
|
|
}
|
|
|
|
sec := time.Second
|
|
cfg := &config.NTPClientConfig{
|
|
AllowedDifference: &sec,
|
|
AllowedNegativeDifference: &sec,
|
|
Level: 1,
|
|
}
|
|
m, err := setupNTPManager(cfg, false)
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
if m.IsRunning() {
|
|
t.Error("expected false")
|
|
}
|
|
|
|
err = m.Start()
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if !m.IsRunning() {
|
|
t.Error("expected true")
|
|
}
|
|
}
|
|
|
|
func TestNTPManagerStart(t *testing.T) {
|
|
var m *ntpManager
|
|
err := m.Start()
|
|
if !errors.Is(err, ErrNilSubsystem) {
|
|
t.Errorf("error '%v', expected '%v'", err, ErrNilSubsystem)
|
|
}
|
|
|
|
sec := time.Second
|
|
cfg := &config.NTPClientConfig{
|
|
AllowedDifference: &sec,
|
|
AllowedNegativeDifference: &sec,
|
|
}
|
|
m, err = setupNTPManager(cfg, true)
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
|
|
err = m.Start()
|
|
if !errors.Is(err, errNTPManagerDisabled) {
|
|
t.Errorf("error '%v', expected '%v'", err, errNTPManagerDisabled)
|
|
}
|
|
|
|
m.level = 1
|
|
err = m.Start()
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
|
|
err = m.Start()
|
|
if !errors.Is(err, ErrSubSystemAlreadyStarted) {
|
|
t.Errorf("error '%v', expected '%v'", err, ErrSubSystemAlreadyStarted)
|
|
}
|
|
}
|
|
|
|
func TestNTPManagerStop(t *testing.T) {
|
|
var m *ntpManager
|
|
err := m.Stop()
|
|
if !errors.Is(err, ErrNilSubsystem) {
|
|
t.Errorf("error '%v', expected '%v'", err, ErrNilSubsystem)
|
|
}
|
|
|
|
sec := time.Second
|
|
cfg := &config.NTPClientConfig{
|
|
AllowedDifference: &sec,
|
|
AllowedNegativeDifference: &sec,
|
|
Level: 1,
|
|
}
|
|
m, err = setupNTPManager(cfg, true)
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
err = m.Stop()
|
|
if !errors.Is(err, ErrSubSystemNotStarted) {
|
|
t.Errorf("error '%v', expected '%v'", err, ErrSubSystemNotStarted)
|
|
}
|
|
|
|
err = m.Start()
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
err = m.Stop()
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
}
|
|
|
|
func TestFetchNTPTime(t *testing.T) {
|
|
var m *ntpManager
|
|
_, err := m.FetchNTPTime()
|
|
if !errors.Is(err, ErrNilSubsystem) {
|
|
t.Errorf("error '%v', expected '%v'", err, ErrNilSubsystem)
|
|
}
|
|
sec := time.Second
|
|
cfg := &config.NTPClientConfig{
|
|
AllowedDifference: &sec,
|
|
AllowedNegativeDifference: &sec,
|
|
Level: 1,
|
|
}
|
|
m, err = setupNTPManager(cfg, true)
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
_, err = m.FetchNTPTime()
|
|
if !errors.Is(err, ErrSubSystemNotStarted) {
|
|
t.Errorf("error '%v', expected '%v'", err, ErrSubSystemNotStarted)
|
|
}
|
|
|
|
err = m.Start()
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
|
|
tt, err := m.FetchNTPTime()
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
if tt.IsZero() {
|
|
t.Error("expected time")
|
|
}
|
|
|
|
m.pools = []string{"0.pool.ntp.org:123"}
|
|
tt, err = m.FetchNTPTime()
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
if tt.IsZero() {
|
|
t.Error("expected time")
|
|
}
|
|
}
|
|
|
|
func TestProcessTime(t *testing.T) {
|
|
sec := time.Second
|
|
cfg := &config.NTPClientConfig{
|
|
AllowedDifference: &sec,
|
|
AllowedNegativeDifference: &sec,
|
|
Level: 1,
|
|
Pool: []string{"0.pool.ntp.org:123"},
|
|
}
|
|
m, err := setupNTPManager(cfg, true)
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
err = m.processTime()
|
|
if !errors.Is(err, ErrSubSystemNotStarted) {
|
|
t.Errorf("error '%v', expected '%v'", err, ErrSubSystemNotStarted)
|
|
}
|
|
|
|
err = m.Start()
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
|
|
err = m.processTime()
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
|
|
m.allowedDifference = time.Duration(1)
|
|
m.allowedNegativeDifference = time.Duration(1)
|
|
err = m.processTime()
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("error '%v', expected '%v'", err, nil)
|
|
}
|
|
}
|