forked from juju/juju
/
environ.go
156 lines (132 loc) · 4.58 KB
/
environ.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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
// Copyright 2013 Canonical Ltd.
// Licensed under the AGPLv3, see LICENCE file for details.
package testing
import (
"io/ioutil"
"os"
gitjujutesting "github.com/juju/testing"
gc "launchpad.net/gocheck"
"github.com/juju/juju/environs/config"
"github.com/juju/juju/juju/osenv"
"github.com/juju/juju/utils/ssh"
)
// FakeAuthKeys holds the authorized key used for testing
// purposes in FakeConfig. It is valid for parsing with the utils/ssh
// authorized-key utilities.
const FakeAuthKeys = `ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAAAYQDP8fPSAMFm2PQGoVUks/FENVUMww1QTK6m++Y2qX9NGHm43kwEzxfoWR77wo6fhBhgFHsQ6ogE/cYLx77hOvjTchMEP74EVxSce0qtDjI7SwYbOpAButRId3g/Ef4STz8= joe@0.1.2.4`
func init() {
_, err := ssh.ParseAuthorisedKey(FakeAuthKeys)
if err != nil {
panic("FakeAuthKeys does not hold a valid authorized key: " + err.Error())
}
}
const FakeDefaultSeries = "precise"
// FakeConfig() returns an environment configuration for a
// fake provider with all required attributes set.
func FakeConfig() Attrs {
return Attrs{
"type": "someprovider",
"name": "testenv",
"authorized-keys": FakeAuthKeys,
"firewall-mode": config.FwInstance,
"admin-secret": "fish",
"ca-cert": CACert,
"ca-private-key": CAKey,
"ssl-hostname-verification": true,
"development": false,
"state-port": 19034,
"api-port": 17777,
"default-series": FakeDefaultSeries,
}
}
// EnvironConfig returns a default environment configuration suitable for
// setting in the state.
func EnvironConfig(c *gc.C) *config.Config {
return CustomEnvironConfig(c, Attrs{})
}
// CustomEnvironConfig returns an environment configuration with
// additional specified keys added.
func CustomEnvironConfig(c *gc.C, extra Attrs) *config.Config {
attrs := FakeConfig().Merge(Attrs{
"agent-version": "1.2.3",
}).Merge(extra).Delete("admin-secret", "ca-private-key")
cfg, err := config.New(config.NoDefaults, attrs)
c.Assert(err, gc.IsNil)
return cfg
}
const (
SampleEnvName = "erewhemos"
EnvDefault = "default:\n " + SampleEnvName + "\n"
)
const DefaultMongoPassword = "conn-from-name-secret"
// Environment names below are explicit as it makes them more readable.
const SingleEnvConfigNoDefault = `
environments:
erewhemos:
type: dummy
state-server: true
authorized-keys: i-am-a-key
admin-secret: ` + DefaultMongoPassword + `
`
const SingleEnvConfig = EnvDefault + SingleEnvConfigNoDefault
const MultipleEnvConfigNoDefault = `
environments:
erewhemos:
type: dummy
state-server: true
authorized-keys: i-am-a-key
admin-secret: ` + DefaultMongoPassword + `
erewhemos-2:
type: dummy
state-server: true
authorized-keys: i-am-a-key
admin-secret: ` + DefaultMongoPassword + `
`
const MultipleEnvConfig = EnvDefault + MultipleEnvConfigNoDefault
const SampleCertName = "erewhemos"
// FakeJujuHomeSuite isolates the user's home directory and
// sets up a Juju home with a sample environment and certificate.
type FakeJujuHomeSuite struct {
JujuOSEnvSuite
gitjujutesting.FakeHomeSuite
oldJujuHome string
}
func (s *FakeJujuHomeSuite) SetUpSuite(c *gc.C) {
s.JujuOSEnvSuite.SetUpTest(c)
s.FakeHomeSuite.SetUpTest(c)
}
func (s *FakeJujuHomeSuite) TearDownSuite(c *gc.C) {
s.FakeHomeSuite.SetUpTest(c)
s.JujuOSEnvSuite.SetUpTest(c)
}
func (s *FakeJujuHomeSuite) SetUpTest(c *gc.C) {
s.JujuOSEnvSuite.SetUpTest(c)
s.FakeHomeSuite.SetUpTest(c)
jujuHome := gitjujutesting.HomePath(".juju")
err := os.Mkdir(jujuHome, 0700)
c.Assert(err, gc.IsNil)
s.oldJujuHome = osenv.SetJujuHome(jujuHome)
WriteEnvironments(c, SingleEnvConfig, SampleCertName)
}
func (s *FakeJujuHomeSuite) TearDownTest(c *gc.C) {
osenv.SetJujuHome(s.oldJujuHome)
s.FakeHomeSuite.TearDownTest(c)
s.JujuOSEnvSuite.TearDownTest(c)
}
// MakeSampleJujuHome sets up a sample Juju environment.
func MakeSampleJujuHome(c *gc.C) {
WriteEnvironments(c, SingleEnvConfig, SampleCertName)
}
// WriteEnvironments creates an environments file with envConfig and certs
// from certNames.
func WriteEnvironments(c *gc.C, envConfig string, certNames ...string) {
envs := osenv.JujuHomePath("environments.yaml")
err := ioutil.WriteFile(envs, []byte(envConfig), 0644)
c.Assert(err, gc.IsNil)
for _, name := range certNames {
err := ioutil.WriteFile(osenv.JujuHomePath(name+"-cert.pem"), []byte(CACert), 0600)
c.Assert(err, gc.IsNil)
err = ioutil.WriteFile(osenv.JujuHomePath(name+"-private-key.pem"), []byte(CAKey), 0600)
c.Assert(err, gc.IsNil)
}
}