我目前正在编写一个正在写入 QLDB 分类帐的应用程序。我有一个类似的功能:
// Use an interface that matches the QLDB Driver so we can inject / mock
type ILedgerDriver interface {
Execute(ctx context.Context, fn func(txn qldbdriver.Transaction) (interface{}, error)) (interface{}, error)
Shutdown(ctx context.Context)
}
// Create checks for a records existence before inserting on to the ledger.
func Create(driver ILedgerDriver, document interface{}) (interface{}, error) {
return ls.Driver.Execute(context.Background(), func(txn qldbdriver.Transaction) (interface{}, error) {
result, err := txn.Execute("SELECT * FROM People WHERE ID = ?", id)
if err != nil {
return nil, errors.Wrap(err, "error selecting document")
}
// Check if there are any results
if result.Next(txn) {
// document exists
return nil, nil
}
result, err = txn.Execute("INSERT INTO People ?", document)
if err != nil {
return nil, errors.Wrap(err, "error inserting document")
}
return result, nil
})
}
然后我尝试用这样的东西来模拟:
// implements qldbdriver.Transaction.
type mockQldbTx struct{}
func (mockQldbTx) Execute(statement string, parameters ...interface{}) (*qldbdriver.Result, error) {
for _, p := range parameters {
if ps, _ := p.(string); ps == "ERROR" {
return nil, errors.New("execute failed")
}
if ps, _ := p.(string); ps == "WILLFINDME" {
emptyResult := &qldbdriver.Result{}
return emptyResult, nil
}
}
return nil, nil
}
func (mockQldbTx) BufferResult(result *qldbdriver.Result) (*qldbdriver.BufferedResult, error) {
return nil, nil
}
func (mockQldbTx) Abort() error {
return nil
}
// implements ILedgerDriver
type mockDriver struct{}
func (mockDriver) Execute(ctx context.Context, fn func(txn qldbdriver.Transaction) (interface{}, error)) (interface{}, error) {
mockTx1 := mockQldbTx{}
result, err := fn(mockTx1)
return result, err
}
func (mockDriver) Shutdown(ctx context.Context) {
}
这在很大程度上有效。但是,由于qldbdriver.Result
不是接口,因此我似乎无法模拟事务来测试结果何时具有index
和pageValues
属性(这将触发if result.Next(txn)
块)的情况。
任何人都有这方面的经验或可以指出任何指南?还是我真的有点过于谨慎了,我真的不需要测试我的 create 函数是否有效?(除此之外的任何其他更大的业务逻辑都在另一个可以单独测试的函数中?)