Documentation ¶
Index ¶
- Constants
- Variables
- func NewFakeResult(insertID int64, rowsAffected int64) driver.Result
- type Exceptions
- type FakeConn
- func (c *FakeConn) Begin() (driver.Tx, error)
- func (c *FakeConn) Close() (err error)
- func (c *FakeConn) Exec(query string, args []driver.Value) (driver.Result, error)
- func (c *FakeConn) ExecContext(ctx context.Context, query string, args []driver.NamedValue) (driver.Result, error)
- func (c *FakeConn) Prepare(query string) (driver.Stmt, error)
- func (c *FakeConn) PrepareContext(ctx context.Context, query string) (driver.Stmt, error)
- func (c *FakeConn) Query(query string, args []driver.Value) (driver.Rows, error)
- func (c *FakeConn) QueryContext(ctx context.Context, query string, args []driver.NamedValue) (driver.Rows, error)
- type FakeDB
- type FakeDriver
- type FakeResponse
- func (fr *FakeResponse) IsMatch(query string, args []driver.NamedValue) bool
- func (fr *FakeResponse) MarkAsTriggered()
- func (fr *FakeResponse) OneTime() *FakeResponse
- func (fr *FakeResponse) WithArgs(vars ...interface{}) *FakeResponse
- func (fr *FakeResponse) WithCallback(f func(string, []driver.NamedValue)) *FakeResponse
- func (fr *FakeResponse) WithError(err error) *FakeResponse
- func (fr *FakeResponse) WithExecException() *FakeResponse
- func (fr *FakeResponse) WithID(id int64) *FakeResponse
- func (fr *FakeResponse) WithQuery(query string) *FakeResponse
- func (fr *FakeResponse) WithQueryException() *FakeResponse
- func (fr *FakeResponse) WithReply(response []map[string]interface{}) *FakeResponse
- func (fr *FakeResponse) WithRowsNum(num int64) *FakeResponse
- type FakeResult
- type FakeStmt
- func (s *FakeStmt) Close() error
- func (s *FakeStmt) ColumnConverter(idx int) driver.ValueConverter
- func (s *FakeStmt) Exec(args []driver.Value) (driver.Result, error)deprecated
- func (s *FakeStmt) ExecContext(ctx context.Context, args []driver.NamedValue) (driver.Result, error)
- func (s *FakeStmt) NumInput() int
- func (s *FakeStmt) Query(args []driver.Value) (driver.Rows, error)deprecated
- func (s *FakeStmt) QueryContext(ctx context.Context, args []driver.NamedValue) (driver.Rows, error)
- type FakeTx
- type MockCatcher
- type RowsCursor
Constants ¶
const (
// DriverName is the name of the fake driver
DriverName = "MOCK_FAKE_DRIVER"
)
Variables ¶
var HookBadCommit func() bool
HookBadCommit is a hook to simulate broken connections
var HookBadRollback func() bool
HookBadRollback is a hook to simulate broken connections
Functions ¶
Types ¶
type Exceptions ¶
Exceptions represents possible exceptions during query executions
type FakeConn ¶
type FakeConn struct {
// contains filtered or unexported fields
}
FakeConn implements connection
func (*FakeConn) ExecContext ¶
func (c *FakeConn) ExecContext(ctx context.Context, query string, args []driver.NamedValue) (driver.Result, error)
ExecContext is optional to implement and it returns skip
func (*FakeConn) PrepareContext ¶
PrepareContext returns a prepared statement, bound to this connection. context is for the preparation of the statement, it must not store the context within the statement itself.
type FakeDB ¶
type FakeDB struct {
// contains filtered or unexported fields
}
FakeDB represents the database
type FakeDriver ¶
type FakeDriver struct {
// contains filtered or unexported fields
}
FakeDriver implements driver interface in sql package
type FakeResponse ¶
type FakeResponse struct { Pattern string // SQL query pattern to match with Args []interface{} // List args to be matched with Response []map[string]interface{} // Array of rows to be parsed as result Once bool // To trigger only once Triggered bool // If it was triggered at least once Callback func(string, []driver.NamedValue) // Callback to execute when response triggered RowsAffected int64 // Defines affected rows count LastInsertID int64 // ID to be returned for INSERT queries Error error // Any type of error which could happen dur *Exceptions }
FakeResponse represents mock of response with holding all required values to return mocked response
func (*FakeResponse) IsMatch ¶
func (fr *FakeResponse) IsMatch(query string, args []driver.NamedValue) bool
IsMatch checks if both query and args matcher's return true and if this is Once mock
func (*FakeResponse) MarkAsTriggered ¶
func (fr *FakeResponse) MarkAsTriggered()
MarkAsTriggered marks response as executed. For one time catches it will not make this possible to execute anymore
func (*FakeResponse) OneTime ¶
func (fr *FakeResponse) OneTime() *FakeResponse
OneTime sets current mock to be triggered only once
func (*FakeResponse) WithArgs ¶
func (fr *FakeResponse) WithArgs(vars ...interface{}) *FakeResponse
WithArgs attaches Args check for prepared statements
func (*FakeResponse) WithCallback ¶
func (fr *FakeResponse) WithCallback(f func(string, []driver.NamedValue)) *FakeResponse
WithCallback adds callback to be executed during matching
func (*FakeResponse) WithError ¶ added in v1.0.3
func (fr *FakeResponse) WithError(err error) *FakeResponse
WithError sets Error to FakeResponse struct to have it available on any statements executed example: WithError(sql.ErrNoRows)
func (*FakeResponse) WithExecException ¶
func (fr *FakeResponse) WithExecException() *FakeResponse
WithExecException says that if mock attached to non-SELECT query we need to trigger error there
func (*FakeResponse) WithID ¶ added in v1.0.6
func (fr *FakeResponse) WithID(id int64) *FakeResponse
WithID sets ID to be considered as insert ID for INSERT statements
func (*FakeResponse) WithQuery ¶
func (fr *FakeResponse) WithQuery(query string) *FakeResponse
WithQuery adds SQL query pattern to match for
func (*FakeResponse) WithQueryException ¶
func (fr *FakeResponse) WithQueryException() *FakeResponse
WithQueryException adds to SELECT mocks triggering of error
func (*FakeResponse) WithReply ¶
func (fr *FakeResponse) WithReply(response []map[string]interface{}) *FakeResponse
WithReply adds to chain and assign some parts of response
func (*FakeResponse) WithRowsNum ¶
func (fr *FakeResponse) WithRowsNum(num int64) *FakeResponse
WithRowsNum specifies how many records to consider as affected
type FakeResult ¶
type FakeResult struct {
// contains filtered or unexported fields
}
FakeResult implementation of sql Result interface
func (*FakeResult) LastInsertId ¶
func (fr *FakeResult) LastInsertId() (int64, error)
LastInsertId required to give sql package ability get ID of inserted record
func (*FakeResult) RowsAffected ¶
func (fr *FakeResult) RowsAffected() (int64, error)
RowsAffected returns the number of rows affected
type FakeStmt ¶
type FakeStmt struct {
// contains filtered or unexported fields
}
FakeStmt is implementation of Stmt sql interfcae
func (*FakeStmt) ColumnConverter ¶
func (s *FakeStmt) ColumnConverter(idx int) driver.ValueConverter
ColumnConverter returns a ValueConverter for the provided column index.
func (*FakeStmt) ExecContext ¶
func (s *FakeStmt) ExecContext(ctx context.Context, args []driver.NamedValue) (driver.Result, error)
ExecContext executes a query that doesn't return rows, such as an INSERT or UPDATE.
func (*FakeStmt) QueryContext ¶
QueryContext executes a query that may return rows, such as a SELECT.
type FakeTx ¶
type FakeTx struct {
// contains filtered or unexported fields
}
FakeTx implements Tx interface
type MockCatcher ¶
type MockCatcher struct { Mocks []*FakeResponse // Slice of all mocks Logging bool // Do we need to log what we catching? PanicOnEmptyResponse bool // If not response matches - do we need to panic? }
MockCatcher is global entity to save all mocks aka FakeResponses
var Catcher *MockCatcher
Catcher is global instance of Catcher used for attaching all mocks to connection
func (*MockCatcher) Attach ¶
func (mc *MockCatcher) Attach(fr []*FakeResponse)
Attach several mocks to MockCather. Could be useful to attach mocks from some factories of mocks
func (*MockCatcher) FindResponse ¶
func (mc *MockCatcher) FindResponse(query string, args []driver.NamedValue) *FakeResponse
FindResponse finds suitable response by provided
func (*MockCatcher) NewMock ¶
func (mc *MockCatcher) NewMock() *FakeResponse
NewMock creates new FakeResponse and return for chains of attachments
func (*MockCatcher) Register ¶ added in v1.0.1
func (mc *MockCatcher) Register()
Register safely register FakeDriver
func (*MockCatcher) Reset ¶
func (mc *MockCatcher) Reset() *MockCatcher
Reset removes all Mocks to start process again
type RowsCursor ¶
type RowsCursor struct {
// contains filtered or unexported fields
}
RowsCursor is implementation of Rows sql interface
func (*RowsCursor) ColumnTypeScanType ¶
func (rc *RowsCursor) ColumnTypeScanType(index int) reflect.Type
ColumnTypeScanType may be implemented by Rows. It should return the value type that can be used to scan types into.
func (*RowsCursor) Columns ¶
func (rc *RowsCursor) Columns() []string
Columns returns the names of the columns.
func (*RowsCursor) HasNextResultSet ¶
func (rc *RowsCursor) HasNextResultSet() bool
HasNextResultSet is called at the end of the current result set and reports whether there is another result set after the current one.
func (*RowsCursor) Next ¶
func (rc *RowsCursor) Next(accumulator []driver.Value) error
Next is called to populate the next row of data into the provided slice.
func (*RowsCursor) NextResultSet ¶
func (rc *RowsCursor) NextResultSet() error
NextResultSet advances the driver to the next result set even if there are remaining rows in the current result set.