forked from TrueCloudLab/certificates
Add test for updateAddOrderIDs
This commit is contained in:
parent
31d3bf1cfc
commit
a3028bbc0e
2 changed files with 30 additions and 3 deletions
|
@ -124,10 +124,8 @@ func (db *DB) updateAddOrderIDs(ctx context.Context, accID string, addOids ...st
|
||||||
ordersByAccountMux.Lock()
|
ordersByAccountMux.Lock()
|
||||||
defer ordersByAccountMux.Unlock()
|
defer ordersByAccountMux.Unlock()
|
||||||
|
|
||||||
|
var oldOids []string
|
||||||
b, err := db.db.Get(ordersByAccountIDTable, []byte(accID))
|
b, err := db.db.Get(ordersByAccountIDTable, []byte(accID))
|
||||||
var (
|
|
||||||
oldOids []string
|
|
||||||
)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if !nosql.IsErrNotFound(err) {
|
if !nosql.IsErrNotFound(err) {
|
||||||
return nil, errors.Wrapf(err, "error loading orderIDs for account %s", accID)
|
return nil, errors.Wrapf(err, "error loading orderIDs for account %s", accID)
|
||||||
|
|
|
@ -12,6 +12,7 @@ import (
|
||||||
"github.com/smallstep/certificates/acme"
|
"github.com/smallstep/certificates/acme"
|
||||||
"github.com/smallstep/certificates/db"
|
"github.com/smallstep/certificates/db"
|
||||||
"github.com/smallstep/nosql"
|
"github.com/smallstep/nosql"
|
||||||
|
"github.com/smallstep/nosql/database"
|
||||||
nosqldb "github.com/smallstep/nosql/database"
|
nosqldb "github.com/smallstep/nosql/database"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -710,6 +711,34 @@ func TestDB_updateAddOrderIDs(t *testing.T) {
|
||||||
err: errors.Errorf("error saving orderIDs index for account %s", accID),
|
err: errors.Errorf("error saving orderIDs index for account %s", accID),
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"ok/no-old": func(t *testing.T) test {
|
||||||
|
return test{
|
||||||
|
db: &db.MockNoSQLDB{
|
||||||
|
MGet: func(bucket, key []byte) ([]byte, error) {
|
||||||
|
switch string(bucket) {
|
||||||
|
case string(ordersByAccountIDTable):
|
||||||
|
return nil, database.ErrNotFound
|
||||||
|
default:
|
||||||
|
assert.FatalError(t, errors.Errorf("unexpected bucket %s", string(bucket)))
|
||||||
|
return nil, errors.New("force")
|
||||||
|
}
|
||||||
|
},
|
||||||
|
MCmpAndSwap: func(bucket, key, old, nu []byte) ([]byte, bool, error) {
|
||||||
|
switch string(bucket) {
|
||||||
|
case string(ordersByAccountIDTable):
|
||||||
|
assert.Equals(t, key, []byte(accID))
|
||||||
|
assert.Equals(t, old, nil)
|
||||||
|
assert.Equals(t, nu, nil)
|
||||||
|
return nil, true, nil
|
||||||
|
default:
|
||||||
|
assert.FatalError(t, errors.Errorf("unexpected bucket %s", string(bucket)))
|
||||||
|
return nil, false, errors.New("force")
|
||||||
|
}
|
||||||
|
},
|
||||||
|
},
|
||||||
|
res: []string{},
|
||||||
|
}
|
||||||
|
},
|
||||||
"ok/all-old-not-pending": func(t *testing.T) test {
|
"ok/all-old-not-pending": func(t *testing.T) test {
|
||||||
oldOids := []string{"foo", "bar"}
|
oldOids := []string{"foo", "bar"}
|
||||||
bOldOids, err := json.Marshal(oldOids)
|
bOldOids, err := json.Marshal(oldOids)
|
||||||
|
|
Loading…
Reference in a new issue