| // Copyright 2015 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 mutate |
| |
| import ( |
| "context" |
| "testing" |
| |
| "go.chromium.org/luci/common/clock/testclock" |
| "go.chromium.org/luci/common/logging/memlogger" |
| dm "go.chromium.org/luci/dm/api/service/v1" |
| "go.chromium.org/luci/dm/appengine/model" |
| "go.chromium.org/luci/gae/impl/memory" |
| ds "go.chromium.org/luci/gae/service/datastore" |
| |
| . "github.com/smartystreets/goconvey/convey" |
| |
| . "go.chromium.org/luci/common/testing/assertions" |
| ) |
| |
| func TestFinishAttempt(t *testing.T) { |
| t.Parallel() |
| |
| Convey("FinishAttempt", t, func() { |
| c := memory.Use(context.Background()) |
| fa := &FinishAttempt{ |
| dm.FinishAttemptReq{ |
| Auth: &dm.Execution_Auth{ |
| Id: dm.NewExecutionID("quest", 1, 1), |
| Token: []byte("exekey"), |
| }, |
| Data: dm.NewJsonResult(`{"result": true}`, testclock.TestTimeUTC), |
| }, |
| } |
| |
| So(fa.Normalize(), ShouldBeNil) |
| |
| Convey("Root", func() { |
| So(fa.Root(c).String(), ShouldEqual, `dev~app::/Attempt,"quest|fffffffe"`) |
| }) |
| |
| Convey("RollForward", func() { |
| a := &model.Attempt{ |
| ID: *fa.Auth.Id.AttemptID(), |
| State: dm.Attempt_EXECUTING, |
| CurExecution: 1, |
| } |
| ak := ds.KeyForObj(c, a) |
| ar := &model.AttemptResult{Attempt: ak} |
| e := &model.Execution{ |
| ID: 1, Attempt: ak, State: dm.Execution_RUNNING, Token: []byte("exekey")} |
| |
| So(ds.Put(c, a, e), ShouldBeNil) |
| |
| Convey("Good", func() { |
| muts, err := fa.RollForward(c) |
| memlogger.MustDumpStdout(c) |
| So(err, ShouldBeNil) |
| So(muts, ShouldBeEmpty) |
| |
| So(ds.Get(c, a, e, ar), ShouldBeNil) |
| So(e.Token, ShouldBeEmpty) |
| So(a.Result.Data.Expiration.AsTime(), ShouldResemble, testclock.TestTimeUTC) |
| So(ar.Data.Object, ShouldResemble, `{"result":true}`) |
| }) |
| |
| Convey("Bad ExecutionKey", func() { |
| fa.Auth.Token = []byte("wat") |
| _, err := fa.RollForward(c) |
| So(err, ShouldBeRPCPermissionDenied, "execution Auth") |
| |
| So(ds.Get(c, a, e), ShouldBeNil) |
| So(e.Token, ShouldNotBeEmpty) |
| So(a.State, ShouldEqual, dm.Attempt_EXECUTING) |
| |
| So(ds.Get(c, ar), ShouldEqual, ds.ErrNoSuchEntity) |
| }) |
| |
| }) |
| }) |
| } |