Skip to content

Commit

Permalink
Super basic argless calls
Browse files Browse the repository at this point in the history
  • Loading branch information
lekko-jonathan committed Sep 26, 2024
1 parent 606b971 commit d1c2715
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 3 deletions.
23 changes: 23 additions & 0 deletions cmd/lekko/sync_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ import (
"testing"

"github.com/lekkodev/cli/pkg/gen"
protoutils "github.com/lekkodev/cli/pkg/proto"
"github.com/lekkodev/cli/pkg/sync"
"google.golang.org/protobuf/encoding/protojson"
"google.golang.org/protobuf/proto"
Expand Down Expand Up @@ -223,3 +224,25 @@ func Test_ProtoJsonToTs(t *testing.T) {
})
}
*/

func Test_blobToTs(t *testing.T) {

Check failure on line 228 in cmd/lekko/sync_test.go

View workflow job for this annotation

GitHub Actions / build

`Test_blobToTs` - `t` is unused (unparam)
repoContents, err := sync.SyncTSOutputToRepositoryContents([]byte("Cp0CCgdkZWZhdWx0EnUKDWJhbm5lci1jb25maWcaYgovCi10eXBlLmdvb2dsZWFwaXMuY29tL2dvb2dsZS5wcm90b2J1Zi5Cb29sVmFsdWUaLwotdHlwZS5nb29nbGVhcGlzLmNvbS9nb29nbGUucHJvdG9idWYuQm9vbFZhbHVlIAESmgEKBXRoaW5nGo4BCkUKMnR5cGUuZ29vZ2xlYXBpcy5jb20vbGVra28ucnVsZXMudjFiZXRhMy5Db25maWdDYWxsEg8aDWJhbm5lci1jb25maWcaRQoydHlwZS5nb29nbGVhcGlzLmNvbS9sZWtrby5ydWxlcy52MWJldGEzLkNvbmZpZ0NhbGwSDxoNYmFubmVyLWNvbmZpZyABEuwLCvsBCh5nb29nbGUvcHJvdG9idWYvZHVyYXRpb24ucHJvdG8SD2dvb2dsZS5wcm90b2J1ZiI6CghEdXJhdGlvbhIYCgdzZWNvbmRzGAEgASgDUgdzZWNvbmRzEhQKBW5hbm9zGAIgASgFUgVuYW5vc0KDAQoTY29tLmdvb2dsZS5wcm90b2J1ZkINRHVyYXRpb25Qcm90b1ABWjFnb29nbGUuZ29sYW5nLm9yZy9wcm90b2J1Zi90eXBlcy9rbm93bi9kdXJhdGlvbnBi+AEBogIDR1BCqgIeR29vZ2xlLlByb3RvYnVmLldlbGxLbm93blR5cGVzYgZwcm90bzMK4gUKHGdvb2dsZS9wcm90b2J1Zi9zdHJ1Y3QucHJvdG8SD2dvb2dsZS5wcm90b2J1ZiKYAQoGU3RydWN0EjsKBmZpZWxkcxgBIAMoCzIjLmdvb2dsZS5wcm90b2J1Zi5TdHJ1Y3QuRmllbGRzRW50cnlSBmZpZWxkcxpRCgtGaWVsZHNFbnRyeRIQCgNrZXkYASABKAlSA2tleRIsCgV2YWx1ZRgCIAEoCzIWLmdvb2dsZS5wcm90b2J1Zi5WYWx1ZVIFdmFsdWU6AjgBIrICCgVWYWx1ZRI7CgpudWxsX3ZhbHVlGAEgASgOMhouZ29vZ2xlLnByb3RvYnVmLk51bGxWYWx1ZUgAUgludWxsVmFsdWUSIwoMbnVtYmVyX3ZhbHVlGAIgASgBSABSC251bWJlclZhbHVlEiMKDHN0cmluZ192YWx1ZRgDIAEoCUgAUgtzdHJpbmdWYWx1ZRIfCgpib29sX3ZhbHVlGAQgASgISABSCWJvb2xWYWx1ZRI8CgxzdHJ1Y3RfdmFsdWUYBSABKAsyFy5nb29nbGUucHJvdG9idWYuU3RydWN0SABSC3N0cnVjdFZhbHVlEjsKCmxpc3RfdmFsdWUYBiABKAsyGi5nb29nbGUucHJvdG9idWYuTGlzdFZhbHVlSABSCWxpc3RWYWx1ZUIGCgRraW5kIjsKCUxpc3RWYWx1ZRIuCgZ2YWx1ZXMYASADKAsyFi5nb29nbGUucHJvdG9idWYuVmFsdWVSBnZhbHVlcyobCglOdWxsVmFsdWUSDgoKTlVMTF9WQUxVRRAAQn8KE2NvbS5nb29nbGUucHJvdG9idWZCC1N0cnVjdFByb3RvUAFaL2dvb2dsZS5nb2xhbmcub3JnL3Byb3RvYnVmL3R5cGVzL2tub3duL3N0cnVjdHBi+AEBogIDR1BCqgIeR29vZ2xlLlByb3RvYnVmLldlbGxLbm93blR5cGVzYgZwcm90bzMKhgQKHmdvb2dsZS9wcm90b2J1Zi93cmFwcGVycy5wcm90bxIPZ29vZ2xlLnByb3RvYnVmIiMKC0RvdWJsZVZhbHVlEhQKBXZhbHVlGAEgASgBUgV2YWx1ZSIiCgpGbG9hdFZhbHVlEhQKBXZhbHVlGAEgASgCUgV2YWx1ZSIiCgpJbnQ2NFZhbHVlEhQKBXZhbHVlGAEgASgDUgV2YWx1ZSIjCgtVSW50NjRWYWx1ZRIUCgV2YWx1ZRgBIAEoBFIFdmFsdWUiIgoKSW50MzJWYWx1ZRIUCgV2YWx1ZRgBIAEoBVIFdmFsdWUiIwoLVUludDMyVmFsdWUSFAoFdmFsdWUYASABKA1SBXZhbHVlIiEKCUJvb2xWYWx1ZRIUCgV2YWx1ZRgBIAEoCFIFdmFsdWUiIwoLU3RyaW5nVmFsdWUSFAoFdmFsdWUYASABKAlSBXZhbHVlIiIKCkJ5dGVzVmFsdWUSFAoFdmFsdWUYASABKAxSBXZhbHVlQoMBChNjb20uZ29vZ2xlLnByb3RvYnVmQg1XcmFwcGVyc1Byb3RvUAFaMWdvb2dsZS5nb2xhbmcub3JnL3Byb3RvYnVmL3R5cGVzL2tub3duL3dyYXBwZXJzcGL4AQGiAgNHUEKqAh5Hb29nbGUuUHJvdG9idWYuV2VsbEtub3duVHlwZXNiBnByb3RvMw=="))
if err != nil {
panic(err)
}

typeRegistry, err := protoutils.FileDescriptorSetToTypeRegistry(repoContents.FileDescriptorSet)
if err != nil {
panic(err)
}
gen.TypeRegistry = typeRegistry
for _, namespace := range repoContents.Namespaces {
for _, f := range namespace.Features {
code, err := gen.GenTSForFeature(f, namespace.Name, "")
if err != nil {
panic(err)
}
fmt.Println(code)
}
}
}
15 changes: 15 additions & 0 deletions pkg/gen/ts.go
Original file line number Diff line number Diff line change
Expand Up @@ -575,6 +575,21 @@ func FieldValueToTS(f protoreflect.FieldDescriptor, val protoreflect.Value) stri
}

func translateRetValueTS(val *anypb.Any, t featurev1beta1.FeatureType) string {
// TODO - move to lekkoAny
if val.TypeUrl == "type.googleapis.com/lekko.rules.v1beta3.ConfigCall" {
call := &rulesv1beta3.ConfigCall{}
err := proto.Unmarshal(val.Value, call)
if err != nil {
panic(err)
}
var funcNameBuilder strings.Builder
funcNameBuilder.WriteString("get")
for _, word := range regexp.MustCompile("[_-]+").Split(call.Key, -1) {
funcNameBuilder.WriteString(strings.ToUpper(word[:1]) + word[1:])
}
funcName := funcNameBuilder.String()
return fmt.Sprintf("%s()", funcName)
}
//var dypb *dynamicpb.Message
marshalOptions := protojson.MarshalOptions{
UseProtoNames: true,
Expand Down
6 changes: 3 additions & 3 deletions pkg/sync/ts.go
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ func SyncTS(lekkoPath string) (*featurev1beta1.RepositoryContents, error) {
if err != nil {
return nil, errors.Wrapf(err, "sync ts: %s", output)
}
return syncTSOutputToRepositoryContents(output)
return SyncTSOutputToRepositoryContents(output)
}

func SyncTSFiles(lekkoFiles ...string) (*featurev1beta1.RepositoryContents, error) {
Expand All @@ -66,11 +66,11 @@ func SyncTSFiles(lekkoFiles ...string) (*featurev1beta1.RepositoryContents, erro
if err != nil {
return nil, errors.Wrapf(err, "sync ts: %s", output)
}
return syncTSOutputToRepositoryContents(output)
return SyncTSOutputToRepositoryContents(output)
}

// Output is expected to be base64 encoded serialized RepositoryContents message
func syncTSOutputToRepositoryContents(output []byte) (*featurev1beta1.RepositoryContents, error) {
func SyncTSOutputToRepositoryContents(output []byte) (*featurev1beta1.RepositoryContents, error) {
// Because Protobuf is not self-describing, we have to jump through some hoops here for deserialization.
// The RepositoryContents message contains the FDS which we want to use as the resolver for unmarshalling
// the rest of the contents.
Expand Down

0 comments on commit d1c2715

Please sign in to comment.