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.
- checksums.yaml +4 -4
- data/.gitmodules +3 -6
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent-log +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent-run +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.cert +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.json +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.key +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-agent +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-agent-rc +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-blobstore-dav +0 -0
- data/bosh-provisioner/assets/bosh-provisioner +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit-log +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit-run +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monitrc +0 -0
- data/dev/Vagrantfile +1 -1
- data/dev/example-bosh-manifest.yml +12 -12
- data/lib/vagrant-bosh/bootstrapper.rb +6 -2
- data/lib/vagrant-bosh/config.rb +1 -1
- data/lib/vagrant-bosh/provisioner.rb +1 -1
- data/lib/vagrant-bosh/version.rb +1 -1
- data/vagrant-bosh.gemspec +3 -1
- metadata +20 -139
- data/go/.gitignore +0 -11
- data/go/bin/build +0 -10
- data/go/bin/build-linux-amd64 +0 -9
- data/go/bin/env +0 -13
- data/go/bin/go +0 -5
- data/go/bin/golint +0 -19
- data/go/bin/test +0 -37
- data/go/src/boshprovisioner/agent/client/client_interface.go +0 -73
- data/go/src/boshprovisioner/agent/client/fakes/fake_client.go +0 -81
- data/go/src/boshprovisioner/agent/client/http_client.go +0 -299
- data/go/src/boshprovisioner/agent/client/http_client_envelope.go +0 -107
- data/go/src/boshprovisioner/deployment/deployment.go +0 -221
- data/go/src/boshprovisioner/deployment/instance.go +0 -54
- data/go/src/boshprovisioner/deployment/manifest/deployment.go +0 -84
- data/go/src/boshprovisioner/deployment/manifest/ips.go +0 -23
- data/go/src/boshprovisioner/deployment/manifest/manifest.go +0 -143
- data/go/src/boshprovisioner/deployment/manifest/manifest_suite_test.go +0 -13
- data/go/src/boshprovisioner/deployment/manifest/manifest_test.go +0 -86
- data/go/src/boshprovisioner/deployment/manifest/syntax_validator.go +0 -186
- data/go/src/boshprovisioner/deployment/manifest/watch_time.go +0 -43
- data/go/src/boshprovisioner/deployment/manifest_reader.go +0 -46
- data/go/src/boshprovisioner/deployment/reader_factory.go +0 -25
- data/go/src/boshprovisioner/deployment/semantic_validator.go +0 -111
- data/go/src/boshprovisioner/downloader/blobstore_downloader.go +0 -55
- data/go/src/boshprovisioner/downloader/default_mux_downloader.go +0 -22
- data/go/src/boshprovisioner/downloader/downloader_interface.go +0 -6
- data/go/src/boshprovisioner/downloader/http_downloader.go +0 -53
- data/go/src/boshprovisioner/downloader/local_fs_downloader.go +0 -48
- data/go/src/boshprovisioner/downloader/mux_downloader.go +0 -69
- data/go/src/boshprovisioner/eventlog/log.go +0 -72
- data/go/src/boshprovisioner/eventlog/stage.go +0 -39
- data/go/src/boshprovisioner/eventlog/task.go +0 -58
- data/go/src/boshprovisioner/index/file_index.go +0 -289
- data/go/src/boshprovisioner/index/file_index_test.go +0 -296
- data/go/src/boshprovisioner/index/index_interface.go +0 -18
- data/go/src/boshprovisioner/index/index_suite_test.go +0 -13
- data/go/src/boshprovisioner/instance/instance.go +0 -43
- data/go/src/boshprovisioner/instance/instance_provisioner.go +0 -48
- data/go/src/boshprovisioner/instance/templatescompiler/concrete_templates_compiler.go +0 -284
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/erb_renderer.go +0 -117
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/erbrenderer_suite_test.go +0 -13
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/render_properties.go +0 -77
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/render_properties_test.go +0 -193
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/template_evaluation_context.go +0 -85
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/template_evaluation_context_rb.go +0 -155
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_jobs_repository.go +0 -86
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_runtime_packages_repository.go +0 -113
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_template_to_job_repository.go +0 -86
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/jobs_repository_interface.go +0 -49
- data/go/src/boshprovisioner/instance/templatescompiler/rendered_archives_compiler.go +0 -81
- data/go/src/boshprovisioner/instance/templatescompiler/templates_compiler_interface.go +0 -20
- data/go/src/boshprovisioner/instance/templatescompiler/templatesrepo/ct_repository.go +0 -54
- data/go/src/boshprovisioner/instance/templatescompiler/templatesrepo/templates_repository_interface.go +0 -16
- data/go/src/boshprovisioner/instance/updater/applier/applier.go +0 -93
- data/go/src/boshprovisioner/instance/updater/applier/empty_state.go +0 -66
- data/go/src/boshprovisioner/instance/updater/applier/job_state.go +0 -178
- data/go/src/boshprovisioner/instance/updater/drainer.go +0 -72
- data/go/src/boshprovisioner/instance/updater/starter.go +0 -36
- data/go/src/boshprovisioner/instance/updater/stopper.go +0 -36
- data/go/src/boshprovisioner/instance/updater/updater.go +0 -97
- data/go/src/boshprovisioner/instance/updater/updater_factory.go +0 -80
- data/go/src/boshprovisioner/instance/updater/updater_suite_test.go +0 -13
- data/go/src/boshprovisioner/instance/updater/waiter.go +0 -77
- data/go/src/boshprovisioner/instance/updater/waiter_test.go +0 -147
- data/go/src/boshprovisioner/main/config.go +0 -95
- data/go/src/boshprovisioner/main/config_test.go +0 -67
- data/go/src/boshprovisioner/main/main.go +0 -185
- data/go/src/boshprovisioner/main/main_suite_test.go +0 -13
- data/go/src/boshprovisioner/main/repos_factory.go +0 -86
- data/go/src/boshprovisioner/packagescompiler/compiledpackagesrepo/compiled_packages_repository_interface.go +0 -17
- data/go/src/boshprovisioner/packagescompiler/compiledpackagesrepo/concrete_compiled_packages_repository.go +0 -61
- data/go/src/boshprovisioner/packagescompiler/concrete_packages_compiler.go +0 -179
- data/go/src/boshprovisioner/packagescompiler/concrete_packages_compiler_factory.go +0 -48
- data/go/src/boshprovisioner/packagescompiler/packages_compiler_interface.go +0 -20
- data/go/src/boshprovisioner/packagescompiler/packagesrepo/concrete_packages_repository.go +0 -65
- data/go/src/boshprovisioner/packagescompiler/packagesrepo/packages_repository_interface.go +0 -16
- data/go/src/boshprovisioner/provisioner/blobstore_config.go +0 -65
- data/go/src/boshprovisioner/provisioner/blobstore_provisioner.go +0 -38
- data/go/src/boshprovisioner/provisioner/deployment_provisioner_interface.go +0 -10
- data/go/src/boshprovisioner/provisioner/release_compiler.go +0 -95
- data/go/src/boshprovisioner/provisioner/single_configured_vm_provisioner.go +0 -124
- data/go/src/boshprovisioner/provisioner/single_non_configured_vm_provisioner.go +0 -40
- data/go/src/boshprovisioner/provisioner/single_vm_provisioner_factory.go +0 -68
- data/go/src/boshprovisioner/release/dir_reader.go +0 -146
- data/go/src/boshprovisioner/release/job/job.go +0 -86
- data/go/src/boshprovisioner/release/job/manifest/manifest.go +0 -79
- data/go/src/boshprovisioner/release/job/manifest/manifest_suite_test.go +0 -13
- data/go/src/boshprovisioner/release/job/manifest/manifest_test.go +0 -59
- data/go/src/boshprovisioner/release/job/manifest/syntax_validator.go +0 -43
- data/go/src/boshprovisioner/release/job/reader_factory.go +0 -34
- data/go/src/boshprovisioner/release/job/tar_reader.go +0 -133
- data/go/src/boshprovisioner/release/manifest/manifest.go +0 -120
- data/go/src/boshprovisioner/release/manifest/manifest_suite_test.go +0 -13
- data/go/src/boshprovisioner/release/manifest/manifest_test.go +0 -126
- data/go/src/boshprovisioner/release/manifest/syntax_validator.go +0 -134
- data/go/src/boshprovisioner/release/reader_factory.go +0 -45
- data/go/src/boshprovisioner/release/reader_interface.go +0 -6
- data/go/src/boshprovisioner/release/release.go +0 -144
- data/go/src/boshprovisioner/release/release_suite_test.go +0 -13
- data/go/src/boshprovisioner/release/release_test.go +0 -129
- data/go/src/boshprovisioner/release/tar_reader.go +0 -141
- data/go/src/boshprovisioner/tar/cmd_compressor.go +0 -68
- data/go/src/boshprovisioner/tar/cmd_extractor.go +0 -47
- data/go/src/boshprovisioner/tar/compressor_interface.go +0 -6
- data/go/src/boshprovisioner/tar/extractor_interface.go +0 -6
- data/go/src/boshprovisioner/util/possible_base64.go +0 -21
- data/go/src/boshprovisioner/util/string_keyed.go +0 -70
- data/go/src/boshprovisioner/vm/vagrant/agent_provisioner.go +0 -296
- data/go/src/boshprovisioner/vm/vagrant/asset_manager.go +0 -61
- data/go/src/boshprovisioner/vm/vagrant/configured_vm.go +0 -29
- data/go/src/boshprovisioner/vm/vagrant/deps_provisioner.go +0 -214
- data/go/src/boshprovisioner/vm/vagrant/monit_provisioner.go +0 -85
- data/go/src/boshprovisioner/vm/vagrant/non_configured_vm.go +0 -26
- data/go/src/boshprovisioner/vm/vagrant/runit_provisioner.go +0 -229
- data/go/src/boshprovisioner/vm/vagrant/simple_cmds.go +0 -54
- data/go/src/boshprovisioner/vm/vagrant/vcap_user_provisioner.go +0 -167
- data/go/src/boshprovisioner/vm/vagrant/vm_provisioner.go +0 -119
- data/go/src/boshprovisioner/vm/vagrant/vm_provisioner_factory.go +0 -101
- data/go/src/boshprovisioner/vm/vm_interface.go +0 -45
- data/lib/vagrant-bosh/assets/provisioner +0 -0
@@ -1,120 +0,0 @@
|
|
1
|
-
// Package manifest represents internal structure of a release.
|
2
|
-
package manifest
|
3
|
-
|
4
|
-
import (
|
5
|
-
bosherr "bosh/errors"
|
6
|
-
boshsys "bosh/system"
|
7
|
-
"github.com/cloudfoundry-incubator/candiedyaml"
|
8
|
-
)
|
9
|
-
|
10
|
-
type Manifest struct {
|
11
|
-
Release Release
|
12
|
-
}
|
13
|
-
|
14
|
-
type Release struct {
|
15
|
-
Name string `yaml:"name"`
|
16
|
-
Version string `yaml:"version"`
|
17
|
-
|
18
|
-
Jobs []Job `yaml:"jobs"`
|
19
|
-
Packages []Package `yaml:"packages"`
|
20
|
-
|
21
|
-
CommitHash string `yaml:"commit_hash"`
|
22
|
-
UncommittedChanges bool `yaml:"uncommitted_changes"`
|
23
|
-
}
|
24
|
-
|
25
|
-
type Job struct {
|
26
|
-
Name string `yaml:"name"`
|
27
|
-
|
28
|
-
// bosh_cli uses fingerprint as job version
|
29
|
-
VersionRaw string `yaml:"version"`
|
30
|
-
Version string
|
31
|
-
|
32
|
-
FingerprintRaw string `yaml:"fingerprint"`
|
33
|
-
Fingerprint string
|
34
|
-
|
35
|
-
SHA1Raw string `yaml:"sha1"`
|
36
|
-
SHA1 string
|
37
|
-
}
|
38
|
-
|
39
|
-
type Package struct {
|
40
|
-
Name string `yaml:"name"`
|
41
|
-
|
42
|
-
// bosh_cli uses fingerprint as package version
|
43
|
-
VersionRaw string `yaml:"version"`
|
44
|
-
Version string
|
45
|
-
|
46
|
-
FingerprintRaw string `yaml:"fingerprint"`
|
47
|
-
Fingerprint string
|
48
|
-
|
49
|
-
SHA1Raw string `yaml:"sha1"`
|
50
|
-
SHA1 string
|
51
|
-
|
52
|
-
DependencyNames []DependencyName `yaml:"dependencies"`
|
53
|
-
}
|
54
|
-
|
55
|
-
func (p Package) DependencyName() DependencyName {
|
56
|
-
return DependencyName(p.Name)
|
57
|
-
}
|
58
|
-
|
59
|
-
type DependencyName string
|
60
|
-
|
61
|
-
// NewManifestFromPath returns manifest read from the file system.
|
62
|
-
func NewManifestFromPath(path string, fs boshsys.FileSystem) (Manifest, error) {
|
63
|
-
bytes, err := fs.ReadFile(path)
|
64
|
-
if err != nil {
|
65
|
-
return Manifest{}, bosherr.WrapError(err, "Reading manifest %s", path)
|
66
|
-
}
|
67
|
-
|
68
|
-
return NewManifestFromBytes(bytes)
|
69
|
-
}
|
70
|
-
|
71
|
-
// NewManifestFromBytes returns manifest built from given bytes.
|
72
|
-
func NewManifestFromBytes(bytes []byte) (Manifest, error) {
|
73
|
-
var manifest Manifest
|
74
|
-
var release Release
|
75
|
-
|
76
|
-
err := candiedyaml.Unmarshal(bytes, &release)
|
77
|
-
if err != nil {
|
78
|
-
return manifest, bosherr.WrapError(err, "Parsing release")
|
79
|
-
}
|
80
|
-
|
81
|
-
manifest.Release = release
|
82
|
-
|
83
|
-
err = NewSyntaxValidator(&manifest).Validate()
|
84
|
-
if err != nil {
|
85
|
-
return manifest, bosherr.WrapError(err, "Validating manifest syntactically")
|
86
|
-
}
|
87
|
-
|
88
|
-
return manifest, nil
|
89
|
-
}
|
90
|
-
|
91
|
-
/*
|
92
|
-
# Example for release.MF
|
93
|
-
name: bosh
|
94
|
-
version: 77
|
95
|
-
|
96
|
-
commit_hash: bbe5476c
|
97
|
-
uncommitted_changes: true
|
98
|
-
|
99
|
-
packages:
|
100
|
-
- name: registry
|
101
|
-
version: !binary |-
|
102
|
-
ZGQxYmEzMzBiYzQ0YjMxODFiMjYzMzgzYjhlNDI1MmQ3MDUxZGVjYQ==
|
103
|
-
fingerprint: !binary |-
|
104
|
-
ZGQxYmEzMzBiYzQ0YjMxODFiMjYzMzgzYjhlNDI1MmQ3MDUxZGVjYQ==
|
105
|
-
sha1: !binary |-
|
106
|
-
NmVhYTZjOTYxZWFjN2JkOTk0ZDE2NDRhZDQwNWIzMzk1NDIwZWNhZg==
|
107
|
-
dependencies:
|
108
|
-
- libpq
|
109
|
-
- mysql
|
110
|
-
- ruby
|
111
|
-
|
112
|
-
jobs:
|
113
|
-
- name: powerdns
|
114
|
-
version: !binary |-
|
115
|
-
MGI4MGIzYzE5OGJmN2FiYzZjODEyNjIwMTNkZTQ5NDM2OWZkMjViNg==
|
116
|
-
fingerprint: !binary |-
|
117
|
-
MGI4MGIzYzE5OGJmN2FiYzZjODEyNjIwMTNkZTQ5NDM2OWZkMjViNg==
|
118
|
-
sha1: !binary |-
|
119
|
-
YWI5NzA5YmVhYjViZTBmYjYyYTJkMWYzYzg4ZDA2YzliNGJkZWM2NQ==
|
120
|
-
*/
|
@@ -1,126 +0,0 @@
|
|
1
|
-
package manifest_test
|
2
|
-
|
3
|
-
import (
|
4
|
-
. "github.com/onsi/ginkgo"
|
5
|
-
. "github.com/onsi/gomega"
|
6
|
-
|
7
|
-
. "boshprovisioner/release/manifest"
|
8
|
-
)
|
9
|
-
|
10
|
-
var _ = Describe("Manifest", func() {
|
11
|
-
Describe("NewManifestFromBytes", func() {
|
12
|
-
It("returns manifest with decoded version/fingerprint/sha1 for jobs and packages", func() {
|
13
|
-
manifestBytes := []byte(`
|
14
|
-
name: bosh
|
15
|
-
version: 77
|
16
|
-
|
17
|
-
commit_hash: bbe5476c
|
18
|
-
uncommitted_changes: true
|
19
|
-
|
20
|
-
packages:
|
21
|
-
- name: registry
|
22
|
-
version: !binary |-
|
23
|
-
ZGQxYmEzMzBiYzQ0YjMxODFiMjYzMzgzYjhlNDI1MmQ3MDUxZGVjYQ==
|
24
|
-
fingerprint: !binary |-
|
25
|
-
ZGQxYmEzMzBiYzQ0YjMxODFiMjYzMzgzYjhlNDI1MmQ3MDUxZGVjYQ==
|
26
|
-
sha1: !binary |-
|
27
|
-
NmVhYTZjOTYxZWFjN2JkOTk0ZDE2NDRhZDQwNWIzMzk1NDIwZWNhZg==
|
28
|
-
dependencies: []
|
29
|
-
|
30
|
-
jobs:
|
31
|
-
- name: powerdns
|
32
|
-
version: !binary |-
|
33
|
-
MGI4MGIzYzE5OGJmN2FiYzZjODEyNjIwMTNkZTQ5NDM2OWZkMjViNg==
|
34
|
-
fingerprint: !binary |-
|
35
|
-
MGI4MGIzYzE5OGJmN2FiYzZjODEyNjIwMTNkZTQ5NDM2OWZkMjViNg==
|
36
|
-
sha1: !binary |-
|
37
|
-
YWI5NzA5YmVhYjViZTBmYjYyYTJkMWYzYzg4ZDA2YzliNGJkZWM2NQ==
|
38
|
-
`)
|
39
|
-
|
40
|
-
manifest, err := NewManifestFromBytes(manifestBytes)
|
41
|
-
Expect(err).ToNot(HaveOccurred())
|
42
|
-
|
43
|
-
Expect(manifest.Release.Packages[0]).To(Equal(Package{
|
44
|
-
Name: "registry",
|
45
|
-
|
46
|
-
VersionRaw: "ZGQxYmEzMzBiYzQ0YjMxODFiMjYzMzgzYjhlNDI1MmQ3MDUxZGVjYQ==",
|
47
|
-
Version: "dd1ba330bc44b3181b263383b8e4252d7051deca",
|
48
|
-
|
49
|
-
FingerprintRaw: "ZGQxYmEzMzBiYzQ0YjMxODFiMjYzMzgzYjhlNDI1MmQ3MDUxZGVjYQ==",
|
50
|
-
Fingerprint: "dd1ba330bc44b3181b263383b8e4252d7051deca",
|
51
|
-
|
52
|
-
SHA1Raw: "NmVhYTZjOTYxZWFjN2JkOTk0ZDE2NDRhZDQwNWIzMzk1NDIwZWNhZg==",
|
53
|
-
SHA1: "6eaa6c961eac7bd994d1644ad405b3395420ecaf",
|
54
|
-
|
55
|
-
DependencyNames: []DependencyName{},
|
56
|
-
}))
|
57
|
-
|
58
|
-
Expect(manifest.Release.Jobs[0]).To(Equal(Job{
|
59
|
-
Name: "powerdns",
|
60
|
-
|
61
|
-
VersionRaw: "MGI4MGIzYzE5OGJmN2FiYzZjODEyNjIwMTNkZTQ5NDM2OWZkMjViNg==",
|
62
|
-
Version: "0b80b3c198bf7abc6c81262013de494369fd25b6",
|
63
|
-
|
64
|
-
FingerprintRaw: "MGI4MGIzYzE5OGJmN2FiYzZjODEyNjIwMTNkZTQ5NDM2OWZkMjViNg==",
|
65
|
-
Fingerprint: "0b80b3c198bf7abc6c81262013de494369fd25b6",
|
66
|
-
|
67
|
-
SHA1Raw: "YWI5NzA5YmVhYjViZTBmYjYyYTJkMWYzYzg4ZDA2YzliNGJkZWM2NQ==",
|
68
|
-
SHA1: "ab9709beab5be0fb62a2d1f3c88d06c9b4bdec65",
|
69
|
-
}))
|
70
|
-
})
|
71
|
-
|
72
|
-
It("returns manifest with given version/fingerprint/sha1 for jobs and packages if they were not base64 binary encoded", func() {
|
73
|
-
manifestBytes := []byte(`
|
74
|
-
name: bosh
|
75
|
-
version: 77
|
76
|
-
|
77
|
-
commit_hash: bbe5476c
|
78
|
-
uncommitted_changes: true
|
79
|
-
|
80
|
-
packages:
|
81
|
-
- name: registry
|
82
|
-
version: dd1ba330bc44b3181b263383b8e4252d7051deca
|
83
|
-
fingerprint: dd1ba330bc44b3181b263383b8e4252d7051deca
|
84
|
-
sha1: 6eaa6c961eac7bd994d1644ad405b3395420ecaf
|
85
|
-
dependencies: []
|
86
|
-
|
87
|
-
jobs:
|
88
|
-
- name: powerdns
|
89
|
-
version: 0b80b3c198bf7abc6c81262013de494369fd25b6
|
90
|
-
fingerprint: 0b80b3c198bf7abc6c81262013de494369fd25b6
|
91
|
-
sha1: ab9709beab5be0fb62a2d1f3c88d06c9b4bdec65
|
92
|
-
`)
|
93
|
-
|
94
|
-
manifest, err := NewManifestFromBytes(manifestBytes)
|
95
|
-
Expect(err).ToNot(HaveOccurred())
|
96
|
-
|
97
|
-
Expect(manifest.Release.Packages[0]).To(Equal(Package{
|
98
|
-
Name: "registry",
|
99
|
-
|
100
|
-
VersionRaw: "dd1ba330bc44b3181b263383b8e4252d7051deca",
|
101
|
-
Version: "dd1ba330bc44b3181b263383b8e4252d7051deca",
|
102
|
-
|
103
|
-
FingerprintRaw: "dd1ba330bc44b3181b263383b8e4252d7051deca",
|
104
|
-
Fingerprint: "dd1ba330bc44b3181b263383b8e4252d7051deca",
|
105
|
-
|
106
|
-
SHA1Raw: "6eaa6c961eac7bd994d1644ad405b3395420ecaf",
|
107
|
-
SHA1: "6eaa6c961eac7bd994d1644ad405b3395420ecaf",
|
108
|
-
|
109
|
-
DependencyNames: []DependencyName{},
|
110
|
-
}))
|
111
|
-
|
112
|
-
Expect(manifest.Release.Jobs[0]).To(Equal(Job{
|
113
|
-
Name: "powerdns",
|
114
|
-
|
115
|
-
VersionRaw: "0b80b3c198bf7abc6c81262013de494369fd25b6",
|
116
|
-
Version: "0b80b3c198bf7abc6c81262013de494369fd25b6",
|
117
|
-
|
118
|
-
FingerprintRaw: "0b80b3c198bf7abc6c81262013de494369fd25b6",
|
119
|
-
Fingerprint: "0b80b3c198bf7abc6c81262013de494369fd25b6",
|
120
|
-
|
121
|
-
SHA1Raw: "ab9709beab5be0fb62a2d1f3c88d06c9b4bdec65",
|
122
|
-
SHA1: "ab9709beab5be0fb62a2d1f3c88d06c9b4bdec65",
|
123
|
-
}))
|
124
|
-
})
|
125
|
-
})
|
126
|
-
})
|
@@ -1,134 +0,0 @@
|
|
1
|
-
package manifest
|
2
|
-
|
3
|
-
import (
|
4
|
-
bosherr "bosh/errors"
|
5
|
-
|
6
|
-
bputil "boshprovisioner/util"
|
7
|
-
)
|
8
|
-
|
9
|
-
// SyntaxValidator parses and saves all manifest values to determine
|
10
|
-
// their syntactic validity. Determining if individual values make sense
|
11
|
-
// in a greater context (within a full release) is outside of scope.
|
12
|
-
type SyntaxValidator struct {
|
13
|
-
release *Release
|
14
|
-
}
|
15
|
-
|
16
|
-
func NewSyntaxValidator(manifest *Manifest) SyntaxValidator {
|
17
|
-
if manifest == nil {
|
18
|
-
panic("Expected manifest to not be nil")
|
19
|
-
}
|
20
|
-
|
21
|
-
return SyntaxValidator{release: &manifest.Release}
|
22
|
-
}
|
23
|
-
|
24
|
-
func (v SyntaxValidator) Validate() error {
|
25
|
-
if v.release.Name == "" {
|
26
|
-
return bosherr.New("Missing release name")
|
27
|
-
}
|
28
|
-
|
29
|
-
if v.release.Version == "" {
|
30
|
-
return bosherr.New("Missing release version")
|
31
|
-
}
|
32
|
-
|
33
|
-
if v.release.CommitHash == "" {
|
34
|
-
return bosherr.New("Missing release commit_hash")
|
35
|
-
}
|
36
|
-
|
37
|
-
for i, job := range v.release.Jobs {
|
38
|
-
err := v.validateJob(&v.release.Jobs[i])
|
39
|
-
if err != nil {
|
40
|
-
return bosherr.WrapError(err, "Job %s (%d)", job.Name, i)
|
41
|
-
}
|
42
|
-
}
|
43
|
-
|
44
|
-
for i, pkg := range v.release.Packages {
|
45
|
-
err := v.validatePkg(&v.release.Packages[i])
|
46
|
-
if err != nil {
|
47
|
-
return bosherr.WrapError(err, "Package %s (%d)", pkg.Name, i)
|
48
|
-
}
|
49
|
-
}
|
50
|
-
|
51
|
-
return nil
|
52
|
-
}
|
53
|
-
|
54
|
-
func (v SyntaxValidator) validateJob(job *Job) error {
|
55
|
-
if job.Name == "" {
|
56
|
-
return bosherr.New("Missing name")
|
57
|
-
}
|
58
|
-
|
59
|
-
if job.VersionRaw == "" {
|
60
|
-
return bosherr.New("Missing version")
|
61
|
-
}
|
62
|
-
|
63
|
-
str, err := bputil.DecodePossibleBase64Str(job.VersionRaw)
|
64
|
-
if err != nil {
|
65
|
-
return bosherr.WrapError(err, "Decoding base64 encoded version")
|
66
|
-
}
|
67
|
-
|
68
|
-
job.Version = str
|
69
|
-
|
70
|
-
if job.FingerprintRaw == "" {
|
71
|
-
return bosherr.New("Missing fingerprint")
|
72
|
-
}
|
73
|
-
|
74
|
-
str, err = bputil.DecodePossibleBase64Str(job.FingerprintRaw)
|
75
|
-
if err != nil {
|
76
|
-
return bosherr.WrapError(err, "Decoding base64 encoded fingerprint")
|
77
|
-
}
|
78
|
-
|
79
|
-
job.Fingerprint = str
|
80
|
-
|
81
|
-
if job.SHA1Raw == "" {
|
82
|
-
return bosherr.New("Missing sha1")
|
83
|
-
}
|
84
|
-
|
85
|
-
str, err = bputil.DecodePossibleBase64Str(job.SHA1Raw)
|
86
|
-
if err != nil {
|
87
|
-
return bosherr.WrapError(err, "Decoding base64 encoded sha1")
|
88
|
-
}
|
89
|
-
|
90
|
-
job.SHA1 = str
|
91
|
-
|
92
|
-
return nil
|
93
|
-
}
|
94
|
-
|
95
|
-
func (v SyntaxValidator) validatePkg(pkg *Package) error {
|
96
|
-
if pkg.Name == "" {
|
97
|
-
return bosherr.New("Missing name")
|
98
|
-
}
|
99
|
-
|
100
|
-
if pkg.VersionRaw == "" {
|
101
|
-
return bosherr.New("Missing version")
|
102
|
-
}
|
103
|
-
|
104
|
-
str, err := bputil.DecodePossibleBase64Str(pkg.VersionRaw)
|
105
|
-
if err != nil {
|
106
|
-
return bosherr.WrapError(err, "Decoding base64 encoded version")
|
107
|
-
}
|
108
|
-
|
109
|
-
pkg.Version = str
|
110
|
-
|
111
|
-
if pkg.FingerprintRaw == "" {
|
112
|
-
return bosherr.New("Missing fingerprint")
|
113
|
-
}
|
114
|
-
|
115
|
-
str, err = bputil.DecodePossibleBase64Str(pkg.FingerprintRaw)
|
116
|
-
if err != nil {
|
117
|
-
return bosherr.WrapError(err, "Decoding base64 encoded fingerprint")
|
118
|
-
}
|
119
|
-
|
120
|
-
pkg.Fingerprint = str
|
121
|
-
|
122
|
-
if pkg.SHA1Raw == "" {
|
123
|
-
return bosherr.New("Missing sha1")
|
124
|
-
}
|
125
|
-
|
126
|
-
str, err = bputil.DecodePossibleBase64Str(pkg.SHA1Raw)
|
127
|
-
if err != nil {
|
128
|
-
return bosherr.WrapError(err, "Decoding base64 encoded sha1")
|
129
|
-
}
|
130
|
-
|
131
|
-
pkg.SHA1 = str
|
132
|
-
|
133
|
-
return nil
|
134
|
-
}
|
@@ -1,45 +0,0 @@
|
|
1
|
-
package release
|
2
|
-
|
3
|
-
import (
|
4
|
-
"strings"
|
5
|
-
|
6
|
-
boshlog "bosh/logger"
|
7
|
-
boshsys "bosh/system"
|
8
|
-
|
9
|
-
bpdload "boshprovisioner/downloader"
|
10
|
-
bptar "boshprovisioner/tar"
|
11
|
-
)
|
12
|
-
|
13
|
-
const (
|
14
|
-
readerFactoryDirPrefix = "dir://"
|
15
|
-
)
|
16
|
-
|
17
|
-
type ReaderFactory struct {
|
18
|
-
downloader bpdload.Downloader
|
19
|
-
extractor bptar.Extractor
|
20
|
-
fs boshsys.FileSystem
|
21
|
-
logger boshlog.Logger
|
22
|
-
}
|
23
|
-
|
24
|
-
func NewReaderFactory(
|
25
|
-
downloader bpdload.Downloader,
|
26
|
-
extractor bptar.Extractor,
|
27
|
-
fs boshsys.FileSystem,
|
28
|
-
logger boshlog.Logger,
|
29
|
-
) ReaderFactory {
|
30
|
-
return ReaderFactory{
|
31
|
-
downloader: downloader,
|
32
|
-
extractor: extractor,
|
33
|
-
fs: fs,
|
34
|
-
logger: logger,
|
35
|
-
}
|
36
|
-
}
|
37
|
-
|
38
|
-
func (rf ReaderFactory) NewReader(name, version, url string) Reader {
|
39
|
-
if strings.HasPrefix(url, readerFactoryDirPrefix) {
|
40
|
-
path := url[len(readerFactoryDirPrefix):]
|
41
|
-
return NewDirReader(name, version, path, rf.fs, rf.logger)
|
42
|
-
}
|
43
|
-
|
44
|
-
return NewTarReader(url, rf.downloader, rf.extractor, rf.fs, rf.logger)
|
45
|
-
}
|