-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathpath_config_rotate_test.go
109 lines (96 loc) · 3.39 KB
/
path_config_rotate_test.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
package artifactory
import (
"testing"
"github.com/hashicorp/vault/sdk/logical"
"github.com/stretchr/testify/assert"
)
func TestAcceptanceBackend_PathRotate(t *testing.T) {
if !runAcceptanceTests {
t.SkipNow()
}
// Unconfigured Test
unconfigured, err := newAcceptanceTestEnv()
if err != nil {
t.Fatal(err)
}
t.Run("unconfigured", unconfigured.PathConfigRotateUnconfigured)
//Configured Tests
e := NewConfiguredAcceptanceTestEnv(t)
t.Run("zeroLengthUsername", e.PathConfigRotateZeroLengthUsername)
t.Run("empty", e.PathConfigRotateEmpty)
t.Run("withDetails", e.PathConfigRotateWithDetails)
// Cleanup Token
e.Cleanup(t)
// Failure Tests
t.Run("MissingAccessTokenErr", e.PathConfigRotateMissingAccessTokenErr)
t.Run("CreateTokenErr", e.PathConfigRotateCreateTokenErr)
t.Run("badAccessToken", e.PathConfigRotateBadAccessToken)
}
func (e *accTestEnv) PathConfigRotateUnconfigured(t *testing.T) {
resp, err := e.update("config/rotate", testData{})
assert.Contains(t, resp.Data["error"], "backend not configured")
assert.NoError(t, err)
}
func (e *accTestEnv) PathConfigRotateEmpty(t *testing.T) {
before := e.ReadConfigAdmin(t)
e.UpdateConfigRotate(t, testData{}) // empty write
after := e.ReadConfigAdmin(t)
assert.NotEqual(t, before["access_token_sha256sum"], after["access_token_sha256"])
}
func (e *accTestEnv) PathConfigRotateZeroLengthUsername(t *testing.T) {
e.UpdateConfigRotate(t, testData{
"username": "",
}) // empty write
after := e.ReadConfigAdmin(t)
assert.Equal(t, "admin-vault-secrets-artifactory", after["username"])
}
func (e *accTestEnv) PathConfigRotateWithDetails(t *testing.T) {
newUsername := "vault-acceptance-test-changed"
description := "Artifactory Secrets Engine Accceptance Test"
before := e.ReadConfigAdmin(t)
e.UpdateConfigRotate(t, testData{
"username": newUsername,
"description": description,
})
after := e.ReadConfigAdmin(t)
assert.NotEqual(t, before["access_token_sha256sum"], after["access_token_sha256"])
assert.Equal(t, newUsername, after["username"])
// Not testing Description, because it is not returned in the token (yet)
}
func (e *accTestEnv) PathConfigRotateMissingAccessTokenErr(t *testing.T) {
e.UpdateConfigAdmin(t, testData{
"access_token": "",
"url": e.URL,
})
resp, err := e.update("config/rotate", testData{})
assert.NotNil(t, resp)
assert.Contains(t, resp.Data["error"], "missing access token")
assert.ErrorContains(t, err, "missing access token")
}
func (e *accTestEnv) PathConfigRotateCreateTokenErr(t *testing.T) {
tokenId, accessToken := e.createNewNonAdminTestToken(t)
e.UpdateConfigAdmin(t, testData{
"access_token": accessToken,
"url": e.URL,
})
resp, err := e.update("config/rotate", testData{})
assert.NotNil(t, resp)
assert.Contains(t, resp.Data["error"], "error creating new access token")
assert.ErrorContains(t, err, "could not create access token")
e.revokeTestToken(t, tokenId)
}
func (e *accTestEnv) PathConfigRotateBadAccessToken(t *testing.T) {
// Forcibly set a bad token
entry, err := logical.StorageEntryJSON(configAdminPath, adminConfiguration{
baseConfiguration: baseConfiguration{
AccessToken: "bogus.token",
ArtifactoryURL: e.URL,
},
})
assert.NoError(t, err)
err = e.Storage.Put(e.Context, entry)
assert.NoError(t, err)
resp, err := e.update("config/rotate", testData{})
assert.Contains(t, resp.Data["error"], "error parsing existing access token")
assert.Error(t, err)
}