File: random_test.go

package info (click to toggle)
rclone 1.60.1%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 34,820 kB
  • sloc: sh: 957; xml: 857; python: 655; javascript: 612; makefile: 264; ansic: 101; php: 74
file content (64 lines) | stat: -rw-r--r-- 1,309 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package random

import (
	"math/rand"
	"testing"

	"github.com/stretchr/testify/assert"
	"github.com/stretchr/testify/require"
)

func TestStringLength(t *testing.T) {
	for i := 0; i < 100; i++ {
		s := String(i)
		assert.Equal(t, i, len(s))
	}
}

func TestStringDuplicates(t *testing.T) {
	seen := map[string]bool{}
	for i := 0; i < 100; i++ {
		s := String(8)
		assert.False(t, seen[s])
		assert.Equal(t, 8, len(s))
		seen[s] = true
	}
}

func TestPasswordLength(t *testing.T) {
	for i := 0; i <= 128; i++ {
		s, err := Password(i)
		require.NoError(t, err)
		// expected length is number of bytes rounded up
		expected := i / 8
		if i%8 != 0 {
			expected++
		}
		// then converted to base 64
		expected = (expected*8 + 5) / 6
		assert.Equal(t, expected, len(s), i)
	}
}

func TestPasswordDuplicates(t *testing.T) {
	seen := map[string]bool{}
	for i := 0; i < 100; i++ {
		s, err := Password(64)
		require.NoError(t, err)
		assert.False(t, seen[s])
		seen[s] = true
	}
}

func TestSeed(t *testing.T) {
	// seed 100 times and check the first random number doesn't repeat
	// This test could fail with a probability of ~ 10**-15
	const n = 100
	var seen = map[int64]bool{}
	for i := 0; i < n; i++ {
		assert.NoError(t, Seed())
		first := rand.Int63()
		assert.False(t, seen[first])
		seen[first] = true
	}
}