Documentation ¶
Index ¶
- Constants
- Variables
- func BoolToUint(v bool) uint8
- func ByteLen(length uint32) uint32
- func GetInsertModeName(mode InsertMode) string
- func GetOpCodeName(op OpCode) string
- func PackBool(w []byte, v bool, mode iproto.PackMode) ([]byte, error)
- func PackDelete(ns uint32, primaryKey [][]byte) []byte
- func PackDeleteFlagsVal(w []byte, ret bool) []byte
- func PackField(w []byte, field []byte) []byte
- func PackFieldNums(w []byte, cnt uint32) []byte
- func PackIndexNum(w []byte, indexnum uint32) []byte
- func PackInsertReplace(ns uint32, insertMode InsertMode, tuple [][]byte) []byte
- func PackKey(w []byte, key [][]byte) []byte
- func PackLimit(w []byte, limit uint32) []byte
- func PackLua(name string, args ...string) []byte
- func PackMockResponse(ome []MockEntities) ([]byte, error)
- func PackOffset(w []byte, offset uint32) []byte
- func PackRequestFlagsVal(w []byte, ret bool, mode InsertMode) []byte
- func PackResopnseStatus(statusCode RetCode, data [][][]byte) ([]byte, error)
- func PackSelect(ns, indexnum, offset, limit uint32, keys [][][]byte) []byte
- func PackSpace(w []byte, space uint32) []byte
- func PackString(w []byte, field string, mode iproto.PackMode) []byte
- func PackTuple(w []byte, keys [][]byte) []byte
- func PackTuples(w []byte, keys [][][]byte) []byte
- func PackUpdate(ns uint32, primaryKey [][]byte, updateOps []Ops) []byte
- func PackedFieldLen(field []byte) uint32
- func PackedKeyLen(keys [][]byte) (length uint32)
- func PackedKeysLen(keys [][]byte) (length uint32)
- func PackedTupleLen(keys [][]byte) (length uint32)
- func PackedTuplesLen(keys [][][]byte) (length uint32)
- func PackedUpdateOpsLen(updateOps []Ops) (length uint32)
- func UintToBool(v uint8) bool
- func UnpackDelete(data []byte) (ns uint32, primaryKey [][]byte, err error)
- func UnpackField(r *bytes.Reader) ([]byte, error)
- func UnpackFieldNums(r *bytes.Reader) (uint32, error)
- func UnpackIndexNum(r *bytes.Reader) (uint32, error)
- func UnpackKey(r *bytes.Reader) ([][]byte, error)
- func UnpackLimit(r *bytes.Reader) (uint32, error)
- func UnpackOffset(r *bytes.Reader) (uint32, error)
- func UnpackResopnseStatus(data []byte) (uint32, []byte, error)
- func UnpackSelect(data []byte) (ns, indexnum, offset, limit uint32, keys [][][]byte, err error)
- func UnpackSpace(r *bytes.Reader) (uint32, error)
- func UnpackString(r *bytes.Reader, res *string, mode iproto.PackMode) error
- func UnpackTuple(r *bytes.Reader) ([][]byte, error)
- func UnpackTuples(r *bytes.Reader) ([][][]byte, error)
- func WrapTriggerWithOnUsePromise(trigger func(types []FixtureType) []FixtureType) (wrappedTrigger func(types []FixtureType) []FixtureType, isUsed func() bool)
- type BaseField
- type BoxMode
- type CheckUsesFixtureType
- type Connection
- type ConnectionOption
- type ConnectionOptions
- type CountFlags
- type DefaultLogger
- func (l *DefaultLogger) Debug(fmt string, args ...any)
- func (l *DefaultLogger) DebugDeleteRequest(ns uint32, primaryKey [][]byte)
- func (l *DefaultLogger) DebugInsertRequest(ns uint32, needRetVal bool, insertMode InsertMode, tuple TupleData)
- func (l *DefaultLogger) DebugSelectRequest(ns uint32, indexnum uint32, offset uint32, limit uint32, keys [][][]byte)
- func (l *DefaultLogger) DebugUpdateRequest(ns uint32, primaryKey [][]byte, updateOps []Ops)
- type FixtureType
- func CreateFixture(id uint32, msg uint8, reqData []byte, respData []byte, ...) FixtureType
- func CreateInsertOrReplaceFixture(entity MockEntities, reqData []byte, trigger func([]FixtureType) []FixtureType) FixtureType
- func CreateSelectFixture(reqData func(mocks []MockEntities) []byte, respEnt []MockEntities) (FixtureType, error)
- func CreateUpdateFixture(reqData []byte, trigger func([]FixtureType) []FixtureType) FixtureType
- type Format
- type InsertMode
- type MockEntities
- type MockServer
- func (oms *MockServer) DebugFixtureNotFound(msg uint8, req []byte)
- func (oms *MockServer) GetServerHostPort() string
- func (oms *MockServer) Handler(ctx context.Context, c iproto.Conn, p iproto.Packet)
- func (oms *MockServer) ProcessRequest(msg uint8, req []byte) ([]byte, bool)
- func (oms *MockServer) SetFixtures(oft []FixtureType)
- func (oms *MockServer) Start() error
- func (oms *MockServer) Stop() error
- type MockServerLogger
- type MockServerOption
- type ModelStruct
- type OpCode
- type Ops
- type RepositoryDebugMeta
- type RequetsTypeType
- type RetCode
- type ServerModeType
- type TupleData
Constants ¶
const ( DefaultTimeout = 20 * time.Millisecond DefaultConnectionTimeout = 20 * time.Millisecond DefaultRedialInterval = 50 * time.Millisecond DefaultPingInterval = 1 * time.Second DefaultPoolSize = 1 )
Константы определяющие дефолтное поведение конектора к octopus-у
const ( SpaceLen uint32 = 4 IndexLen LimitLen OffsetLen FlagsLen FieldNumLen OpsLen OpFieldNumLen OpOpLen = 1 )
const ( RcOK = RetCode(0x0) RcReadOnly = RetCode(0x0401) RcLocked = RetCode(0x0601) RcMemoryIssue = RetCode(0x0701) RcNonMaster = RetCode(0x0102) RcIllegalParams = RetCode(0x0202) RcSecondaryPort = RetCode(0x0301) RcBadIntegrity = RetCode(0x0801) RcUnsupportedCommand = RetCode(0x0a02) RcDuplicate = RetCode(0x2002) RcWrongField = RetCode(0x1e02) RcWrongNumber = RetCode(0x1f02) RcWrongVersion = RetCode(0x2602) RcWalIO = RetCode(0x2702) RcDoesntExists = RetCode(0x3102) RcStoredProcNotDefined = RetCode(0x3202) RcLuaError = RetCode(0x3302) RcTupleExists = RetCode(0x3702) RcDuplicateKey = RetCode(0x3802) )
Variables ¶
var AllFormat = append(append(append( NumericFormat, FloatFormat...), DataFormat...), Bool, )
var DataFormat = []Format{String}
var (
ErrConnection = fmt.Errorf("error dial to box")
)
var FloatFormat = []Format{Float32, Float64}
var NumericFormat = append(UnsignedFormat, Int8, Int16, Int32, Int64, Int)
Functions ¶
func BoolToUint ¶
func GetInsertModeName ¶
func GetInsertModeName(mode InsertMode) string
func GetOpCodeName ¶
func PackDelete ¶
func PackDeleteFlagsVal ¶
func PackFieldNums ¶
func PackIndexNum ¶
func PackInsertReplace ¶
func PackInsertReplace(ns uint32, insertMode InsertMode, tuple [][]byte) []byte
func PackMockResponse ¶
func PackMockResponse(ome []MockEntities) ([]byte, error)
func PackOffset ¶
func PackRequestFlagsVal ¶
func PackRequestFlagsVal(w []byte, ret bool, mode InsertMode) []byte
func PackResopnseStatus ¶
func PackSelect ¶
func PackTuples ¶
func PackedFieldLen ¶
func PackedKeyLen ¶
func PackedKeysLen ¶
func PackedTupleLen ¶
func PackedTuplesLen ¶
func PackedUpdateOpsLen ¶
func UintToBool ¶
func UnpackSelect ¶
func WrapTriggerWithOnUsePromise ¶
func WrapTriggerWithOnUsePromise(trigger func(types []FixtureType) []FixtureType) (wrappedTrigger func(types []FixtureType) []FixtureType, isUsed func() bool)
Types ¶
type BoxMode ¶
type BoxMode uint8
const ( ReplicaMaster BoxMode = iota MasterReplica ReplicaOnly MasterOnly SelectModeDefault = ReplicaMaster )
type CheckUsesFixtureType ¶
type CheckUsesFixtureType uint8
const ( AnyUsesFixtures CheckUsesFixtureType = iota AllFixtureUses AllFixtureUsesOnlyOnce )
Константы для проверки использования фикстур
type Connection ¶
type Connection struct {
// contains filtered or unexported fields
}
func GetConnection ¶
func GetConnection(ctx context.Context, octopusOpts *ConnectionOptions) (*Connection, error)
func (*Connection) Call ¶
func (c *Connection) Call(ctx context.Context, rt RequetsTypeType, data []byte) ([]byte, error)
func (*Connection) Close ¶
func (c *Connection) Close()
func (*Connection) Done ¶
func (c *Connection) Done() <-chan struct{}
func (*Connection) Info ¶
func (c *Connection) Info() string
func (*Connection) InstanceMode ¶
func (c *Connection) InstanceMode() any
type ConnectionOption ¶
type ConnectionOption interface {
// contains filtered or unexported methods
}
ConnectionOption - интерфейс которому должны соответствовать опции передаваемые в конструктор
func WithIntervals ¶
func WithIntervals(redial, maxRedial, ping time.Duration) ConnectionOption
WithIntervals - опция для изменения интервалов
func WithPoolSize ¶
func WithPoolSize(size int) ConnectionOption
WithPoolSize - опция для изменения размера пулла подключений
func WithTimeout ¶
func WithTimeout(request, connection time.Duration) ConnectionOption
WithTimeout - опция для изменений таймаутов
type ConnectionOptions ¶
type ConnectionOptions struct { Mode ServerModeType // contains filtered or unexported fields }
ConnectionOptions - опции используемые для подключения
func NewOptions ¶
func NewOptions(server string, mode ServerModeType, opts ...ConnectionOption) (*ConnectionOptions, error)
NewOptions - cоздание структуры с опциями и дефолтными значениями. Для мидификации значений по умолчанию, надо передавать опции в конструктор
func (*ConnectionOptions) GetConnectionID ¶
func (o *ConnectionOptions) GetConnectionID() string
GetConnectionID - получение ConnecitionID. После первого получения, больше нельзя его модифицировать. Можно только новый Options создать
func (*ConnectionOptions) InstanceMode ¶
func (o *ConnectionOptions) InstanceMode() any
InstanceMode - метод для получения режима аботы инстанса RO или RW
func (*ConnectionOptions) UpdateHash ¶
func (o *ConnectionOptions) UpdateHash(data ...interface{}) error
UpdateHash - функция расчета ConnectionID, необходима для шаринга конектов между моделями.
type DefaultLogger ¶
type DefaultLogger struct {
DebugMeta RepositoryDebugMeta
}
func (*DefaultLogger) Debug ¶
func (l *DefaultLogger) Debug(fmt string, args ...any)
func (*DefaultLogger) DebugDeleteRequest ¶
func (l *DefaultLogger) DebugDeleteRequest(ns uint32, primaryKey [][]byte)
func (*DefaultLogger) DebugInsertRequest ¶
func (l *DefaultLogger) DebugInsertRequest(ns uint32, needRetVal bool, insertMode InsertMode, tuple TupleData)
func (*DefaultLogger) DebugSelectRequest ¶
func (*DefaultLogger) DebugUpdateRequest ¶
func (l *DefaultLogger) DebugUpdateRequest(ns uint32, primaryKey [][]byte, updateOps []Ops)
type FixtureType ¶
type FixtureType struct { // Уникальный идентификатор фикстуры ID uint32 // Msg - задаёт тип запроса (select, insert, delete, update) Msg RequetsTypeType // Байтовое представление запроса Request []byte // Байтовое представление ответа Response []byte // Возвращаемые объекты. Используется в режиме mock RespObjs []MockEntities // Trigger - функция, которая будет выполнена при обработке запроса // в случае если надо проверить insert или delete внутри этой функции // можно модифицировать список фикстур сервера Trigger func([]FixtureType) []FixtureType }
FixtureType - структура определяющая ответ Response для конкретного запроса Request
func CreateFixture ¶
func CreateFixture(id uint32, msg uint8, reqData []byte, respData []byte, trigger func([]FixtureType) []FixtureType) FixtureType
CreateFixture - конструктор фикстур
func CreateInsertOrReplaceFixture ¶
func CreateInsertOrReplaceFixture(entity MockEntities, reqData []byte, trigger func([]FixtureType) []FixtureType) FixtureType
func CreateSelectFixture ¶
func CreateSelectFixture(reqData func(mocks []MockEntities) []byte, respEnt []MockEntities) (FixtureType, error)
CreateSelectFixture - конструктор фикстур для select-а
func CreateUpdateFixture ¶
func CreateUpdateFixture(reqData []byte, trigger func([]FixtureType) []FixtureType) FixtureType
type Format ¶
type Format string
const ( Uint8 Format = "uint8" Uint16 Format = "uint16" Uint32 Format = "uint32" Uint64 Format = "uint64" Uint Format = "uint" Int8 Format = "int8" Int16 Format = "int16" Int32 Format = "int32" Int64 Format = "int64" Int Format = "int" String Format = "string" Bool Format = "bool" Float32 Format = "float32" Float64 Format = "float64" )
type InsertMode ¶
type InsertMode uint8
const ( InsertModeInserOrReplace InsertMode = iota InsertModeInsert InsertModeReplace )
func UnpackInsertReplace ¶
func UnpackRequestFlagsVal ¶
func UnpackRequestFlagsVal(r *bytes.Reader) (bool, InsertMode, error)
type MockEntities ¶
type MockServer ¶
type MockServer struct { // Мьютекс для работы с триггерами sync.Mutex // contains filtered or unexported fields }
func InitMockServer ¶
func InitMockServer(opts ...MockServerOption) (*MockServer, error)
func (*MockServer) DebugFixtureNotFound ¶
func (oms *MockServer) DebugFixtureNotFound(msg uint8, req []byte)
func (*MockServer) GetServerHostPort ¶
func (oms *MockServer) GetServerHostPort() string
func (*MockServer) ProcessRequest ¶
func (oms *MockServer) ProcessRequest(msg uint8, req []byte) ([]byte, bool)
func (*MockServer) SetFixtures ¶
func (oms *MockServer) SetFixtures(oft []FixtureType)
func (*MockServer) Start ¶
func (oms *MockServer) Start() error
func (*MockServer) Stop ¶
func (oms *MockServer) Stop() error
type MockServerLogger ¶
type MockServerLogger interface { Debug(fmt string, args ...any) DebugSelectRequest(ns uint32, indexnum uint32, offset uint32, limit uint32, keys [][][]byte) DebugUpdateRequest(ns uint32, primaryKey [][]byte, updateOps []Ops) DebugInsertRequest(ns uint32, needRetVal bool, insertMode InsertMode, tuple TupleData) DebugDeleteRequest(ns uint32, primaryKey [][]byte) }
type MockServerOption ¶
type MockServerOption interface {
// contains filtered or unexported methods
}
func WithHost ¶
func WithHost(host, port string) MockServerOption
WithHost - опция для изменения сервера в конфиге
func WithLogger ¶
func WithLogger(logger MockServerLogger) MockServerOption
type ModelStruct ¶
type RepositoryDebugMeta ¶
type RepositoryDebugMeta interface { GetSelectDebugInfo(ns uint32, indexnum uint32, offset uint32, limit uint32, keys [][][]byte) string GetUpdateDebugInfo(ns uint32, primaryKey [][]byte, updateOps []Ops) string GetInsertDebugInfo(ns uint32, needRetVal bool, insertMode InsertMode, tuple TupleData) string GetDeleteDebugInfo(ns uint32, primaryKey [][]byte) string }
type RequetsTypeType ¶
type RequetsTypeType uint8
const ( RequestTypeInsert RequetsTypeType = 13 RequestTypeSelect RequetsTypeType = 17 RequestTypeUpdate RequetsTypeType = 19 RequestTypeDelete RequetsTypeType = 21 RequestTypeCall RequetsTypeType = 22 )
type ServerModeType ¶
type ServerModeType uint8
ServerModeType - тип используемый для описания режима работы инстанса. см. ниже
const ( ModeMaster ServerModeType = iota ModeReplica )
Режим работы конкретного инстанса. Мастер или реплика. При селекте из реплики быдет выставляться флаг readonly. Более подробно можно прочитать в доке.
type TupleData ¶
func CallLua ¶
func CallLua(ctx context.Context, connection *Connection, name string, args ...string) ([]TupleData, error)
CallLua - функция для вызова lua процедур. В будущем надо будет сделать возможность декларативно описывать процедуры в модели и в сгенерированном коде вызывать эту функцию. Так же надо будет сделать возможность описывать формат для результата в произвольной форме, а не в форме тупла для мочёдели.
func ProcessResp ¶
func ProcessResp(respBytes []byte, cntFlag CountFlags) ([]TupleData, error)