* refine comments for cache.go * refine comments for log.go * Update orm.go * refine comments for orm_log.go,types.go * Update utils.go * Update doc.go * Update db.go
		
			
				
	
	
		
			168 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			168 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2020 beego
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| // http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| package mock
 | |
| 
 | |
| import (
 | |
| 	"database/sql"
 | |
| 	"os"
 | |
| 	"path/filepath"
 | |
| 
 | |
| 	_ "github.com/mattn/go-sqlite3"
 | |
| 
 | |
| 	"github.com/beego/beego/v2/client/orm"
 | |
| )
 | |
| 
 | |
| func init() {
 | |
| 	RegisterMockDB("default")
 | |
| }
 | |
| 
 | |
| // RegisterMockDB create an "virtual DB" by using sqllite
 | |
| // you should not
 | |
| func RegisterMockDB(name string) {
 | |
| 	source := filepath.Join(os.TempDir(), name+".db")
 | |
| 	_ = orm.RegisterDataBase(name, "sqlite3", source)
 | |
| }
 | |
| 
 | |
| // MockTable only check table name
 | |
| func MockTable(tableName string, resp ...interface{}) *Mock {
 | |
| 	return NewMock(NewSimpleCondition(tableName, ""), resp, nil)
 | |
| }
 | |
| 
 | |
| // MockMethod only check method name
 | |
| func MockMethod(method string, resp ...interface{}) *Mock {
 | |
| 	return NewMock(NewSimpleCondition("", method), resp, nil)
 | |
| }
 | |
| 
 | |
| // MockRead support orm.Read and orm.ReadWithCtx
 | |
| // cb is used to mock read data from DB
 | |
| func MockRead(tableName string, cb func(data interface{}), err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition(tableName, "ReadWithCtx"), []interface{}{err}, func(inv *orm.Invocation) {
 | |
| 		if cb != nil {
 | |
| 			cb(inv.Args[0])
 | |
| 		}
 | |
| 	})
 | |
| }
 | |
| 
 | |
| // MockReadForUpdateWithCtx support ReadForUpdate and ReadForUpdateWithCtx
 | |
| // cb is used to mock read data from DB
 | |
| func MockReadForUpdateWithCtx(tableName string, cb func(data interface{}), err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition(tableName, "ReadForUpdateWithCtx"),
 | |
| 		[]interface{}{err},
 | |
| 		func(inv *orm.Invocation) {
 | |
| 			cb(inv.Args[0])
 | |
| 		})
 | |
| }
 | |
| 
 | |
| // MockReadOrCreateWithCtx support ReadOrCreate and ReadOrCreateWithCtx
 | |
| // cb is used to mock read data from DB
 | |
| func MockReadOrCreateWithCtx(tableName string,
 | |
| 	cb func(data interface{}),
 | |
| 	insert bool, id int64, err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition(tableName, "ReadOrCreateWithCtx"),
 | |
| 		[]interface{}{insert, id, err},
 | |
| 		func(inv *orm.Invocation) {
 | |
| 			cb(inv.Args[0])
 | |
| 		})
 | |
| }
 | |
| 
 | |
| // MockInsertWithCtx support Insert and InsertWithCtx
 | |
| func MockInsertWithCtx(tableName string, id int64, err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition(tableName, "InsertWithCtx"), []interface{}{id, err}, nil)
 | |
| }
 | |
| 
 | |
| // MockInsertMultiWithCtx support InsertMulti and InsertMultiWithCtx
 | |
| func MockInsertMultiWithCtx(tableName string, cnt int64, err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition(tableName, "InsertMultiWithCtx"), []interface{}{cnt, err}, nil)
 | |
| }
 | |
| 
 | |
| // MockInsertOrUpdateWithCtx support InsertOrUpdate and InsertOrUpdateWithCtx
 | |
| func MockInsertOrUpdateWithCtx(tableName string, id int64, err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition(tableName, "InsertOrUpdateWithCtx"), []interface{}{id, err}, nil)
 | |
| }
 | |
| 
 | |
| // MockUpdateWithCtx support UpdateWithCtx and Update
 | |
| func MockUpdateWithCtx(tableName string, affectedRow int64, err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition(tableName, "UpdateWithCtx"), []interface{}{affectedRow, err}, nil)
 | |
| }
 | |
| 
 | |
| // MockDeleteWithCtx support Delete and DeleteWithCtx
 | |
| func MockDeleteWithCtx(tableName string, affectedRow int64, err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition(tableName, "DeleteWithCtx"), []interface{}{affectedRow, err}, nil)
 | |
| }
 | |
| 
 | |
| // MockQueryM2MWithCtx support QueryM2MWithCtx and QueryM2M
 | |
| // Now you may be need to use golang/mock to generate QueryM2M mock instance
 | |
| // Or use DoNothingQueryM2Mer
 | |
| // for example:
 | |
| // 	post := Post{Id: 4}
 | |
| // 	m2m := Ormer.QueryM2M(&post, "Tags")
 | |
| // when you write test code:
 | |
| // MockQueryM2MWithCtx("post", "Tags", mockM2Mer)
 | |
| // "post" is the table name of model Post structure
 | |
| // TODO provide orm.QueryM2Mer
 | |
| func MockQueryM2MWithCtx(tableName string, name string, res orm.QueryM2Mer) *Mock {
 | |
| 	return NewMock(NewQueryM2MerCondition(tableName, name), []interface{}{res}, nil)
 | |
| }
 | |
| 
 | |
| // MockLoadRelatedWithCtx support LoadRelatedWithCtx and LoadRelated
 | |
| func MockLoadRelatedWithCtx(tableName string, name string, rows int64, err error) *Mock {
 | |
| 	return NewMock(NewQueryM2MerCondition(tableName, name), []interface{}{rows, err}, nil)
 | |
| }
 | |
| 
 | |
| // MockQueryTableWithCtx support QueryTableWithCtx and QueryTable
 | |
| func MockQueryTableWithCtx(tableName string, qs orm.QuerySeter) *Mock {
 | |
| 	return NewMock(NewSimpleCondition(tableName, "QueryTable"), []interface{}{qs}, nil)
 | |
| }
 | |
| 
 | |
| // MockRawWithCtx support RawWithCtx and Raw
 | |
| func MockRawWithCtx(rs orm.RawSeter) *Mock {
 | |
| 	return NewMock(NewSimpleCondition("", "RawWithCtx"), []interface{}{rs}, nil)
 | |
| }
 | |
| 
 | |
| // MockDriver support Driver
 | |
| // func MockDriver(driver orm.Driver) *Mock {
 | |
| // 	return NewMock(NewSimpleCondition("", "Driver"), []interface{}{driver})
 | |
| // }
 | |
| 
 | |
| // MockDBStats support DBStats
 | |
| func MockDBStats(stats *sql.DBStats) *Mock {
 | |
| 	return NewMock(NewSimpleCondition("", "DBStats"), []interface{}{stats}, nil)
 | |
| }
 | |
| 
 | |
| // MockBeginWithCtxAndOpts support Begin, BeginWithCtx, BeginWithOpts, BeginWithCtxAndOpts
 | |
| // func MockBeginWithCtxAndOpts(txOrm *orm.TxOrmer, err error) *Mock {
 | |
| // 	return NewMock(NewSimpleCondition("", "BeginWithCtxAndOpts"), []interface{}{txOrm, err})
 | |
| // }
 | |
| 
 | |
| // MockDoTxWithCtxAndOpts support DoTx, DoTxWithCtx, DoTxWithOpts, DoTxWithCtxAndOpts
 | |
| // func MockDoTxWithCtxAndOpts(txOrm *orm.TxOrmer, err error) *Mock {
 | |
| // 	return MockBeginWithCtxAndOpts(txOrm, err)
 | |
| // }
 | |
| 
 | |
| // MockCommit support Commit
 | |
| func MockCommit(err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition("", "Commit"), []interface{}{err}, nil)
 | |
| }
 | |
| 
 | |
| // MockRollback support Rollback
 | |
| func MockRollback(err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition("", "Rollback"), []interface{}{err}, nil)
 | |
| }
 | |
| 
 | |
| // MockRollbackUnlessCommit support RollbackUnlessCommit
 | |
| func MockRollbackUnlessCommit(err error) *Mock {
 | |
| 	return NewMock(NewSimpleCondition("", "RollbackUnlessCommit"), []interface{}{err}, nil)
 | |
| }
 |