1
0
mirror of https://github.com/MontFerret/ferret.git synced 2024-12-16 11:37:36 +02:00

rename KEEP -> KEEP_KEYS (#223)

This commit is contained in:
3timeslazy 2019-02-02 05:39:28 +03:00 committed by Tim Voronov
parent fdf3c7c33f
commit 24512715e5
3 changed files with 33 additions and 33 deletions

View File

@ -7,11 +7,11 @@ import (
"github.com/MontFerret/ferret/pkg/runtime/values" "github.com/MontFerret/ferret/pkg/runtime/values"
) )
// Keep returns a new object with only given keys. // KeepKeys returns a new object with only given keys.
// @params src (Object) - source object. // @params src (Object) - source object.
// @params keys (Array Of String OR Strings) - keys that need to be keeped. // @params keys (Array Of String OR Strings) - keys that need to be keeped.
// @returns (Object) - New Object with only given keys. // @returns (Object) - New Object with only given keys.
func Keep(_ context.Context, args ...core.Value) (core.Value, error) { func KeepKeys(_ context.Context, args ...core.Value) (core.Value, error) {
err := core.ValidateArgs(args, 2, core.MaxArgs) err := core.ValidateArgs(args, 2, core.MaxArgs)
if err != nil { if err != nil {

View File

@ -10,37 +10,37 @@ import (
. "github.com/smartystreets/goconvey/convey" . "github.com/smartystreets/goconvey/convey"
) )
func TestKeep(t *testing.T) { func TestKeepKeys(t *testing.T) {
Convey("When not enought arguments)", t, func() { Convey("When not enought arguments)", t, func() {
// there is no object // there is no object
obj, err := objects.Keep(context.Background()) obj, err := objects.KeepKeys(context.Background())
So(err, ShouldBeError) So(err, ShouldBeError)
So(obj, ShouldEqual, values.None) So(obj, ShouldEqual, values.None)
// there are no keys // there are no keys
obj, err = objects.Keep(context.Background(), values.NewObject()) obj, err = objects.KeepKeys(context.Background(), values.NewObject())
So(err, ShouldBeError) So(err, ShouldBeError)
So(obj, ShouldEqual, values.None) So(obj, ShouldEqual, values.None)
}) })
Convey("When first argument isn't object", t, func() { Convey("When first argument isn't object", t, func() {
obj, err := objects.Keep(context.Background(), values.NewInt(0)) obj, err := objects.KeepKeys(context.Background(), values.NewInt(0))
So(err, ShouldBeError) So(err, ShouldBeError)
So(obj, ShouldEqual, values.None) So(obj, ShouldEqual, values.None)
}) })
Convey("When wrong keys arguments", t, func() { Convey("When wrong keys arguments", t, func() {
obj, err := objects.Keep(context.Background(), values.NewObject(), values.NewInt(0)) obj, err := objects.KeepKeys(context.Background(), values.NewObject(), values.NewInt(0))
So(err, ShouldBeError) So(err, ShouldBeError)
So(obj, ShouldEqual, values.None) So(obj, ShouldEqual, values.None)
// looks like a valid case // looks like a valid case
// but there is another argument besides an array // but there is another argument besides an array
obj, err = objects.Keep(context.Background(), values.NewObject(), values.NewArray(0), values.NewInt(0)) obj, err = objects.KeepKeys(context.Background(), values.NewObject(), values.NewArray(0), values.NewInt(0))
So(err, ShouldBeError) So(err, ShouldBeError)
So(obj, ShouldEqual, values.None) So(obj, ShouldEqual, values.None)
@ -55,18 +55,18 @@ func TestKeep(t *testing.T) {
values.NewObjectProperty("a", values.NewArrayWith(values.Int(0))), values.NewObjectProperty("a", values.NewArrayWith(values.Int(0))),
) )
afterKeep, err := objects.Keep(context.Background(), obj, values.NewString("a")) afterKeepKeys, err := objects.KeepKeys(context.Background(), obj, values.NewString("a"))
So(err, ShouldBeNil) So(err, ShouldBeNil)
arr.Push(values.NewInt(1)) arr.Push(values.NewInt(1))
So(afterKeep.Compare(resultObj), ShouldEqual, 0) So(afterKeepKeys.Compare(resultObj), ShouldEqual, 0)
}) })
} }
func TestKeepStrings(t *testing.T) { func TestKeepKeysStrings(t *testing.T) {
Convey("Keep key 'a'", t, func() { Convey("KeepKeys key 'a'", t, func() {
obj := values.NewObjectWith( obj := values.NewObjectWith(
values.NewObjectProperty("a", values.NewInt(1)), values.NewObjectProperty("a", values.NewInt(1)),
values.NewObjectProperty("b", values.NewString("string")), values.NewObjectProperty("b", values.NewString("string")),
@ -75,26 +75,26 @@ func TestKeepStrings(t *testing.T) {
values.NewObjectProperty("a", values.NewInt(1)), values.NewObjectProperty("a", values.NewInt(1)),
) )
afterKeep, err := objects.Keep(context.Background(), obj, values.NewString("a")) afterKeepKeys, err := objects.KeepKeys(context.Background(), obj, values.NewString("a"))
So(err, ShouldEqual, nil) So(err, ShouldEqual, nil)
So(afterKeep.Compare(resultObj), ShouldEqual, 0) So(afterKeepKeys.Compare(resultObj), ShouldEqual, 0)
}) })
Convey("Keep key doesn't exists", t, func() { Convey("KeepKeys key doesn't exists", t, func() {
obj := values.NewObjectWith( obj := values.NewObjectWith(
values.NewObjectProperty("a", values.NewInt(1)), values.NewObjectProperty("a", values.NewInt(1)),
values.NewObjectProperty("b", values.NewString("string")), values.NewObjectProperty("b", values.NewString("string")),
) )
resultObj := values.NewObject() resultObj := values.NewObject()
afterKeep, err := objects.Keep(context.Background(), obj, values.NewString("c")) afterKeepKeys, err := objects.KeepKeys(context.Background(), obj, values.NewString("c"))
So(err, ShouldEqual, nil) So(err, ShouldEqual, nil)
So(isEqualObjects(afterKeep.(*values.Object), resultObj), ShouldEqual, true) So(isEqualObjects(afterKeepKeys.(*values.Object), resultObj), ShouldEqual, true)
}) })
Convey("Keep when there are more keys than object properties", t, func() { Convey("KeepKeys when there are more keys than object properties", t, func() {
obj := values.NewObjectWith( obj := values.NewObjectWith(
values.NewObjectProperty("a", values.NewInt(1)), values.NewObjectProperty("a", values.NewInt(1)),
values.NewObjectProperty("b", values.NewString("string")), values.NewObjectProperty("b", values.NewString("string")),
@ -104,17 +104,17 @@ func TestKeepStrings(t *testing.T) {
values.NewObjectProperty("b", values.NewString("string")), values.NewObjectProperty("b", values.NewString("string")),
) )
afterKeep, err := objects.Keep(context.Background(), obj, afterKeepKeys, err := objects.KeepKeys(context.Background(), obj,
values.NewString("a"), values.NewString("b"), values.NewString("c"), values.NewString("a"), values.NewString("b"), values.NewString("c"),
) )
So(err, ShouldEqual, nil) So(err, ShouldEqual, nil)
So(isEqualObjects(afterKeep.(*values.Object), resultObj), ShouldEqual, true) So(isEqualObjects(afterKeepKeys.(*values.Object), resultObj), ShouldEqual, true)
}) })
} }
func TestKeepArray(t *testing.T) { func TestKeepKeysArray(t *testing.T) {
Convey("Keep array", t, func() { Convey("KeepKeys array", t, func() {
obj := values.NewObjectWith( obj := values.NewObjectWith(
values.NewObjectProperty("a", values.NewInt(1)), values.NewObjectProperty("a", values.NewInt(1)),
values.NewObjectProperty("b", values.NewString("string")), values.NewObjectProperty("b", values.NewString("string")),
@ -124,13 +124,13 @@ func TestKeepArray(t *testing.T) {
values.NewObjectProperty("a", values.NewInt(1)), values.NewObjectProperty("a", values.NewInt(1)),
) )
afterKeep, err := objects.Keep(context.Background(), obj, keys) afterKeepKeys, err := objects.KeepKeys(context.Background(), obj, keys)
So(err, ShouldEqual, nil) So(err, ShouldEqual, nil)
So(isEqualObjects(afterKeep.(*values.Object), resultObj), ShouldEqual, true) So(isEqualObjects(afterKeepKeys.(*values.Object), resultObj), ShouldEqual, true)
}) })
Convey("Keep empty array", t, func() { Convey("KeepKeys empty array", t, func() {
obj := values.NewObjectWith( obj := values.NewObjectWith(
values.NewObjectProperty("a", values.NewInt(1)), values.NewObjectProperty("a", values.NewInt(1)),
values.NewObjectProperty("b", values.NewString("string")), values.NewObjectProperty("b", values.NewString("string")),
@ -138,13 +138,13 @@ func TestKeepArray(t *testing.T) {
keys := values.NewArray(0) keys := values.NewArray(0)
resultObj := values.NewObject() resultObj := values.NewObject()
afterKeep, err := objects.Keep(context.Background(), obj, keys) afterKeepKeys, err := objects.KeepKeys(context.Background(), obj, keys)
So(err, ShouldEqual, nil) So(err, ShouldEqual, nil)
So(isEqualObjects(afterKeep.(*values.Object), resultObj), ShouldEqual, true) So(isEqualObjects(afterKeepKeys.(*values.Object), resultObj), ShouldEqual, true)
}) })
Convey("Keep when there are more keys than object properties", t, func() { Convey("KeepKeys when there are more keys than object properties", t, func() {
obj := values.NewObjectWith( obj := values.NewObjectWith(
values.NewObjectProperty("a", values.NewInt(1)), values.NewObjectProperty("a", values.NewInt(1)),
values.NewObjectProperty("b", values.NewString("string")), values.NewObjectProperty("b", values.NewString("string")),
@ -157,10 +157,10 @@ func TestKeepArray(t *testing.T) {
values.NewObjectProperty("b", values.NewString("string")), values.NewObjectProperty("b", values.NewString("string")),
) )
afterKeep, err := objects.Keep(context.Background(), obj, keys) afterKeepKeys, err := objects.KeepKeys(context.Background(), obj, keys)
So(err, ShouldEqual, nil) So(err, ShouldEqual, nil)
So(isEqualObjects(afterKeep.(*values.Object), resultObj), ShouldEqual, true) So(isEqualObjects(afterKeepKeys.(*values.Object), resultObj), ShouldEqual, true)
}) })
Convey("When there is not string key", t, func() { Convey("When there is not string key", t, func() {
@ -173,10 +173,10 @@ func TestKeepArray(t *testing.T) {
values.NewInt(0), values.NewInt(0),
) )
afterKeep, err := objects.Keep(context.Background(), obj, keys) afterKeepKeys, err := objects.KeepKeys(context.Background(), obj, keys)
So(err, ShouldBeError) So(err, ShouldBeError)
So(afterKeep, ShouldEqual, values.None) So(afterKeepKeys, ShouldEqual, values.None)
}) })
} }

View File

@ -6,7 +6,7 @@ func NewLib() map[string]core.Function {
return map[string]core.Function{ return map[string]core.Function{
"HAS": Has, "HAS": Has,
"KEYS": Keys, "KEYS": Keys,
"KEEP": Keep, "KEEP_KEYS": KeepKeys,
"MERGE": Merge, "MERGE": Merge,
"ZIP": Zip, "ZIP": Zip,
"VALUES": Values, "VALUES": Values,