forked from oVirt/go-ovirt-client
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathaffinitygroup_create.go
118 lines (109 loc) · 2.86 KB
/
affinitygroup_create.go
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
package ovirtclient
import (
"fmt"
ovirtsdk4 "github.com/ovirt/go-ovirt"
)
func (o *oVirtClient) CreateAffinityGroup(
clusterID ClusterID,
name string,
params CreateAffinityGroupOptionalParams,
retries ...RetryStrategy,
) (result AffinityGroup, err error) {
if params == nil {
params = CreateAffinityGroupParams()
}
retries = defaultRetries(retries, defaultWriteTimeouts(o))
err = retry(
fmt.Sprintf("creating affinity group in cluster %s", clusterID),
o.logger,
retries,
func() error {
agBuilder := ovirtsdk4.NewAffinityGroupBuilder().
Name(name)
if enforcing := params.Enforcing(); enforcing != nil {
agBuilder.Enforcing(*enforcing)
}
if description := params.Description(); description != "" {
agBuilder.Description(description)
}
if vmsRule := params.VMsRule(); vmsRule != nil {
rule := ovirtsdk4.NewAffinityRuleBuilder()
rule.Enabled(vmsRule.Enabled())
rule.Positive(bool(vmsRule.Affinity()))
rule.Enforcing(vmsRule.Enforcing())
agBuilder.VmsRule(rule.MustBuild())
}
if hostsRule := params.HostsRule(); hostsRule != nil {
rule := ovirtsdk4.NewAffinityRuleBuilder()
rule.Enabled(hostsRule.Enabled())
rule.Positive(bool(hostsRule.Affinity()))
rule.Enforcing(hostsRule.Enforcing())
agBuilder.HostsRule(rule.MustBuild())
}
addRequest := o.conn.
SystemService().
ClustersService().
ClusterService(string(clusterID)).
AffinityGroupsService().
Add()
addRequest.Group(
agBuilder.MustBuild(),
)
response, err := addRequest.Send()
if err != nil {
return err
}
group, ok := response.Group()
if !ok {
return newFieldNotFound("add affinity group response", "group")
}
result, err = convertSDKAffinityGroup(group, o)
return err
},
)
return result, err
}
func (m *mockClient) CreateAffinityGroup(
clusterID ClusterID,
name string,
params CreateAffinityGroupOptionalParams,
_ ...RetryStrategy,
) (AffinityGroup, error) {
if params == nil {
params = CreateAffinityGroupParams()
}
priority := AffinityGroupPriority(1)
if params.Priority() != nil {
priority = *params.Priority()
}
enforcing := false
if params.Enforcing() != nil {
enforcing = *params.Enforcing()
}
hostsRule := params.HostsRule()
if hostsRule == nil {
hostsRule = &affinityRule{}
}
vmsRule := params.VMsRule()
if vmsRule == nil {
vmsRule = &affinityRule{}
}
ag := &affinityGroup{
client: m,
id: AffinityGroupID(m.GenerateUUID()),
name: name,
description: params.Description(),
clusterID: clusterID,
priority: priority,
enforcing: enforcing,
hostsRule: hostsRule,
vmsRule: vmsRule,
}
m.lock.Lock()
defer m.lock.Unlock()
if _, ok := m.affinityGroups[ag.ClusterID()]; !ok {
return nil, newError(ENotFound, "Cluster %s not found.", ag.ClusterID())
}
m.affinityGroups[ag.ClusterID()][ag.id] = ag
return ag, nil
}