go.uuid/uuid_test.go

210 lines
5.4 KiB
Go
Raw Normal View History

2013-06-18 13:50:18 +04:00
package uuid
import (
"testing"
)
2013-06-18 20:14:33 +04:00
func TestString(t *testing.T) {
if NamespaceDNS.String() != "6ba7b810-9dad-11d1-80b4-00c04fd430c8" {
t.Errorf("Incorrect string representation for UUID: %s", NamespaceDNS.String())
}
}
2013-06-18 20:17:07 +04:00
func TestEqual(t *testing.T) {
2013-06-18 23:04:30 +04:00
if !Equal(NamespaceDNS, NamespaceDNS) {
2013-06-18 20:17:07 +04:00
t.Errorf("Incorrect comparison of %s and %s", NamespaceDNS, NamespaceDNS)
}
2013-06-18 23:04:30 +04:00
if Equal(NamespaceDNS, NamespaceURL) {
2013-06-18 20:17:07 +04:00
t.Errorf("Incorrect comparison of %s and %s", NamespaceDNS, NamespaceURL)
}
}
2013-06-18 13:50:18 +04:00
func TestVersion(t *testing.T) {
u := UUID{0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}
if u.Version() != 1 {
t.Errorf("Incorrect version for UUID: %d", u.Version())
}
}
func TestSetVersion(t *testing.T) {
u := new(UUID)
u.setVersion(4)
if u.Version() != 4 {
t.Errorf("Incorrect version for UUID after u.setVersion(4): %d", u.Version())
}
}
func TestVariant(t *testing.T) {
2013-06-18 14:51:58 +04:00
u1 := UUID{0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}
if u1.Variant() != VariantNCS {
t.Errorf("Incorrect variant for UUID variant %d: %d", VariantNCS, u1.Variant())
}
u2 := UUID{0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}
if u2.Variant() != VariantRFC4122 {
t.Errorf("Incorrect variant for UUID variant %d: %d", VariantRFC4122, u2.Variant())
}
u3 := UUID{0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}
if u3.Variant() != VariantMicrosoft {
t.Errorf("Incorrect variant for UUID variant %d: %d", VariantMicrosoft, u3.Variant())
}
u4 := UUID{0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}
if u4.Variant() != VariantFuture {
t.Errorf("Incorrect variant for UUID variant %d: %d", VariantFuture, u4.Variant())
}
2013-06-18 13:50:18 +04:00
}
func TestSetVariant(t *testing.T) {
u := new(UUID)
u.setVariant()
2013-06-18 14:51:58 +04:00
if u.Variant() != VariantRFC4122 {
t.Errorf("Incorrect variant for UUID after u.setVariant(): %d", u.Variant())
}
2013-06-18 13:50:18 +04:00
}
2013-06-18 18:58:10 +04:00
func TestNewV1(t *testing.T) {
u, err := NewV1()
if err != nil {
t.Errorf("UUIDv1 generated with error: %s", err.Error())
}
if u.Version() != 1 {
t.Errorf("UUIDv1 generated with incorrect version: %d", u.Version())
}
if u.Variant() != VariantRFC4122 {
t.Errorf("UUIDv1 generated with incorrect variant: %d", u.Variant())
}
2013-06-18 21:00:58 +04:00
u1, _ := NewV1()
u2, _ := NewV1()
if Equal(u1, u2) {
t.Errorf("UUIDv1 generated two equal UUIDs: %s and %s", u1, u2)
}
2013-06-18 18:58:10 +04:00
}
func TestNewV2(t *testing.T) {
u, err := NewV2(DomainPerson)
if err != nil {
t.Errorf("UUIDv2 generated with error: %s", err.Error())
}
if u.Version() != 2 {
t.Errorf("UUIDv2 generated with incorrect version: %d", u.Version())
}
if u.Variant() != VariantRFC4122 {
t.Errorf("UUIDv2 generated with incorrect variant: %d", u.Variant())
}
}
2013-06-18 17:23:53 +04:00
func TestNewV3(t *testing.T) {
u, err := NewV3(NamespaceDNS, "www.example.com")
if err != nil {
t.Errorf("UUIDv3 generated with error: %s", err.Error())
}
if u.Version() != 3 {
t.Errorf("UUIDv3 generated with incorrect version: %d", u.Version())
}
if u.Variant() != VariantRFC4122 {
t.Errorf("UUIDv3 generated with incorrect variant: %d", u.Variant())
}
2013-06-18 20:14:33 +04:00
if u.String() != "5df41881-3aed-3515-88a7-2f4a814cf09e" {
t.Errorf("UUIDv3 generated incorrectly: %s", u.String())
}
2013-06-18 21:00:58 +04:00
u, _ = NewV3(NamespaceDNS, "python.org")
2013-06-18 20:14:33 +04:00
if u.String() != "6fa459ea-ee8a-3ca4-894e-db77e160355e" {
t.Errorf("UUIDv3 generated incorrectly: %s", u.String())
}
2013-06-18 21:00:58 +04:00
u1, _ := NewV3(NamespaceDNS, "golang.org")
u2, _ := NewV3(NamespaceDNS, "golang.org")
if !Equal(u1, u2) {
t.Errorf("UUIDv3 generated different UUIDs for same namespace and name: %s and %s", u1, u2)
}
u3, _ := NewV3(NamespaceDNS, "example.com")
if Equal(u1, u3) {
t.Errorf("UUIDv3 generated same UUIDs for different names in same namespace: %s and %s", u1, u2)
}
u4, _ := NewV3(NamespaceURL, "golang.org")
if Equal(u1, u4) {
t.Errorf("UUIDv3 generated same UUIDs for sane names in different namespaces: %s and %s", u1, u4)
}
2013-06-18 17:23:53 +04:00
}
2013-06-18 13:50:18 +04:00
func TestNewV4(t *testing.T) {
u, err := NewV4()
if err != nil {
t.Errorf("UUIDv4 generated with error: %s", err.Error())
return
}
if u.Version() != 4 {
t.Errorf("UUIDv4 generated with incorrect version: %d", u.Version())
}
2013-06-18 14:51:58 +04:00
if u.Variant() != VariantRFC4122 {
t.Errorf("UUIDv4 generated with incorrect variant: %d", u.Variant())
}
2013-06-18 13:50:18 +04:00
}
2013-06-18 17:23:53 +04:00
func TestNewV5(t *testing.T) {
u, err := NewV5(NamespaceDNS, "www.example.com")
if err != nil {
t.Errorf("UUIDv5 generated with error: %s", err.Error())
}
if u.Version() != 5 {
t.Errorf("UUIDv5 generated with incorrect version: %d", u.Version())
}
if u.Variant() != VariantRFC4122 {
t.Errorf("UUIDv5 generated with incorrect variant: %d", u.Variant())
}
2013-06-18 20:14:33 +04:00
2013-06-18 21:00:58 +04:00
u, _ = NewV5(NamespaceDNS, "python.org")
2013-06-18 20:14:33 +04:00
if u.String() != "886313e1-3b8a-5372-9b90-0c9aee199e5d" {
t.Errorf("UUIDv5 generated incorrectly: %s", u.String())
}
2013-06-18 21:00:58 +04:00
u1, _ := NewV5(NamespaceDNS, "golang.org")
u2, _ := NewV5(NamespaceDNS, "golang.org")
if !Equal(u1, u2) {
t.Errorf("UUIDv5 generated different UUIDs for same namespace and name: %s and %s", u1, u2)
}
u3, _ := NewV5(NamespaceDNS, "example.com")
if Equal(u1, u3) {
t.Errorf("UUIDv5 generated same UUIDs for different names in same namespace: %s and %s", u1, u2)
}
u4, _ := NewV5(NamespaceURL, "golang.org")
if Equal(u1, u4) {
t.Errorf("UUIDv3 generated same UUIDs for sane names in different namespaces: %s and %s", u1, u4)
}
2013-06-18 17:23:53 +04:00
}