mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-26 08:09:00 +00:00 
			
		
		
		
	 f680dd934d
			
		
	
	f680dd934d
	
	
	
		
			
			* chore: rename package errors to zerrors * rename package errors to gerrors * fix error related linting issues * fix zitadel error assertion * fix gosimple linting issues * fix deprecated linting issues * resolve gci linting issues * fix import structure --------- Co-authored-by: Elio Bischof <elio@zitadel.com>
		
			
				
	
	
		
			161 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			161 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package key
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"io"
 | |
| 	"reflect"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 
 | |
| 	"github.com/zitadel/zitadel/internal/crypto"
 | |
| 	"github.com/zitadel/zitadel/internal/zerrors"
 | |
| )
 | |
| 
 | |
| func Test_keysFromArgs(t *testing.T) {
 | |
| 	type args struct {
 | |
| 		args []string
 | |
| 	}
 | |
| 	type res struct {
 | |
| 		keys []*crypto.Key
 | |
| 		err  func(error) bool
 | |
| 	}
 | |
| 	tests := []struct {
 | |
| 		name string
 | |
| 		args args
 | |
| 		res  res
 | |
| 	}{
 | |
| 		{
 | |
| 			"no args",
 | |
| 			args{},
 | |
| 			res{
 | |
| 				keys: []*crypto.Key{},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			"invalid arg",
 | |
| 			args{
 | |
| 				args: []string{"keyID", "value"},
 | |
| 			},
 | |
| 			res{
 | |
| 				err: zerrors.IsInternal,
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			"single arg",
 | |
| 			args{
 | |
| 				args: []string{"keyID=value"},
 | |
| 			},
 | |
| 			res{
 | |
| 				keys: []*crypto.Key{
 | |
| 					{
 | |
| 						ID:    "keyID",
 | |
| 						Value: "value",
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			"multiple args",
 | |
| 			args{
 | |
| 				args: []string{"keyID=value", "keyID2=value2"},
 | |
| 			},
 | |
| 			res{
 | |
| 				keys: []*crypto.Key{
 | |
| 					{
 | |
| 						ID:    "keyID",
 | |
| 						Value: "value",
 | |
| 					},
 | |
| 					{
 | |
| 						ID:    "keyID2",
 | |
| 						Value: "value2",
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.name, func(t *testing.T) {
 | |
| 			got, err := keysFromArgs(tt.args.args)
 | |
| 			if tt.res.err == nil {
 | |
| 				assert.NoError(t, err)
 | |
| 			}
 | |
| 			if tt.res.err != nil && !tt.res.err(err) {
 | |
| 				t.Errorf("got wrong err: %v ", err)
 | |
| 			}
 | |
| 			if !reflect.DeepEqual(got, tt.res.keys) {
 | |
| 				t.Errorf("keysFromArgs() got = %v, want %v", got, tt.res.keys)
 | |
| 			}
 | |
| 		})
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func Test_keysFromYAML(t *testing.T) {
 | |
| 	type args struct {
 | |
| 		file io.Reader
 | |
| 	}
 | |
| 	type res struct {
 | |
| 		keys []*crypto.Key
 | |
| 		err  func(error) bool
 | |
| 	}
 | |
| 	tests := []struct {
 | |
| 		name string
 | |
| 		args args
 | |
| 		res  res
 | |
| 	}{
 | |
| 		{
 | |
| 			"invalid yaml",
 | |
| 			args{
 | |
| 				file: bytes.NewReader([]byte("keyID=ds")),
 | |
| 			},
 | |
| 			res{
 | |
| 				err: zerrors.IsInternal,
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			"single key",
 | |
| 			args{
 | |
| 				file: bytes.NewReader([]byte("keyID: value")),
 | |
| 			},
 | |
| 			res{
 | |
| 				keys: []*crypto.Key{
 | |
| 					{
 | |
| 						ID:    "keyID",
 | |
| 						Value: "value",
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			"multiple keys",
 | |
| 			args{
 | |
| 				file: bytes.NewReader([]byte("keyID: value\nkeyID2: value2")),
 | |
| 			},
 | |
| 			res{
 | |
| 				keys: []*crypto.Key{
 | |
| 					{
 | |
| 						ID:    "keyID",
 | |
| 						Value: "value",
 | |
| 					},
 | |
| 					{
 | |
| 						ID:    "keyID2",
 | |
| 						Value: "value2",
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.name, func(t *testing.T) {
 | |
| 			got, err := keysFromYAML(tt.args.file)
 | |
| 			if tt.res.err == nil {
 | |
| 				assert.NoError(t, err)
 | |
| 			}
 | |
| 			if tt.res.err != nil && !tt.res.err(err) {
 | |
| 				t.Errorf("got wrong err: %v ", err)
 | |
| 			}
 | |
| 			assert.ElementsMatch(t, got, tt.res.keys)
 | |
| 		})
 | |
| 	}
 | |
| }
 |