Skip to content

Commit

Permalink
Merge pull request #95 from wneessen/more_test-coverage
Browse files Browse the repository at this point in the history
Add new test cases and rearrange existing ones
  • Loading branch information
wneessen authored Mar 26, 2024
2 parents d302625 + 2a6ebbc commit 54c76b3
Showing 1 changed file with 52 additions and 30 deletions.
82 changes: 52 additions & 30 deletions random_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -523,36 +523,13 @@ func TestGenerate(t *testing.T) {
}
}

func BenchmarkGenerator_CoinFlip(b *testing.B) {
b.ReportAllocs()
g := New(NewConfig())
for i := 0; i < b.N; i++ {
_ = g.CoinFlip()
}
}

func BenchmarkGenerator_RandomBytes(b *testing.B) {
b.ReportAllocs()
g := New(NewConfig())
var l int64 = 1024
for i := 0; i < b.N; i++ {
_, err := g.RandomBytes(l)
if err != nil {
b.Errorf("failed to generate random bytes: %s", err)
return
}
}
}

func BenchmarkGenerator_RandomString(b *testing.B) {
b.ReportAllocs()
g := New(NewConfig())
cr := CharRangeAlphaUpper + CharRangeAlphaLower + CharRangeNumeric + CharRangeSpecial
for i := 0; i < b.N; i++ {
_, err := g.RandomStringFromCharRange(32, cr)
if err != nil {
b.Errorf("RandomStringFromCharRange() failed: %s", err)
}
func TestGenerator_RandomStringFromCharRange_fail(t *testing.T) {
config := NewConfig()
gen := New(config)
_, err := gen.RandomStringFromCharRange(0, gen.GetCharRangeFromConfig())
if err == nil {
t.Errorf("RandomStringFromCharRange() with zero length is supposed" +
"to fail, but didn't")
}
}

Expand Down Expand Up @@ -590,3 +567,48 @@ func TestGenerator_generateBinary(t *testing.T) {
})
}
}

func TestGenerator_checkMinimumRequirements_human(t *testing.T) {
config := NewConfig(WithModeMask(ModeLowerCase|ModeUpperCase|ModeNumeric|
ModeSpecial|ModeHumanReadable), WithMinLowercase(1), WithMinUppercase(1),
WithMinNumeric(1), WithMinSpecial(1))
gen := New(config)
pw, err := gen.Generate()
if err != nil {
t.Errorf("Generate() failed: %s", err)
}
_ = gen.checkMinimumRequirements(pw)
}

func BenchmarkGenerator_CoinFlip(b *testing.B) {
b.ReportAllocs()
g := New(NewConfig())
for i := 0; i < b.N; i++ {
_ = g.CoinFlip()
}
}

func BenchmarkGenerator_RandomBytes(b *testing.B) {
b.ReportAllocs()
g := New(NewConfig())
var l int64 = 1024
for i := 0; i < b.N; i++ {
_, err := g.RandomBytes(l)
if err != nil {
b.Errorf("failed to generate random bytes: %s", err)
return
}
}
}

func BenchmarkGenerator_RandomString(b *testing.B) {
b.ReportAllocs()
g := New(NewConfig())
cr := CharRangeAlphaUpper + CharRangeAlphaLower + CharRangeNumeric + CharRangeSpecial
for i := 0; i < b.N; i++ {
_, err := g.RandomStringFromCharRange(32, cr)
if err != nil {
b.Errorf("RandomStringFromCharRange() failed: %s", err)
}
}
}

0 comments on commit 54c76b3

Please sign in to comment.