| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- // package mock_hand_serve -- мок-обработчик входящих запросов.
- package mock_hand_serve
- import (
- "fmt"
- "sync"
- mKh "gitp78su.ipnodns.ru/svi/kern/v4/lev0/helpers"
- mKa "gitp78su.ipnodns.ru/svi/kern/v4/lev0/kalias"
- mKt "gitp78su.ipnodns.ru/svi/kern/v4/lev0/ktypes"
- mL1 "gitp78su.ipnodns.ru/svi/kern/v4/lev1"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev1/safe_bool"
- )
- // MockHandlerServe -- мок-обработчик входящих запросов.
- type MockHandlerServe struct {
- IsBad_ mKt.ISafeBool // Признак сбоя при вызове
- Msg_ []byte // Для обратного вызова
- Name_ mKa.AHandlerName // Уникальное имя мок-обработчика подписки
- Topic_ mKa.ATopic // Имя топика подписки
- block sync.Mutex
- }
- // NewMockHandlerServe -- возвращает новый обработчик подписки.
- func NewMockHandlerServe(topic mKa.ATopic, name string) *MockHandlerServe {
- mKh.Hassert(topic != "", "NewMockHandlerServe(): topic is empty")
- mKh.Hassert(name != "", "NewMockHandlerServe(): name is empty")
- sf := &MockHandlerServe{
- Topic_: topic,
- Name_: mKa.AHandlerName(name),
- IsBad_: safe_bool.NewSafeBool(),
- }
- _ = mKt.IBusHandlerServe(sf)
- return sf
- }
- // Функция обратного вызова подписки.
- func (sf *MockHandlerServe) FnBack(binMsg []byte) mKt.IResult[[]byte] {
- sf.block.Lock()
- defer sf.block.Unlock()
- if sf.IsBad_.Get() {
- err := fmt.Errorf("FnBack(): isBad==true")
- return mL1.NewErr[[]byte](err)
- }
- sf.Msg_ = binMsg
- return mL1.NewRes(binMsg)
- }
- // Возвращает уникальное имя обработчика подписки.
- func (sf *MockHandlerServe) Topic() mKa.ATopic {
- return sf.Topic_
- }
- // Возвращает топик для обработчика подписки.
- func (sf *MockHandlerServe) Name() mKa.AHandlerName {
- return sf.Name_
- }
|