mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-25 12:39:35 +00:00 
			
		
		
		
	 2f91679623
			
		
	
	2f91679623
	
	
	
		
			
			This change adds a core_generate_all make target. It installs the required tools and runs generate on the complete project. `golang/mock` is no longer maintained and a fork is available from the Uber folks. So the latter is used as tool. All the mock files have been regenerated and are part of the PR. The obsolete `tools` directory has been removed, as all the tools are now part of specific make targets. Co-authored-by: Silvan <silvan.reusser@gmail.com>
		
			
				
	
	
		
			307 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			307 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package crypto
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	"go.uber.org/mock/gomock"
 | |
| )
 | |
| 
 | |
| func TestIsCodeExpired(t *testing.T) {
 | |
| 	type args struct {
 | |
| 		creationDate time.Time
 | |
| 		expiry       time.Duration
 | |
| 	}
 | |
| 	tests := []struct {
 | |
| 		name string
 | |
| 		args args
 | |
| 		want bool
 | |
| 	}{
 | |
| 		{
 | |
| 			"not expired",
 | |
| 			args{
 | |
| 				creationDate: time.Now(),
 | |
| 				expiry:       time.Duration(5 * time.Minute),
 | |
| 			},
 | |
| 			false,
 | |
| 		},
 | |
| 		{
 | |
| 			"never expires",
 | |
| 			args{
 | |
| 				creationDate: time.Now().Add(-5 * time.Minute),
 | |
| 				expiry:       0,
 | |
| 			},
 | |
| 			false,
 | |
| 		},
 | |
| 		{
 | |
| 			"expired",
 | |
| 			args{
 | |
| 				creationDate: time.Now().Add(-5 * time.Minute),
 | |
| 				expiry:       time.Duration(5 * time.Minute),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 	}
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.name, func(t *testing.T) {
 | |
| 			if got := IsCodeExpired(tt.args.creationDate, tt.args.expiry); got != tt.want {
 | |
| 				t.Errorf("IsCodeExpired() = %v, want %v", got, tt.want)
 | |
| 			}
 | |
| 		})
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestVerifyCode(t *testing.T) {
 | |
| 	type args struct {
 | |
| 		creationDate     time.Time
 | |
| 		expiry           time.Duration
 | |
| 		cryptoCode       *CryptoValue
 | |
| 		verificationCode string
 | |
| 		g                Generator
 | |
| 	}
 | |
| 	tests := []struct {
 | |
| 		name    string
 | |
| 		args    args
 | |
| 		wantErr bool
 | |
| 	}{
 | |
| 		{
 | |
| 			"expired",
 | |
| 			args{
 | |
| 				creationDate:     time.Now().Add(-5 * time.Minute),
 | |
| 				expiry:           5 * time.Minute,
 | |
| 				cryptoCode:       nil,
 | |
| 				verificationCode: "",
 | |
| 				g:                createMockGenerator(t, createMockCrypto(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"unsupported alg err",
 | |
| 			args{
 | |
| 				creationDate:     time.Now(),
 | |
| 				expiry:           5 * time.Minute,
 | |
| 				cryptoCode:       nil,
 | |
| 				verificationCode: "code",
 | |
| 				g:                createMockGenerator(t, createMockCrypto(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"encryption alg ok",
 | |
| 			args{
 | |
| 				creationDate: time.Now(),
 | |
| 				expiry:       5 * time.Minute,
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeEncryption,
 | |
| 					Algorithm:  "enc",
 | |
| 					KeyID:      "id",
 | |
| 					Crypted:    []byte("code"),
 | |
| 				},
 | |
| 				verificationCode: "code",
 | |
| 				g:                createMockGenerator(t, CreateMockEncryptionAlg(gomock.NewController(t))),
 | |
| 			},
 | |
| 			false,
 | |
| 		},
 | |
| 		{
 | |
| 			"hash alg ok",
 | |
| 			args{
 | |
| 				creationDate: time.Now(),
 | |
| 				expiry:       5 * time.Minute,
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeHash,
 | |
| 					Algorithm:  "hash",
 | |
| 					Crypted:    []byte("code"),
 | |
| 				},
 | |
| 				verificationCode: "code",
 | |
| 				g:                createMockGenerator(t, CreateMockHashAlg(gomock.NewController(t))),
 | |
| 			},
 | |
| 			false,
 | |
| 		},
 | |
| 	}
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.name, func(t *testing.T) {
 | |
| 			if err := VerifyCode(tt.args.creationDate, tt.args.expiry, tt.args.cryptoCode, tt.args.verificationCode, tt.args.g); (err != nil) != tt.wantErr {
 | |
| 				t.Errorf("VerifyCode() error = %v, wantErr %v", err, tt.wantErr)
 | |
| 			}
 | |
| 		})
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func Test_verifyEncryptedCode(t *testing.T) {
 | |
| 	type args struct {
 | |
| 		cryptoCode       *CryptoValue
 | |
| 		verificationCode string
 | |
| 		alg              EncryptionAlgorithm
 | |
| 	}
 | |
| 	tests := []struct {
 | |
| 		name    string
 | |
| 		args    args
 | |
| 		wantErr bool
 | |
| 	}{
 | |
| 		{
 | |
| 			"nil error",
 | |
| 			args{
 | |
| 				cryptoCode:       nil,
 | |
| 				verificationCode: "",
 | |
| 				alg:              CreateMockEncryptionAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"wrong cryptotype error",
 | |
| 			args{
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeHash,
 | |
| 					Crypted:    nil,
 | |
| 				},
 | |
| 				verificationCode: "",
 | |
| 				alg:              CreateMockEncryptionAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"wrong algorithm error",
 | |
| 			args{
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeEncryption,
 | |
| 					Algorithm:  "enc2",
 | |
| 					Crypted:    nil,
 | |
| 				},
 | |
| 				verificationCode: "",
 | |
| 				alg:              CreateMockEncryptionAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"wrong key id error",
 | |
| 			args{
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeEncryption,
 | |
| 					Algorithm:  "enc",
 | |
| 					Crypted:    nil,
 | |
| 				},
 | |
| 				verificationCode: "wrong",
 | |
| 				alg:              CreateMockEncryptionAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"wrong verification code error",
 | |
| 			args{
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeEncryption,
 | |
| 					Algorithm:  "enc",
 | |
| 					KeyID:      "id",
 | |
| 					Crypted:    []byte("code"),
 | |
| 				},
 | |
| 				verificationCode: "wrong",
 | |
| 				alg:              CreateMockEncryptionAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"verification code ok",
 | |
| 			args{
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeEncryption,
 | |
| 					Algorithm:  "enc",
 | |
| 					KeyID:      "id",
 | |
| 					Crypted:    []byte("code"),
 | |
| 				},
 | |
| 				verificationCode: "code",
 | |
| 				alg:              CreateMockEncryptionAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			false,
 | |
| 		},
 | |
| 	}
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.name, func(t *testing.T) {
 | |
| 			if err := verifyEncryptedCode(tt.args.cryptoCode, tt.args.verificationCode, tt.args.alg); (err != nil) != tt.wantErr {
 | |
| 				t.Errorf("verifyEncryptedCode() error = %v, wantErr %v", err, tt.wantErr)
 | |
| 			}
 | |
| 		})
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func Test_verifyHashedCode(t *testing.T) {
 | |
| 	type args struct {
 | |
| 		cryptoCode       *CryptoValue
 | |
| 		verificationCode string
 | |
| 		alg              HashAlgorithm
 | |
| 	}
 | |
| 	tests := []struct {
 | |
| 		name    string
 | |
| 		args    args
 | |
| 		wantErr bool
 | |
| 	}{
 | |
| 
 | |
| 		{
 | |
| 			"nil error",
 | |
| 			args{
 | |
| 				cryptoCode:       nil,
 | |
| 				verificationCode: "",
 | |
| 				alg:              CreateMockHashAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"wrong cryptotype error",
 | |
| 			args{
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeEncryption,
 | |
| 					Crypted:    nil,
 | |
| 				},
 | |
| 				verificationCode: "",
 | |
| 				alg:              CreateMockHashAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"wrong algorithm error",
 | |
| 			args{
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeHash,
 | |
| 					Algorithm:  "hash2",
 | |
| 					Crypted:    nil,
 | |
| 				},
 | |
| 				verificationCode: "",
 | |
| 				alg:              CreateMockHashAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"wrong verification code error",
 | |
| 			args{
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeHash,
 | |
| 					Algorithm:  "hash",
 | |
| 					Crypted:    []byte("code"),
 | |
| 				},
 | |
| 				verificationCode: "wrong",
 | |
| 				alg:              CreateMockHashAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			true,
 | |
| 		},
 | |
| 		{
 | |
| 			"verification code ok",
 | |
| 			args{
 | |
| 				cryptoCode: &CryptoValue{
 | |
| 					CryptoType: TypeHash,
 | |
| 					Algorithm:  "hash",
 | |
| 					Crypted:    []byte("code"),
 | |
| 				},
 | |
| 				verificationCode: "code",
 | |
| 				alg:              CreateMockHashAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			false,
 | |
| 		},
 | |
| 	}
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.name, func(t *testing.T) {
 | |
| 			if err := verifyHashedCode(tt.args.cryptoCode, tt.args.verificationCode, tt.args.alg); (err != nil) != tt.wantErr {
 | |
| 				t.Errorf("verifyHashedCode() error = %v, wantErr %v", err, tt.wantErr)
 | |
| 			}
 | |
| 		})
 | |
| 	}
 | |
| }
 |