v/vlib/rand/random_identifiers_test.v

75 lines
1.8 KiB
V

import time
import rand
// uuid_v4:
fn test_rand_uuid_v4() {
uuid1 := rand.uuid_v4()
uuid2 := rand.uuid_v4()
uuid3 := rand.uuid_v4()
assert uuid1 != uuid2
assert uuid1 != uuid3
assert uuid2 != uuid3
assert uuid1.len == 36
assert uuid2.len == 36
assert uuid3.len == 36
for i in 0 .. 1000 {
x := rand.uuid_v4()
// check the version field is always 4:
assert x[14] == `4`
// and the clock_seq_hi_and_reserved field is valid too:
assert x[19] in [`8`, `9`, `a`, `b`]
}
}
// ulids:
fn test_ulids_are_unique() {
ulid1 := rand.ulid()
ulid2 := rand.ulid()
ulid3 := rand.ulid()
assert ulid1.len == 26
assert ulid2.len == 26
assert ulid3.len == 26
assert ulid1 != ulid2
assert ulid1 != ulid3
assert ulid2 != ulid3
}
fn test_ulids_max_start_character_is_ok() {
ulid1 := rand.ulid()
// the largest valid ULID encoded in Base32 is 7ZZZZZZZZZZZZZZZZZZZZZZZZZ
assert (int(ulid1[0]) - 48) <= 7
}
fn test_ulids_generated_in_the_same_millisecond_have_the_same_prefix() {
t := u64(time.utc().unix_time_milli())
mut ulid1 := ''
mut ulid2 := ''
mut ulid3 := ''
ulid1 = rand.ulid_at_millisecond(t)
ulid2 = rand.ulid_at_millisecond(t)
ulid3 = rand.ulid_at_millisecond(t)
ulid1_prefix := ulid1[0..10]
ulid2_prefix := ulid2[0..10]
ulid3_prefix := ulid3[0..10]
assert ulid1_prefix == ulid2_prefix
assert ulid1_prefix == ulid3_prefix
}
fn test_ulids_should_be_lexicographically_ordered_when_not_in_same_millisecond() {
ulid1 := rand.ulid()
time.sleep(1 * time.millisecond)
ulid2 := rand.ulid()
time.sleep(1 * time.millisecond)
ulid3 := rand.ulid()
mut all := [ulid3, ulid2, ulid1]
// eprintln('all before: $all')
all.sort()
// eprintln('all after: $all')
s1 := all[0]
s2 := all[1]
s3 := all[2]
assert s1 == ulid1
assert s2 == ulid2
assert s3 == ulid3
}