pulumi/sdk/go/common/resource/resource_id_test.go

201 lines
5.2 KiB
Go

// Copyright 2016-2018, Pulumi Corporation.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// nolint: goconst
package resource
import (
"strings"
"testing"
"github.com/stretchr/testify/assert"
)
func TestNewUniqueHex(t *testing.T) {
t.Parallel()
prefix := "prefix"
randlen := 8
maxlen := 100
id, err := NewUniqueHex(prefix, randlen, maxlen)
assert.Nil(t, err)
assert.Equal(t, len(prefix)+randlen, len(id))
assert.Equal(t, true, strings.HasPrefix(id, prefix))
}
func TestNewUniqueHexNonDeterminism(t *testing.T) {
t.Parallel()
prefix := "prefix"
randlen := 8
maxlen := 100
id1, err := NewUniqueHex(prefix, randlen, maxlen)
assert.Nil(t, err)
id2, err := NewUniqueHex(prefix, randlen, maxlen)
assert.Nil(t, err)
assert.NotEqual(t, id1, id2)
}
func TestNewUniqueHexMaxLen2(t *testing.T) {
t.Parallel()
prefix := "prefix"
randlen := 8
maxlen := 13
_, err := NewUniqueHex(prefix, randlen, maxlen)
assert.NotNil(t, err)
}
func TestNewUniqueHexEnsureRandomness2(t *testing.T) {
t.Parallel()
prefix := "prefix"
// Just enough space to have 8 chars of randomenss
randlen := 8
maxlen := 14
id, err := NewUniqueHex(prefix, randlen, maxlen)
assert.Nil(t, err)
assert.Equal(t, maxlen, len(id))
assert.Equal(t, true, strings.HasPrefix(id, prefix))
}
func TestNewUniqueDefaults(t *testing.T) {
t.Parallel()
prefix := "prefix"
id, err := NewUniqueHex(prefix, -1, -1)
assert.Nil(t, err)
assert.Equal(t, len(prefix)+8, len(id))
assert.Equal(t, true, strings.HasPrefix(id, prefix))
}
func TestNewUniqueHexID(t *testing.T) {
t.Parallel()
prefix := "prefix"
randlen := 8
maxlen := 100
id, err := NewUniqueHexID(prefix, randlen, maxlen)
assert.Nil(t, err)
assert.Equal(t, len(prefix)+8, len(id))
assert.Equal(t, true, strings.HasPrefix(string(id), prefix))
}
func TestNewUniqueHexMaxLenID(t *testing.T) {
t.Parallel()
prefix := "prefix"
randlen := 8
maxlen := 20
id, err := NewUniqueHexID(prefix, randlen, maxlen)
assert.Nil(t, err)
assert.Equal(t, len(prefix)+8, len(id))
assert.Equal(t, true, strings.HasPrefix(string(id), prefix))
}
func TestNewUniqueDefaultsID(t *testing.T) {
t.Parallel()
prefix := "prefix"
id, err := NewUniqueHexID(prefix, -1, -1)
assert.Nil(t, err)
assert.Equal(t, len(prefix)+8, len(id))
assert.Equal(t, true, strings.HasPrefix(string(id), prefix))
}
func TestNewUniqueV2HexFallback(t *testing.T) {
t.Parallel()
urn := NewURN("stack", "project", "", "test:index:custom", "test")
sequenceNumber := 0
prefix := "prefix"
randlen := 8
maxlen := 100
id, err := NewUniqueHexV2(urn, sequenceNumber, prefix, randlen, maxlen)
assert.Nil(t, err)
assert.Equal(t, len(prefix)+randlen, len(id))
assert.Equal(t, true, strings.HasPrefix(id, prefix))
}
func TestNewUniqueV2Hex(t *testing.T) {
t.Parallel()
urn := NewURN("stack", "project", "", "test:index:custom", "test")
sequenceNumber := 1
prefix := "prefix"
randlen := 8
maxlen := 100
id, err := NewUniqueHexV2(urn, sequenceNumber, prefix, randlen, maxlen)
assert.Nil(t, err)
assert.Equal(t, len(prefix)+randlen, len(id))
assert.Equal(t, true, strings.HasPrefix(id, prefix))
}
func TestNewUniqueHexV2MaxLen2(t *testing.T) {
t.Parallel()
urn := NewURN("stack", "project", "", "test:index:custom", "test")
sequenceNumber := 1
prefix := "prefix"
randlen := 8
maxlen := 13
_, err := NewUniqueHexV2(urn, sequenceNumber, prefix, randlen, maxlen)
assert.NotNil(t, err)
}
func TestNewUniqueHexV2EnsureRandomness2(t *testing.T) {
t.Parallel()
urn := NewURN("stack", "project", "", "test:index:custom", "test")
sequenceNumber := 1
prefix := "prefix"
// Just enough space to have 8 chars of randomenss
randlen := 8
maxlen := 14
id, err := NewUniqueHexV2(urn, sequenceNumber, prefix, randlen, maxlen)
assert.Nil(t, err)
assert.Equal(t, maxlen, len(id))
assert.Equal(t, true, strings.HasPrefix(id, prefix))
}
func TestNewUniqueV2Defaults(t *testing.T) {
t.Parallel()
urn := NewURN("stack", "project", "", "test:index:custom", "test")
sequenceNumber := 1
prefix := "prefix"
id, err := NewUniqueHexV2(urn, sequenceNumber, prefix, -1, -1)
assert.Nil(t, err)
assert.Equal(t, len(prefix)+8, len(id))
assert.Equal(t, true, strings.HasPrefix(id, prefix))
}
func TestNewUniqueV2HexDeterminism(t *testing.T) {
t.Parallel()
urn := NewURN("stack", "project", "", "test:index:custom", "test")
sequenceNumber := 1
prefix := "prefix"
randlen := 8
maxlen := 100
id1, err := NewUniqueHexV2(urn, sequenceNumber, prefix, randlen, maxlen)
assert.Nil(t, err)
id2, err := NewUniqueHexV2(urn, sequenceNumber, prefix, randlen, maxlen)
assert.Nil(t, err)
assert.Equal(t, id1, id2)
id3, err := NewUniqueHexV2(urn, sequenceNumber+1, prefix, randlen, maxlen)
assert.Nil(t, err)
assert.NotEqual(t, id2, id3)
}