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
|
|
|
}
|
|
|
|
|
2013-06-19 01:48:27 +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
|
|
|
}
|