File: model_test.go

package info (click to toggle)
golang-github-juju-names 4.0.0-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, trixie
  • size: 340 kB
  • sloc: makefile: 14
file content (76 lines) | stat: -rw-r--r-- 1,656 bytes parent folder | download
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
65
66
67
68
69
70
71
72
73
74
75
76
// Copyright 2016 Canonical Ltd.
// Licensed under the LGPLv3, see LICENCE file for details.

package names_test

import (
	gc "gopkg.in/check.v1"
	"github.com/juju/names/v4"
)

type modelSuite struct{}

var _ = gc.Suite(&modelSuite{})

var parseModelTagTests = []struct {
	tag      string
	expected names.Tag
	err      error
}{{
	tag: "",
	err: names.InvalidTagError("", ""),
}, {
	tag:      "model-f47ac10b-58cc-4372-a567-0e02b2c3d479",
	expected: names.NewModelTag("f47ac10b-58cc-4372-a567-0e02b2c3d479"),
}, {
	tag: "dave",
	err: names.InvalidTagError("dave", ""),
}, {
	tag: "model-",
	err: names.InvalidTagError("model-", names.ModelTagKind),
}, {
	tag: "application-dave",
	err: names.InvalidTagError("application-dave", names.ModelTagKind),
}}

func (s *modelSuite) TestParseModelTag(c *gc.C) {
	for i, t := range parseModelTagTests {
		c.Logf("test %d: %s", i, t.tag)
		got, err := names.ParseModelTag(t.tag)
		if err != nil || t.err != nil {
			c.Check(err, gc.DeepEquals, t.err)
			continue
		}
		c.Check(got, gc.FitsTypeOf, t.expected)
		c.Check(got, gc.Equals, t.expected)
	}
}

var modelNameTest = []struct {
	test     string
	name     string
	expected bool
}{{
	test:     "Hyphenated true",
	name:     "foo-bar",
	expected: true,
}, {
	test:     "Whitespsce false",
	name:     "foo bar",
	expected: false,
}, {
	test:     "Capital false",
	name:     "fooBar",
	expected: false,
}, {
	test:     "At sign false",
	name:     "foo@bar",
	expected: false,
}}

func (s *modelSuite) TestModelName(c *gc.C) {
	for i, t := range modelNameTest {
		c.Logf("test %d: %q", i, t.name)
		c.Check(names.IsValidModelName(t.name), gc.Equals, t.expected)
	}
}