test(random): add unit tests for random behavior
SonarQube Scan / SonarQube Trigger (push) Successful in 1m37s
SonarQube Scan / SonarQube Trigger (push) Successful in 1m37s
- Added unit tests to cover random string generation and error handling. - Introduced Random interface and random struct for better abstraction. - Updated server, session, and interaction packages to require Random interface for dependency injection.
This commit is contained in:
@@ -1,12 +1,35 @@
|
||||
package random
|
||||
|
||||
import "crypto/rand"
|
||||
import (
|
||||
"crypto/rand"
|
||||
"fmt"
|
||||
"io"
|
||||
)
|
||||
|
||||
func GenerateRandomString(length int) (string, error) {
|
||||
var (
|
||||
ErrInvalidLength = fmt.Errorf("invalid length")
|
||||
)
|
||||
|
||||
type Random interface {
|
||||
String(length int) (string, error)
|
||||
}
|
||||
|
||||
type random struct {
|
||||
reader io.Reader
|
||||
}
|
||||
|
||||
func New() Random {
|
||||
return &random{reader: rand.Reader}
|
||||
}
|
||||
|
||||
func (ran *random) String(length int) (string, error) {
|
||||
if length < 0 {
|
||||
return "", ErrInvalidLength
|
||||
}
|
||||
const charset = "abcdefghijklmnopqrstuvwxyz0123456789"
|
||||
b := make([]byte, length)
|
||||
|
||||
if _, err := rand.Read(b); err != nil {
|
||||
if _, err := ran.reader.Read(b); err != nil {
|
||||
return "", err
|
||||
}
|
||||
|
||||
|
||||
@@ -0,0 +1,61 @@
|
||||
package random
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
"testing"
|
||||
)
|
||||
|
||||
type brainrotReader struct {
|
||||
err error
|
||||
}
|
||||
|
||||
func (f *brainrotReader) Read(p []byte) (int, error) {
|
||||
return 0, f.err
|
||||
}
|
||||
|
||||
func TestRandom_String(t *testing.T) {
|
||||
tests := []struct {
|
||||
name string
|
||||
length int
|
||||
wantErr bool
|
||||
}{
|
||||
{"ValidLengthZero", 0, false},
|
||||
{"ValidPositiveLength", 10, false},
|
||||
{"NegativeLength", -1, true},
|
||||
{"VeryLargeLength", 1_000_000, false},
|
||||
}
|
||||
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
randomizer := New()
|
||||
|
||||
result, err := randomizer.String(tt.length)
|
||||
if (err != nil) != tt.wantErr {
|
||||
t.Errorf("String() error = %v, wantErr %v", err, tt.wantErr)
|
||||
return
|
||||
}
|
||||
|
||||
if !tt.wantErr && len(result) != tt.length {
|
||||
t.Errorf("String() length = %v, want %v", len(result), tt.length)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestRandomWithFailingReader_String(t *testing.T) {
|
||||
var randomizer Random
|
||||
var errBrainrot = fmt.Errorf("you are not sigma enough")
|
||||
randomizer = &random{reader: &brainrotReader{err: errBrainrot}}
|
||||
t.Run("test failing reader", func(t *testing.T) {
|
||||
result, err := randomizer.String(20)
|
||||
if !errors.Is(err, errBrainrot) {
|
||||
t.Errorf("String() error = %v, wantErr %v", err, errBrainrot)
|
||||
return
|
||||
}
|
||||
|
||||
if result != "" {
|
||||
t.Errorf("String() result = %v, want an empty string due to error", result)
|
||||
}
|
||||
})
|
||||
}
|
||||
Reference in New Issue
Block a user