Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(340)

Unified Diff: go/src/infra/gae/libs/gae/memory/raw_datstore.go

Issue 1242043005: Improve memory implementation of gae to provide the full RawDatastore interface. (Closed) Base URL: https://chromium.googlesource.com/infra/infra.git@port_broken_features
Patch Set: further simplification of CL Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: go/src/infra/gae/libs/gae/memory/raw_datstore.go
diff --git a/go/src/infra/gae/libs/gae/memory/raw_datstore.go b/go/src/infra/gae/libs/gae/memory/raw_datstore.go
index b8ef4ae202aa939da09fbd01817911c37dbfbe73..2cbf1f1fb60e2bcb4e7080e9fdb5c3bf2ad0309b 100644
--- a/go/src/infra/gae/libs/gae/memory/raw_datstore.go
+++ b/go/src/infra/gae/libs/gae/memory/raw_datstore.go
@@ -6,11 +6,9 @@ package memory
import (
"errors"
- "fmt"
"golang.org/x/net/context"
"infra/gae/libs/gae"
- "infra/gae/libs/gae/dummy"
"infra/gae/libs/gae/helper"
)
@@ -22,14 +20,11 @@ func useRDS(c context.Context) context.Context {
return gae.SetRDSFactory(c, func(ic context.Context) gae.RawDatastore {
dsd := cur(ic).Get(memContextDSIdx)
- switch x := dsd.(type) {
- case *dataStoreData:
- return &dsImpl{dummy.RDS(), x, curGID(ic).namespace, ic}
- case *txnDataStoreData:
- return &txnDsImpl{dummy.RDS(), x, curGID(ic).namespace}
- default:
- panic(fmt.Errorf("DS: bad type: %v in context %v", dsd, ic))
+ ns := curGID(ic).namespace
+ if x, ok := dsd.(*dataStoreData); ok {
+ return &dsImpl{x, ns, ic}
}
+ return &txnDsImpl{dsd.(*txnDataStoreData), ns}
})
}
@@ -37,8 +32,6 @@ func useRDS(c context.Context) context.Context {
// dsImpl exists solely to bind the current c to the datastore data.
type dsImpl struct {
- gae.RawDatastore
-
data *dataStoreData
ns string
c context.Context
@@ -46,35 +39,40 @@ type dsImpl struct {
var _ gae.RawDatastore = (*dsImpl)(nil)
+func (d *dsImpl) DecodeKey(encoded string) (gae.DSKey, error) {
+ return helper.NewDSKeyFromEncoded(encoded)
+}
+
func (d *dsImpl) NewKey(kind, stringID string, intID int64, parent gae.DSKey) gae.DSKey {
return helper.NewDSKey(globalAppID, d.ns, kind, stringID, intID, parent)
}
-func (d *dsImpl) Put(key gae.DSKey, pls gae.DSPropertyLoadSaver) (retKey gae.DSKey, err error) {
+func (d *dsImpl) Put(key gae.DSKey, pls gae.DSPropertyLoadSaver) (gae.DSKey, error) {
return d.data.put(d.ns, key, pls)
}
+func (d *dsImpl) PutMulti(keys []gae.DSKey, plss []gae.DSPropertyLoadSaver) ([]gae.DSKey, error) {
+ return d.data.putMulti(d.ns, keys, plss)
+}
+
func (d *dsImpl) Get(key gae.DSKey, pls gae.DSPropertyLoadSaver) error {
return d.data.get(d.ns, key, pls)
}
+func (d *dsImpl) GetMulti(keys []gae.DSKey, plss []gae.DSPropertyLoadSaver) error {
+ return d.data.getMulti(d.ns, keys, plss)
+}
+
func (d *dsImpl) Delete(key gae.DSKey) error {
return d.data.del(d.ns, key)
}
-////////////////////////////////// txnDsImpl ///////////////////////////////////
-
-type txnDsImpl struct {
- gae.RawDatastore
-
- data *txnDataStoreData
- ns string
+func (d *dsImpl) DeleteMulti(keys []gae.DSKey) error {
+ return d.data.delMulti(d.ns, keys)
}
-var _ gae.RawDatastore = (*txnDsImpl)(nil)
-
func (d *dsImpl) NewQuery(kind string) gae.DSQuery {
- return &queryImpl{DSQuery: dummy.QY(), ns: d.ns, kind: kind}
+ return &queryImpl{ns: d.ns, kind: kind}
}
func (d *dsImpl) Run(q gae.DSQuery) gae.RDSIterator {
@@ -85,45 +83,102 @@ func (d *dsImpl) Run(q gae.DSQuery) gae.RDSIterator {
func (d *dsImpl) GetAll(q gae.DSQuery, dst *[]gae.DSPropertyMap) ([]gae.DSKey, error) {
// TODO(riannucci): assert that dst is a slice of structs
- return nil, nil
+ panic("NOT IMPLEMENTED")
}
-func (d *dsImpl) Count(q gae.DSQuery) (ret int, err error) {
- itr := d.Run(q.KeysOnly())
- for _, err = itr.Next(nil); err != nil; _, err = itr.Next(nil) {
- ret++
- }
- if err == gae.ErrDSQueryDone {
- err = nil
- }
- return
+func (d *dsImpl) Count(q gae.DSQuery) (int, error) {
+ return count(d.Run(q.KeysOnly()))
+}
+
+////////////////////////////////// txnDsImpl ///////////////////////////////////
+
+type txnDsImpl struct {
+ data *txnDataStoreData
+ ns string
+}
+
+var _ gae.RawDatastore = (*txnDsImpl)(nil)
+
+func (d *txnDsImpl) DecodeKey(encoded string) (gae.DSKey, error) {
+ return helper.NewDSKeyFromEncoded(encoded)
}
func (d *txnDsImpl) NewKey(kind, stringID string, intID int64, parent gae.DSKey) gae.DSKey {
return helper.NewDSKey(globalAppID, d.ns, kind, stringID, intID, parent)
}
-func (d *txnDsImpl) Put(key gae.DSKey, pls gae.DSPropertyLoadSaver) (gae.DSKey, error) {
- if err := d.data.isBroken(); err != nil {
- return nil, err
- }
- return d.data.put(d.ns, key, pls)
+func (d *txnDsImpl) Put(key gae.DSKey, pls gae.DSPropertyLoadSaver) (retKey gae.DSKey, err error) {
+ err = d.data.run(func() (err error) {
+ retKey, err = d.data.put(d.ns, key, pls)
+ return
+ })
+ return
+}
+
+func (d *txnDsImpl) PutMulti(keys []gae.DSKey, plss []gae.DSPropertyLoadSaver) (retKeys []gae.DSKey, err error) {
+ err = d.data.run(func() (err error) {
+ retKeys, err = d.data.putMulti(d.ns, keys, plss)
+ return
+ })
+ return
}
func (d *txnDsImpl) Get(key gae.DSKey, pls gae.DSPropertyLoadSaver) error {
- if err := d.data.isBroken(); err != nil {
- return err
- }
- return d.data.get(d.ns, key, pls)
+ return d.data.run(func() error {
+ return d.data.get(d.ns, key, pls)
+ })
+}
+
+func (d *txnDsImpl) GetMulti(keys []gae.DSKey, plss []gae.DSPropertyLoadSaver) error {
+ return d.data.run(func() error {
+ return d.data.getMulti(d.ns, keys, plss)
+ })
}
func (d *txnDsImpl) Delete(key gae.DSKey) error {
- if err := d.data.isBroken(); err != nil {
- return err
+ return d.data.run(func() error {
+ return d.data.del(d.ns, key)
+ })
+}
+
+func (d *txnDsImpl) DeleteMulti(keys []gae.DSKey) error {
+ return d.data.run(func() error {
+ return d.data.delMulti(d.ns, keys)
+ })
+}
+
+func (d *txnDsImpl) Run(q gae.DSQuery) gae.RDSIterator {
+ rq := q.(*queryImpl)
+ if rq.ancestor == nil {
+ rq.err = errors.New("memory: queries in transactions only support ancestor queries")
+ return &queryIterImpl{rq}
}
- return d.data.del(d.ns, key)
+ panic("NOT IMPLEMENTED")
}
func (*txnDsImpl) RunInTransaction(func(c context.Context) error, *gae.DSTransactionOptions) error {
return errors.New("datastore: nested transactions are not supported")
}
+
+func (d *txnDsImpl) NewQuery(kind string) gae.DSQuery {
+ return &queryImpl{ns: d.ns, kind: kind}
+}
+
+func (d *txnDsImpl) GetAll(q gae.DSQuery, dst *[]gae.DSPropertyMap) ([]gae.DSKey, error) {
+ // TODO(riannucci): assert that dst is a slice of structs
+ panic("NOT IMPLEMENTED")
+}
+
+func (d *txnDsImpl) Count(q gae.DSQuery) (int, error) {
+ return count(d.Run(q.KeysOnly()))
+}
+
+func count(itr gae.RDSIterator) (ret int, err error) {
+ for _, err = itr.Next(nil); err != nil; _, err = itr.Next(nil) {
+ ret++
+ }
+ if err == gae.ErrDSQueryDone {
+ err = nil
+ }
+ return
+}

Powered by Google App Engine
This is Rietveld 408576698