vagrant-bosh 0.0.6 → 0.0.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (143) hide show
  1. checksums.yaml +4 -4
  2. data/.gitmodules +3 -6
  3. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent-log +0 -0
  4. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent-run +0 -0
  5. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.cert +0 -0
  6. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.json +0 -0
  7. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.key +0 -0
  8. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-agent +0 -0
  9. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-agent-rc +0 -0
  10. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-blobstore-dav +0 -0
  11. data/bosh-provisioner/assets/bosh-provisioner +0 -0
  12. data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit +0 -0
  13. data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit-log +0 -0
  14. data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit-run +0 -0
  15. data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monitrc +0 -0
  16. data/dev/Vagrantfile +1 -1
  17. data/dev/example-bosh-manifest.yml +12 -12
  18. data/lib/vagrant-bosh/bootstrapper.rb +6 -2
  19. data/lib/vagrant-bosh/config.rb +1 -1
  20. data/lib/vagrant-bosh/provisioner.rb +1 -1
  21. data/lib/vagrant-bosh/version.rb +1 -1
  22. data/vagrant-bosh.gemspec +3 -1
  23. metadata +20 -139
  24. data/go/.gitignore +0 -11
  25. data/go/bin/build +0 -10
  26. data/go/bin/build-linux-amd64 +0 -9
  27. data/go/bin/env +0 -13
  28. data/go/bin/go +0 -5
  29. data/go/bin/golint +0 -19
  30. data/go/bin/test +0 -37
  31. data/go/src/boshprovisioner/agent/client/client_interface.go +0 -73
  32. data/go/src/boshprovisioner/agent/client/fakes/fake_client.go +0 -81
  33. data/go/src/boshprovisioner/agent/client/http_client.go +0 -299
  34. data/go/src/boshprovisioner/agent/client/http_client_envelope.go +0 -107
  35. data/go/src/boshprovisioner/deployment/deployment.go +0 -221
  36. data/go/src/boshprovisioner/deployment/instance.go +0 -54
  37. data/go/src/boshprovisioner/deployment/manifest/deployment.go +0 -84
  38. data/go/src/boshprovisioner/deployment/manifest/ips.go +0 -23
  39. data/go/src/boshprovisioner/deployment/manifest/manifest.go +0 -143
  40. data/go/src/boshprovisioner/deployment/manifest/manifest_suite_test.go +0 -13
  41. data/go/src/boshprovisioner/deployment/manifest/manifest_test.go +0 -86
  42. data/go/src/boshprovisioner/deployment/manifest/syntax_validator.go +0 -186
  43. data/go/src/boshprovisioner/deployment/manifest/watch_time.go +0 -43
  44. data/go/src/boshprovisioner/deployment/manifest_reader.go +0 -46
  45. data/go/src/boshprovisioner/deployment/reader_factory.go +0 -25
  46. data/go/src/boshprovisioner/deployment/semantic_validator.go +0 -111
  47. data/go/src/boshprovisioner/downloader/blobstore_downloader.go +0 -55
  48. data/go/src/boshprovisioner/downloader/default_mux_downloader.go +0 -22
  49. data/go/src/boshprovisioner/downloader/downloader_interface.go +0 -6
  50. data/go/src/boshprovisioner/downloader/http_downloader.go +0 -53
  51. data/go/src/boshprovisioner/downloader/local_fs_downloader.go +0 -48
  52. data/go/src/boshprovisioner/downloader/mux_downloader.go +0 -69
  53. data/go/src/boshprovisioner/eventlog/log.go +0 -72
  54. data/go/src/boshprovisioner/eventlog/stage.go +0 -39
  55. data/go/src/boshprovisioner/eventlog/task.go +0 -58
  56. data/go/src/boshprovisioner/index/file_index.go +0 -289
  57. data/go/src/boshprovisioner/index/file_index_test.go +0 -296
  58. data/go/src/boshprovisioner/index/index_interface.go +0 -18
  59. data/go/src/boshprovisioner/index/index_suite_test.go +0 -13
  60. data/go/src/boshprovisioner/instance/instance.go +0 -43
  61. data/go/src/boshprovisioner/instance/instance_provisioner.go +0 -48
  62. data/go/src/boshprovisioner/instance/templatescompiler/concrete_templates_compiler.go +0 -284
  63. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/erb_renderer.go +0 -117
  64. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/erbrenderer_suite_test.go +0 -13
  65. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/render_properties.go +0 -77
  66. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/render_properties_test.go +0 -193
  67. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/template_evaluation_context.go +0 -85
  68. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/template_evaluation_context_rb.go +0 -155
  69. data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_jobs_repository.go +0 -86
  70. data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_runtime_packages_repository.go +0 -113
  71. data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_template_to_job_repository.go +0 -86
  72. data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/jobs_repository_interface.go +0 -49
  73. data/go/src/boshprovisioner/instance/templatescompiler/rendered_archives_compiler.go +0 -81
  74. data/go/src/boshprovisioner/instance/templatescompiler/templates_compiler_interface.go +0 -20
  75. data/go/src/boshprovisioner/instance/templatescompiler/templatesrepo/ct_repository.go +0 -54
  76. data/go/src/boshprovisioner/instance/templatescompiler/templatesrepo/templates_repository_interface.go +0 -16
  77. data/go/src/boshprovisioner/instance/updater/applier/applier.go +0 -93
  78. data/go/src/boshprovisioner/instance/updater/applier/empty_state.go +0 -66
  79. data/go/src/boshprovisioner/instance/updater/applier/job_state.go +0 -178
  80. data/go/src/boshprovisioner/instance/updater/drainer.go +0 -72
  81. data/go/src/boshprovisioner/instance/updater/starter.go +0 -36
  82. data/go/src/boshprovisioner/instance/updater/stopper.go +0 -36
  83. data/go/src/boshprovisioner/instance/updater/updater.go +0 -97
  84. data/go/src/boshprovisioner/instance/updater/updater_factory.go +0 -80
  85. data/go/src/boshprovisioner/instance/updater/updater_suite_test.go +0 -13
  86. data/go/src/boshprovisioner/instance/updater/waiter.go +0 -77
  87. data/go/src/boshprovisioner/instance/updater/waiter_test.go +0 -147
  88. data/go/src/boshprovisioner/main/config.go +0 -95
  89. data/go/src/boshprovisioner/main/config_test.go +0 -67
  90. data/go/src/boshprovisioner/main/main.go +0 -185
  91. data/go/src/boshprovisioner/main/main_suite_test.go +0 -13
  92. data/go/src/boshprovisioner/main/repos_factory.go +0 -86
  93. data/go/src/boshprovisioner/packagescompiler/compiledpackagesrepo/compiled_packages_repository_interface.go +0 -17
  94. data/go/src/boshprovisioner/packagescompiler/compiledpackagesrepo/concrete_compiled_packages_repository.go +0 -61
  95. data/go/src/boshprovisioner/packagescompiler/concrete_packages_compiler.go +0 -179
  96. data/go/src/boshprovisioner/packagescompiler/concrete_packages_compiler_factory.go +0 -48
  97. data/go/src/boshprovisioner/packagescompiler/packages_compiler_interface.go +0 -20
  98. data/go/src/boshprovisioner/packagescompiler/packagesrepo/concrete_packages_repository.go +0 -65
  99. data/go/src/boshprovisioner/packagescompiler/packagesrepo/packages_repository_interface.go +0 -16
  100. data/go/src/boshprovisioner/provisioner/blobstore_config.go +0 -65
  101. data/go/src/boshprovisioner/provisioner/blobstore_provisioner.go +0 -38
  102. data/go/src/boshprovisioner/provisioner/deployment_provisioner_interface.go +0 -10
  103. data/go/src/boshprovisioner/provisioner/release_compiler.go +0 -95
  104. data/go/src/boshprovisioner/provisioner/single_configured_vm_provisioner.go +0 -124
  105. data/go/src/boshprovisioner/provisioner/single_non_configured_vm_provisioner.go +0 -40
  106. data/go/src/boshprovisioner/provisioner/single_vm_provisioner_factory.go +0 -68
  107. data/go/src/boshprovisioner/release/dir_reader.go +0 -146
  108. data/go/src/boshprovisioner/release/job/job.go +0 -86
  109. data/go/src/boshprovisioner/release/job/manifest/manifest.go +0 -79
  110. data/go/src/boshprovisioner/release/job/manifest/manifest_suite_test.go +0 -13
  111. data/go/src/boshprovisioner/release/job/manifest/manifest_test.go +0 -59
  112. data/go/src/boshprovisioner/release/job/manifest/syntax_validator.go +0 -43
  113. data/go/src/boshprovisioner/release/job/reader_factory.go +0 -34
  114. data/go/src/boshprovisioner/release/job/tar_reader.go +0 -133
  115. data/go/src/boshprovisioner/release/manifest/manifest.go +0 -120
  116. data/go/src/boshprovisioner/release/manifest/manifest_suite_test.go +0 -13
  117. data/go/src/boshprovisioner/release/manifest/manifest_test.go +0 -126
  118. data/go/src/boshprovisioner/release/manifest/syntax_validator.go +0 -134
  119. data/go/src/boshprovisioner/release/reader_factory.go +0 -45
  120. data/go/src/boshprovisioner/release/reader_interface.go +0 -6
  121. data/go/src/boshprovisioner/release/release.go +0 -144
  122. data/go/src/boshprovisioner/release/release_suite_test.go +0 -13
  123. data/go/src/boshprovisioner/release/release_test.go +0 -129
  124. data/go/src/boshprovisioner/release/tar_reader.go +0 -141
  125. data/go/src/boshprovisioner/tar/cmd_compressor.go +0 -68
  126. data/go/src/boshprovisioner/tar/cmd_extractor.go +0 -47
  127. data/go/src/boshprovisioner/tar/compressor_interface.go +0 -6
  128. data/go/src/boshprovisioner/tar/extractor_interface.go +0 -6
  129. data/go/src/boshprovisioner/util/possible_base64.go +0 -21
  130. data/go/src/boshprovisioner/util/string_keyed.go +0 -70
  131. data/go/src/boshprovisioner/vm/vagrant/agent_provisioner.go +0 -296
  132. data/go/src/boshprovisioner/vm/vagrant/asset_manager.go +0 -61
  133. data/go/src/boshprovisioner/vm/vagrant/configured_vm.go +0 -29
  134. data/go/src/boshprovisioner/vm/vagrant/deps_provisioner.go +0 -214
  135. data/go/src/boshprovisioner/vm/vagrant/monit_provisioner.go +0 -85
  136. data/go/src/boshprovisioner/vm/vagrant/non_configured_vm.go +0 -26
  137. data/go/src/boshprovisioner/vm/vagrant/runit_provisioner.go +0 -229
  138. data/go/src/boshprovisioner/vm/vagrant/simple_cmds.go +0 -54
  139. data/go/src/boshprovisioner/vm/vagrant/vcap_user_provisioner.go +0 -167
  140. data/go/src/boshprovisioner/vm/vagrant/vm_provisioner.go +0 -119
  141. data/go/src/boshprovisioner/vm/vagrant/vm_provisioner_factory.go +0 -101
  142. data/go/src/boshprovisioner/vm/vm_interface.go +0 -45
  143. data/lib/vagrant-bosh/assets/provisioner +0 -0
@@ -1,107 +0,0 @@
1
- package client
2
-
3
- import (
4
- "encoding/json"
5
-
6
- boshaction "bosh/agent/action"
7
- bosherr "bosh/errors"
8
- )
9
-
10
- type requestEnvelope struct {
11
- Method reqMethod `json:"method"`
12
- Arguments reqArgs `json:"arguments"`
13
- ReplyTo string `json:"reply_to"`
14
- }
15
-
16
- type reqMethod string
17
- type reqArgs []interface{}
18
-
19
- type responseEnvelope struct {
20
- Value json.RawMessage `json:"value"`
21
- Exception respException `json:"exception"`
22
- }
23
-
24
- type respException struct {
25
- Message string `json:"message"`
26
- }
27
-
28
- type errandResultEnvelope struct {
29
- Result boshaction.ErrandResult `json:"result"`
30
- }
31
-
32
- type compiledPackageEnvelope struct {
33
- Result CompiledPackage `json:"result"`
34
- }
35
-
36
- func (re responseEnvelope) HasException() bool {
37
- return len(re.Exception.Message) > 0
38
- }
39
-
40
- func (re responseEnvelope) StringValue() (string, error) {
41
- value, err := re.interfaceValue()
42
- if err != nil {
43
- return "", err
44
- }
45
-
46
- str, ok := value.(string)
47
- if !ok {
48
- return "", bosherr.WrapError(err, "Converting value to string")
49
- }
50
-
51
- return str, nil
52
- }
53
-
54
- func (re responseEnvelope) MapValue() (map[string]interface{}, error) {
55
- var m map[string]interface{}
56
-
57
- value, err := re.interfaceValue()
58
- if err != nil {
59
- return m, err
60
- }
61
-
62
- m, ok := value.(map[string]interface{})
63
- if !ok {
64
- return m, bosherr.WrapError(err, "Converting value to map[string]interface{}")
65
- }
66
-
67
- return m, nil
68
- }
69
-
70
- func (re responseEnvelope) CustomValue(value interface{}) error {
71
- return json.Unmarshal(re.Value, &value)
72
- }
73
-
74
- func (re responseEnvelope) TaskID() (string, bool) {
75
- value, err := re.interfaceValue()
76
- if err != nil {
77
- return "", false
78
- }
79
-
80
- // Check if it looks like a task status
81
- result, ok := value.(map[string]interface{})
82
- if !ok {
83
- return "", false
84
- }
85
-
86
- taskID, found := result["agent_task_id"]
87
- if !found {
88
- return "", false
89
- }
90
-
91
- if result["state"] != "running" {
92
- return "", false
93
- }
94
-
95
- return taskID.(string), true
96
- }
97
-
98
- func (re responseEnvelope) interfaceValue() (interface{}, error) {
99
- var value interface{}
100
-
101
- err := json.Unmarshal(re.Value, &value)
102
- if err != nil {
103
- return value, err
104
- }
105
-
106
- return value, nil
107
- }
@@ -1,221 +0,0 @@
1
- package deployment
2
-
3
- import (
4
- gonet "net"
5
-
6
- boshaction "bosh/agent/action"
7
-
8
- bpdepman "boshprovisioner/deployment/manifest"
9
- )
10
-
11
- type Deployment struct {
12
- Manifest bpdepman.Manifest
13
-
14
- Name string
15
-
16
- Releases []Release
17
-
18
- Networks []Network
19
-
20
- Jobs []Job
21
-
22
- CompilationInstance Instance
23
- }
24
-
25
- type Release struct {
26
- Name string
27
- Version string
28
-
29
- // Not offical BOSH manifest construct
30
- URL string
31
- }
32
-
33
- const (
34
- NetworkTypeManual = bpdepman.NetworkTypeManual
35
- NetworkTypeDynamic = bpdepman.NetworkTypeDynamic
36
- NetworkTypeVip = bpdepman.NetworkTypeVip
37
- )
38
-
39
- var NetworkTypes = []string{NetworkTypeManual, NetworkTypeDynamic, NetworkTypeVip}
40
-
41
- type Network struct {
42
- Name string
43
- Type string
44
- }
45
-
46
- type Job struct {
47
- Name string
48
-
49
- Templates []Template
50
-
51
- Instances []Instance
52
- }
53
-
54
- type Template struct {
55
- Name string
56
-
57
- Release *Release
58
- }
59
-
60
- type Instance struct {
61
- Index int
62
-
63
- // Denormalized values to avoid passing dep/job/instance tuple
64
- JobName string
65
- DeploymentName string
66
-
67
- // Watch time will vary depending if an instance is a canary
68
- WatchTime bpdepman.WatchTime
69
-
70
- Properties Properties
71
-
72
- NetworkAssociations []NetworkAssociation
73
-
74
- // Represents current state of an associated VM
75
- CurrentState boshaction.GetStateV1ApplySpec
76
- }
77
-
78
- type Properties map[string]interface{}
79
-
80
- type NetworkAssociation struct {
81
- Network *Network
82
-
83
- StaticIP gonet.IP
84
-
85
- // StaticIP might equal to nil, though that does not indicate
86
- // that this instance does not need a static IP
87
- MustHaveStaticIP bool
88
- }
89
-
90
- // populateFromManifest populates deployment information
91
- // interpreted from deployment manifest.
92
- func (d *Deployment) populateFromManifest(manifest bpdepman.Manifest) {
93
- d.populateNetworks(manifest)
94
- d.populateReleases(manifest)
95
- d.populateCompilationInstances(manifest)
96
- d.populateJobs(manifest)
97
- d.Manifest = manifest
98
- }
99
-
100
- func (d *Deployment) populateNetworks(manifest bpdepman.Manifest) {
101
- for _, manNet := range manifest.Deployment.Networks {
102
- d.Networks = append(d.Networks, Network{
103
- Name: manNet.Name,
104
- Type: manNet.Type,
105
- })
106
- }
107
- }
108
-
109
- func (d *Deployment) populateReleases(manifest bpdepman.Manifest) {
110
- for _, manRelease := range manifest.Deployment.Releases {
111
- d.Releases = append(d.Releases, Release{
112
- Name: manRelease.Name,
113
- Version: manRelease.Version,
114
- URL: manRelease.URL,
115
- })
116
- }
117
- }
118
-
119
- func (d *Deployment) populateCompilationInstances(manifest bpdepman.Manifest) {
120
- network := d.findNetworkOrDefault(manifest.Deployment.Compilation.NetworkName)
121
-
122
- d.CompilationInstance = Instance{
123
- Index: 0,
124
-
125
- JobName: "compilation",
126
- DeploymentName: manifest.Deployment.Name,
127
-
128
- NetworkAssociations: []NetworkAssociation{
129
- NetworkAssociation{Network: network},
130
- },
131
- }
132
- }
133
-
134
- func (d *Deployment) populateJobs(manifest bpdepman.Manifest) {
135
- for _, manJob := range manifest.Deployment.Jobs {
136
- d.Jobs = append(d.Jobs, d.buildJob(manifest.Deployment, manJob))
137
- }
138
- }
139
-
140
- func (d *Deployment) buildJob(manDep bpdepman.Deployment, manJob bpdepman.Job) Job {
141
- job := Job{Name: manJob.Name}
142
-
143
- for i := 0; i < manJob.Instances; i++ {
144
- watchTime := manDep.InstanceWatchTime(manJob, i)
145
- properties := manDep.InstanceProperties(manJob, i)
146
- netAssocs := d.buildNetworkAssociations(manJob, i)
147
-
148
- job.Instances = append(job.Instances, Instance{
149
- Index: i,
150
-
151
- JobName: manJob.Name,
152
- DeploymentName: manDep.Name,
153
-
154
- WatchTime: watchTime,
155
- Properties: Properties(properties),
156
-
157
- NetworkAssociations: netAssocs,
158
- })
159
- }
160
-
161
- // todo check to make sure release is present
162
- for _, manTemplate := range manJob.Templates {
163
- release := d.findReleaseOrDefault(manTemplate.ReleaseName)
164
-
165
- job.Templates = append(job.Templates, Template{
166
- Name: manTemplate.Name,
167
- Release: release,
168
- })
169
- }
170
-
171
- return job
172
- }
173
-
174
- func (d *Deployment) buildNetworkAssociations(manJob bpdepman.Job, i int) []NetworkAssociation {
175
- var netAssocs []NetworkAssociation
176
-
177
- for _, manNa := range manJob.NetworkAssociations {
178
- var staticIP gonet.IP
179
-
180
- network := d.findNetworkOrDefault(manNa.NetworkName)
181
-
182
- if i < len(manNa.StaticIPs) {
183
- staticIP = manNa.StaticIPs[i]
184
- }
185
-
186
- netAssocs = append(netAssocs, NetworkAssociation{
187
- Network: network,
188
- StaticIP: staticIP,
189
-
190
- MustHaveStaticIP: len(manNa.StaticIPs) > 0,
191
- })
192
- }
193
-
194
- return netAssocs
195
- }
196
-
197
- func (d *Deployment) findReleaseOrDefault(name string) *Release {
198
- // todo check against empty release name
199
- for _, release := range d.Releases {
200
- if release.Name == name {
201
- return &release
202
- }
203
- }
204
-
205
- // Assume if there is only one release it's default
206
- if len(d.Releases) == 1 {
207
- return &d.Releases[0]
208
- }
209
-
210
- return nil
211
- }
212
-
213
- func (d *Deployment) findNetworkOrDefault(name string) *Network {
214
- for _, net := range d.Networks {
215
- if net.Name == name {
216
- return &net
217
- }
218
- }
219
-
220
- return nil
221
- }
@@ -1,54 +0,0 @@
1
- package deployment
2
-
3
- import (
4
- "fmt"
5
- )
6
-
7
- type NetworkConfiguration struct {
8
- IP string
9
- Netmask string
10
- Gateway string
11
- }
12
-
13
- func (i Instance) NetworkConfigurationForNetworkAssociation(na NetworkAssociation) NetworkConfiguration {
14
- // If instance is always has static ip assigned there is nothing to resolve
15
- if na.MustHaveStaticIP {
16
- return NetworkConfiguration{IP: na.StaticIP.String()}
17
- }
18
-
19
- // Dynamic network information can be resolved after VM is powered on.
20
- if na.Network.Type == NetworkTypeDynamic {
21
- networkSpec, ok := i.CurrentState.NetworkSpecs[na.Network.Name]
22
- if !ok {
23
- return NetworkConfiguration{}
24
- }
25
-
26
- // todo better way to deserialize? structmap?
27
- ipStr, ok := networkSpec.Fields["ip"].(string)
28
- if !ok {
29
- return NetworkConfiguration{}
30
- }
31
-
32
- netmaskStr, ok := networkSpec.Fields["netmask"].(string)
33
- if !ok {
34
- return NetworkConfiguration{}
35
- }
36
-
37
- gatewayStr, ok := networkSpec.Fields["gateway"].(string)
38
- if !ok {
39
- return NetworkConfiguration{}
40
- }
41
-
42
- return NetworkConfiguration{
43
- IP: ipStr,
44
- Netmask: netmaskStr,
45
- Gateway: gatewayStr,
46
- }
47
- }
48
-
49
- return NetworkConfiguration{}
50
- }
51
-
52
- func (i Instance) DNDRecordName(na NetworkAssociation) string {
53
- return fmt.Sprintf("%d.%s.%s.%s.bosh", i.Index, i.JobName, na.Network.Name, i.DeploymentName)
54
- }
@@ -1,84 +0,0 @@
1
- package manifest
2
-
3
- import (
4
- "encoding/json"
5
-
6
- bosherr "bosh/errors"
7
- )
8
-
9
- var (
10
- DefaultWatchTime = WatchTime{0, 60000}
11
- )
12
-
13
- func (d Deployment) InstanceWatchTime(job Job, i int) WatchTime {
14
- var canaries int
15
-
16
- if job.Update.Canaries != nil {
17
- canaries = *job.Update.Canaries
18
- } else if d.Update.Canaries != nil {
19
- canaries = *d.Update.Canaries
20
- }
21
-
22
- if canaries > i {
23
- return d.CanaryWatchTime(job)
24
- }
25
-
26
- return d.UpdateWatchTime(job)
27
- }
28
-
29
- func (d Deployment) CanaryWatchTime(job Job) WatchTime {
30
- if job.Update.CanaryWatchTime != nil {
31
- return *job.Update.CanaryWatchTime
32
- } else if d.Update.CanaryWatchTime != nil {
33
- return *d.Update.CanaryWatchTime
34
- }
35
-
36
- return DefaultWatchTime
37
- }
38
-
39
- func (d Deployment) UpdateWatchTime(job Job) WatchTime {
40
- if job.Update.UpdateWatchTime != nil {
41
- return *job.Update.UpdateWatchTime
42
- } else if d.Update.UpdateWatchTime != nil {
43
- return *d.Update.UpdateWatchTime
44
- }
45
-
46
- return DefaultWatchTime
47
- }
48
-
49
- func (d Deployment) InstanceProperties(job Job, i int) Properties {
50
- result, err := job.deepCopyProperties()
51
- if err != nil {
52
- panic("Deep copying job properties")
53
- }
54
-
55
- for name, value := range d.Properties {
56
- if _, ok := result[name]; !ok {
57
- result[name] = value
58
- }
59
- }
60
-
61
- return result
62
- }
63
-
64
- // deepCopyJobProperties makes a deep copy of job properties.
65
- // Always returns an initialized map even if job properties are nil.
66
- func (j Job) deepCopyProperties() (Properties, error) {
67
- result := map[string]interface{}{}
68
-
69
- if j.Properties == nil {
70
- return result, nil
71
- }
72
-
73
- bytes, err := json.Marshal(j.Properties)
74
- if err != nil {
75
- return result, bosherr.WrapError(err, "Marshalling job properties")
76
- }
77
-
78
- err = json.Unmarshal(bytes, &result)
79
- if err != nil {
80
- return result, bosherr.WrapError(err, "Unmarshalling job properties")
81
- }
82
-
83
- return result, nil
84
- }