mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-16 07:26:47 +00:00
* refactor script manager
* remove singleton GCTScriptConfig
* create constant for ".gct" extension
* move GctScriptManager into vm package
* reduce script manager global dependencies
* use manager struct to store runtime override values
* enable/disable scripting subsystem now doesn't store the setting in
config (aligned with other subsystems)
* setting max VMs via start option doesn't change config
* instantiate scriptmanager as part of creating a new Engine
* script manager config is now set during instantiation
* run script manager when enabled in conf or explicitly enabled
* use the Started() method to check if script manager is running
* in tests set script manager as running
* script manager adjustments
* create manager before attempting overrides
* check for nil config when creating script manager
* fix script manager waitgroup counter increased too late
* move autoload() function to autoload.go
* add tests to script manager
126 lines
2.4 KiB
Go
126 lines
2.4 KiB
Go
package vm
|
|
|
|
import (
|
|
"reflect"
|
|
"sync"
|
|
"testing"
|
|
)
|
|
|
|
func TestNewManager(t *testing.T) {
|
|
t.Parallel()
|
|
type args struct {
|
|
config *Config
|
|
}
|
|
sharedConf := &Config{
|
|
AllowImports: true,
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
args args
|
|
want *GctScriptManager
|
|
wantErr bool
|
|
}{
|
|
{
|
|
name: "nil config gives error",
|
|
wantErr: true,
|
|
},
|
|
{
|
|
name: "config is applied",
|
|
args: args{
|
|
config: sharedConf,
|
|
},
|
|
want: &GctScriptManager{
|
|
config: sharedConf,
|
|
},
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
tt := tt
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
got, err := NewManager(tt.args.config)
|
|
if (err != nil) != tt.wantErr {
|
|
t.Errorf("NewManager() error = %v, wantErr %v", err, tt.wantErr)
|
|
return
|
|
}
|
|
if !reflect.DeepEqual(got, tt.want) {
|
|
t.Errorf("NewManager() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestGctScriptManagerStartStopNominal(t *testing.T) {
|
|
t.Parallel()
|
|
mgr, err := NewManager(&Config{AllowImports: true})
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
var wg sync.WaitGroup
|
|
err = mgr.Start(&wg)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if mgr.started != 1 || mgr.stopped != 0 {
|
|
t.Errorf("Manager should be started (%v, %v)", mgr.started, mgr.stopped)
|
|
}
|
|
err = mgr.Stop()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
wg.Wait()
|
|
if mgr.stopped != 0 {
|
|
t.Errorf("Manager should be stopped, expected=%v, got %v", 0, mgr.stopped)
|
|
}
|
|
}
|
|
|
|
func TestGctScriptManagerGetMaxVirtualMachines(t *testing.T) {
|
|
type fields struct {
|
|
config *Config
|
|
started int32
|
|
stopped int32
|
|
shutdown chan struct{}
|
|
MaxVirtualMachines *uint8
|
|
}
|
|
var value uint8 = 6
|
|
tests := []struct {
|
|
name string
|
|
fields fields
|
|
want uint8
|
|
}{
|
|
{
|
|
name: "get from config",
|
|
fields: fields{
|
|
config: &Config{
|
|
MaxVirtualMachines: 7,
|
|
},
|
|
},
|
|
want: 7,
|
|
},
|
|
{
|
|
name: "get from manager",
|
|
fields: fields{
|
|
config: &Config{
|
|
MaxVirtualMachines: 7,
|
|
},
|
|
MaxVirtualMachines: &value,
|
|
},
|
|
want: 6,
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
tt := tt
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
g := &GctScriptManager{
|
|
config: tt.fields.config,
|
|
started: tt.fields.started,
|
|
stopped: tt.fields.stopped,
|
|
shutdown: tt.fields.shutdown,
|
|
MaxVirtualMachines: tt.fields.MaxVirtualMachines,
|
|
}
|
|
if got := g.GetMaxVirtualMachines(); got != tt.want {
|
|
t.Errorf("GctScriptManager.GetMaxVirtualMachines() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|