| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- package kmodule
- import (
- "os"
- "testing"
- "time"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev0/alias"
- . "gitp78su.ipnodns.ru/svi/kern/v4/lev0/ktypes"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev1/mock_env"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kctx"
- )
- type tester struct {
- t *testing.T
- mod IKernelModule
- me *mock_env.MockEnv
- }
- func TestKernelModule(t *testing.T) {
- sf := &tester{
- t: t,
- me: mock_env.MakeEnv(),
- }
- _ = os.Unsetenv("LOCAL_STORE_PATH")
- _ = os.Setenv("LOCAL_STORE_PATH", "/store/store_module")
- _ = os.Unsetenv("LOCAL_HTTP_URL")
- _ = os.Setenv("LOCAL_HTTP_URL", "http://localhost:18331/")
- fnClear := func() {
- pwd := sf.me.Pwd() + "/store/store_module"
- _ = os.RemoveAll(pwd)
- }
- fnClear()
- defer fnClear()
- sf.new()
- sf.run()
- sf.isWork()
- sf.done()
- }
- // Работа после остановки локальной шины.
- func (sf *tester) done() {
- sf.t.Log("done")
- kCtx := kctx.GetKernelCtx().Hassert("done()")
- time.Sleep(time.Millisecond * 250)
- kCtx.Cancel()
- kCtx.Wg().Wait()
- time.Sleep(time.Millisecond * 250)
- }
- // Проверить признак работы.
- func (sf *tester) isWork() {
- sf.t.Log("isWork")
- defer func() {
- if _panic := recover(); _panic == nil {
- sf.t.Fatalf("isWork(): panic==nil")
- }
- }()
- _ = sf.mod.IsWork()
- }
- // Запускает модуль в работу.
- func (sf *tester) run() {
- sf.t.Log("run")
- defer func() {
- if _panic := recover(); _panic == nil {
- sf.t.Fatalf("run(): panic==nil")
- }
- }()
- mod := sf.mod.(*kModule)
- mod.timePhase.Set(5) // Настройка переменной модуля
- sf.mod.Run()
- }
- // Создание нового модуля ядра.
- func (sf *tester) new() {
- sf.t.Log("new")
- sf.newGood1()
- }
- func (sf *tester) newGood1() {
- sf.t.Log("newGood1")
- modName := alias.NewAModuleName("test_module")
- sf.mod = NewKernelModule(modName).Hassert("newGood1()")
- if name := sf.mod.Name(); name.Get() != "test_module" {
- sf.t.Fatalf("newGood1(): name(%v)!='test_module'", name)
- }
- if ctx := sf.mod.Ctx(); ctx == nil {
- sf.t.Fatalf("newGood1(): ctx==nil")
- }
- if _log := sf.mod.Log(); _log == nil {
- sf.t.Fatalf("newGood1(): log==nil")
- }
- _ = sf.mod.Stat()
- _ = sf.mod.Live()
- }
|