File: aggregate_test.go

package info (click to toggle)
golang-github-mesos-mesos-go 0.0.6%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 11,724 kB
  • sloc: makefile: 163
file content (74 lines) | stat: -rw-r--r-- 2,052 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
package resources_test

import (
	"reflect"
	"testing"

	"github.com/mesos/mesos-go/api/v1/lib"
	rez "github.com/mesos/mesos-go/api/v1/lib/resources"
	. "github.com/mesos/mesos-go/api/v1/lib/resourcetest"
)

func TestTypesOf(t *testing.T) {
	rs := Resources(
		Resource(Name("cpus"), ValueScalar(2), Role("role1")),
		Resource(Name("cpus"), ValueScalar(4)),
		Resource(Name("ports"), ValueRange(Span(1, 10)), Role("role1")),
		Resource(Name("ports"), ValueRange(Span(11, 20))),
	)
	types := rez.TypesOf(rs...)
	expected := map[rez.Name]mesos.Value_Type{
		rez.NameCPUs:  mesos.SCALAR,
		rez.NamePorts: mesos.RANGES,
	}
	if !reflect.DeepEqual(types, expected) {
		t.Fatalf("expected %v instead of %v", expected, types)
	}
}

func TestNamesOf(t *testing.T) {
	rs := Resources(
		Resource(Name("cpus"), ValueScalar(2), Role("role1")),
		Resource(Name("cpus"), ValueScalar(4)),
		Resource(Name("mem"), ValueScalar(10), Role("role1")),
		Resource(Name("mem"), ValueScalar(10)),
	)
	names := rez.NamesOf(rs...)
	rez.Names(names).Sort()
	expected := []rez.Name{rez.NameCPUs, rez.NameMem}
	if !reflect.DeepEqual(names, expected) {
		t.Fatalf("expected %v instead of %v", expected, names)
	}
}

func TestFlatten(t *testing.T) {
	for i, tc := range []struct {
		r1, wants mesos.Resources
	}{
		{nil, nil},
		{
			r1: Resources(
				Resource(Name("cpus"), ValueScalar(1), Role("role1")),
				Resource(Name("cpus"), ValueScalar(2), Role("role2")),
				Resource(Name("mem"), ValueScalar(5), Role("role1")),
			),
			wants: Resources(
				Resource(Name("cpus"), ValueScalar(3)),
				Resource(Name("mem"), ValueScalar(5)),
			),
		},
		{
			r1: Resources(
				Resource(Name("cpus"), ValueScalar(3), Role("role1")),
				Resource(Name("mem"), ValueScalar(15), Role("role1")),
			),
			wants: Resources(
				Resource(Name("cpus"), ValueScalar(3), Role("*")),
				Resource(Name("mem"), ValueScalar(15), Role("*")),
			),
		},
	} {
		r := rez.Flatten(tc.r1)
		Expect(t, rez.Equivalent(r, tc.wants), "test case %d failed: expected %+v instead of %+v", i, tc.wants, r)
	}
}