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

Unified Diff: filter/readonly/filter_test.go

Issue 2993033002: [dsreadonly] Add read-only datastore filter. (Closed)
Patch Set: Rename to "readonly" Created 3 years, 4 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
« no previous file with comments | « filter/readonly/filter.go ('k') | filter/readonly/rds.go » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: filter/readonly/filter_test.go
diff --git a/filter/readonly/filter_test.go b/filter/readonly/filter_test.go
new file mode 100644
index 0000000000000000000000000000000000000000..bdd5ba52ec04fbe19cb42b132293d5262de0a264
--- /dev/null
+++ b/filter/readonly/filter_test.go
@@ -0,0 +1,123 @@
+// Copyright 2017 The LUCI Authors.
+//
+// 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 readonly
+
+import (
+ "testing"
+
+ "github.com/luci/gae/impl/memory"
+ ds "github.com/luci/gae/service/datastore"
+
+ "github.com/luci/luci-go/common/errors"
+
+ "golang.org/x/net/context"
+
+ . "github.com/smartystreets/goconvey/convey"
+)
+
+func TestReadOnly(t *testing.T) {
+ t.Parallel()
+
+ Convey("Test datastore filter", t, func() {
+ c := memory.Use(context.Background())
+
+ type Tester struct {
+ ID int `gae:"$id"`
+ Value string
+ }
+
+ // Add a value to the datastore before applying the filter.
+ ds.Put(c, &Tester{ID: 1, Value: "exists"})
+ ds.GetTestable(c).CatchupIndexes()
+
+ // Apply the read-only filter.
+ c = FilterRDS(c)
+ So(c, ShouldNotBeNil)
+
+ Convey("Get works.", func() {
+ v := Tester{ID: 1}
+ So(ds.Get(c, &v), ShouldBeNil)
+ So(v.Value, ShouldEqual, "exists")
+ })
+
+ Convey("Count works.", func() {
+ q := ds.NewQuery("Tester")
+ cnt, err := ds.Count(c, q)
+ So(err, ShouldBeNil)
+ So(cnt, ShouldEqual, 1)
+ })
+
+ Convey("Put fails with read-only error", func() {
+ So(ds.Put(c, &Tester{ID: 2}), ShouldEqual, ErrReadOnly)
+ })
+
+ Convey("Delete fails with read-only error", func() {
+ So(ds.Delete(c, &Tester{ID: 2}), ShouldEqual, ErrReadOnly)
+ })
+
+ Convey("AllocateIDs fails with read-only error", func() {
+ err := ds.AllocateIDs(c, make([]Tester, 10))
+ So(err, ShouldNotBeNil)
+ So(errors.SingleError(err), ShouldEqual, ErrReadOnly)
+ })
+
+ Convey("In a transaction", func() {
+ Convey("Get works.", func() {
+ v := Tester{ID: 1}
+
+ err := ds.RunInTransaction(c, func(c context.Context) error {
+ return ds.Get(c, &v)
+ }, nil)
+ So(err, ShouldBeNil)
+ So(v.Value, ShouldEqual, "exists")
+ })
+
+ Convey("Count works.", func() {
+ // (Need ancestor filter for transaction query)
+ q := ds.NewQuery("Tester").Ancestor(ds.KeyForObj(c, &Tester{ID: 1}))
+
+ var cnt int64
+ err := ds.RunInTransaction(c, func(c context.Context) (err error) {
+ cnt, err = ds.Count(c, q)
+ return
+ }, nil)
+ So(err, ShouldBeNil)
+ So(cnt, ShouldEqual, 1)
+ })
+
+ Convey("Put fails with read-only error", func() {
+ err := ds.RunInTransaction(c, func(c context.Context) error {
+ return ds.Put(c, &Tester{ID: 2})
+ }, nil)
+ So(err, ShouldEqual, ErrReadOnly)
+ })
+
+ Convey("Delete fails with read-only error", func() {
+ err := ds.RunInTransaction(c, func(c context.Context) error {
+ return ds.Delete(c, &Tester{ID: 2})
+ }, nil)
+ So(err, ShouldEqual, ErrReadOnly)
+ })
+
+ Convey("AllocateIDs fails with read-only error", func() {
+ err := ds.RunInTransaction(c, func(c context.Context) error {
+ return ds.AllocateIDs(c, make([]Tester, 10))
+ }, nil)
+ So(err, ShouldNotBeNil)
+ So(errors.SingleError(err), ShouldEqual, ErrReadOnly)
+ })
+ })
+ })
+}
« no previous file with comments | « filter/readonly/filter.go ('k') | filter/readonly/rds.go » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698