open-nomad/api/compose_test.go

149 lines
3.2 KiB
Go
Raw Normal View History

2015-09-09 20:02:39 +00:00
package api
import (
"reflect"
"testing"
2017-02-06 19:48:28 +00:00
"github.com/hashicorp/nomad/helper"
2015-09-09 20:02:39 +00:00
)
func TestCompose(t *testing.T) {
2017-07-21 23:33:04 +00:00
t.Parallel()
2015-09-09 20:02:39 +00:00
// Compose a task
2015-09-10 00:59:18 +00:00
task := NewTask("task1", "exec").
2015-09-09 20:02:39 +00:00
SetConfig("foo", "bar").
2015-09-10 00:59:18 +00:00
SetMeta("foo", "bar").
Constrain(NewConstraint("kernel.name", "=", "linux")).
2015-09-10 00:29:43 +00:00
Require(&Resources{
2017-02-06 19:48:28 +00:00
CPU: helper.IntToPtr(1250),
MemoryMB: helper.IntToPtr(1024),
DiskMB: helper.IntToPtr(2048),
IOPS: helper.IntToPtr(500),
2016-02-19 23:49:32 +00:00
Networks: []*NetworkResource{
2017-09-26 22:26:33 +00:00
{
2016-02-19 23:49:32 +00:00
CIDR: "0.0.0.0/0",
2017-02-13 23:18:17 +00:00
MBits: helper.IntToPtr(100),
2016-02-19 23:49:32 +00:00
ReservedPorts: []Port{{"", 80}, {"", 443}},
},
2015-09-09 20:02:39 +00:00
},
2016-02-19 23:49:32 +00:00
})
2015-09-09 20:02:39 +00:00
// Compose a task group
st1 := NewSpreadTarget("dc1", 80)
st2 := NewSpreadTarget("dc2", 20)
2015-09-10 00:59:18 +00:00
grp := NewTaskGroup("grp1", 2).
Constrain(NewConstraint("kernel.name", "=", "linux")).
2018-07-16 13:30:58 +00:00
AddAffinity(NewAffinity("${node.class}", "=", "large", 50)).
AddSpread(NewSpread("${node.datacenter}", 30, []*SpreadTarget{st1, st2})).
2015-09-09 20:02:39 +00:00
SetMeta("foo", "bar").
AddTask(task)
2015-09-10 00:29:43 +00:00
// Compose a job
2015-09-16 18:42:08 +00:00
job := NewServiceJob("job1", "myjob", "region1", 2).
2015-09-10 00:29:43 +00:00
SetMeta("foo", "bar").
AddDatacenter("dc1").
Constrain(NewConstraint("kernel.name", "=", "linux")).
2015-09-10 00:29:43 +00:00
AddTaskGroup(grp)
2015-09-09 20:02:39 +00:00
// Check that the composed result looks correct
2015-09-10 00:29:43 +00:00
expect := &Job{
2017-02-06 19:48:28 +00:00
Region: helper.StringToPtr("region1"),
ID: helper.StringToPtr("job1"),
Name: helper.StringToPtr("myjob"),
Type: helper.StringToPtr(JobTypeService),
Priority: helper.IntToPtr(2),
2015-09-10 00:59:18 +00:00
Datacenters: []string{
"dc1",
},
Meta: map[string]string{
"foo": "bar",
},
2015-09-09 20:02:39 +00:00
Constraints: []*Constraint{
2017-09-26 22:26:33 +00:00
{
2015-09-09 20:02:39 +00:00
LTarget: "kernel.name",
RTarget: "linux",
Operand: "=",
},
},
2015-09-10 00:29:43 +00:00
TaskGroups: []*TaskGroup{
2017-09-26 22:26:33 +00:00
{
2017-02-06 19:48:28 +00:00
Name: helper.StringToPtr("grp1"),
Count: helper.IntToPtr(2),
2015-09-10 00:29:43 +00:00
Constraints: []*Constraint{
2017-09-26 22:26:33 +00:00
{
2015-09-10 00:29:43 +00:00
LTarget: "kernel.name",
RTarget: "linux",
Operand: "=",
},
},
2018-07-16 13:30:58 +00:00
Affinities: []*Affinity{
{
LTarget: "${node.class}",
RTarget: "large",
Operand: "=",
Weight: 50,
},
},
Spreads: []*Spread{
{
Attribute: "${node.datacenter}",
Weight: 30,
SpreadTarget: []*SpreadTarget{
{
Value: "dc1",
Percent: 80,
},
{
Value: "dc2",
Percent: 20,
},
},
},
},
2015-09-10 00:29:43 +00:00
Tasks: []*Task{
2017-09-26 22:26:33 +00:00
{
2015-09-10 00:59:18 +00:00
Name: "task1",
Driver: "exec",
2015-09-10 00:29:43 +00:00
Resources: &Resources{
2017-02-06 19:48:28 +00:00
CPU: helper.IntToPtr(1250),
MemoryMB: helper.IntToPtr(1024),
DiskMB: helper.IntToPtr(2048),
IOPS: helper.IntToPtr(500),
2015-09-10 00:29:43 +00:00
Networks: []*NetworkResource{
2017-09-26 22:26:33 +00:00
{
2015-09-10 00:59:18 +00:00
CIDR: "0.0.0.0/0",
2017-02-13 23:18:17 +00:00
MBits: helper.IntToPtr(100),
2015-11-15 01:30:36 +00:00
ReservedPorts: []Port{
{"", 80},
{"", 443},
2015-09-10 00:59:18 +00:00
},
2015-09-10 00:29:43 +00:00
},
},
},
Constraints: []*Constraint{
2017-09-26 22:26:33 +00:00
{
2015-09-10 00:29:43 +00:00
LTarget: "kernel.name",
RTarget: "linux",
Operand: "=",
},
},
2015-11-15 01:30:36 +00:00
Config: map[string]interface{}{
2015-09-10 00:29:43 +00:00
"foo": "bar",
2015-09-10 00:59:18 +00:00
},
Meta: map[string]string{
"foo": "bar",
2015-09-09 20:02:39 +00:00
},
},
},
2015-09-10 00:29:43 +00:00
Meta: map[string]string{
2015-09-09 20:02:39 +00:00
"foo": "bar",
},
},
},
}
2015-09-10 00:29:43 +00:00
if !reflect.DeepEqual(job, expect) {
t.Fatalf("expect: %#v, got: %#v", expect, job)
2015-09-09 20:02:39 +00:00
}
}