forked from cloudfoundry/cli
-
Notifications
You must be signed in to change notification settings - Fork 0
/
token_refresh.go
117 lines (103 loc) · 3.79 KB
/
token_refresh.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
package isolated
import (
"fmt"
"code.cloudfoundry.org/cli/integration/helpers"
"code.cloudfoundry.org/cli/util/configv3"
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
. "github.com/onsi/gomega/gbytes"
. "github.com/onsi/gomega/gexec"
)
var _ = Describe("Token Refreshing", func() {
Describe("password grant type", func() {
BeforeEach(func() {
helpers.LoginCF()
})
Context("when the token is invalid", func() {
BeforeEach(func() {
helpers.SetConfig(func(config *configv3.Config) {
config.ConfigFile.AccessToken = helpers.InvalidAccessToken()
config.ConfigFile.TargetedOrganization.GUID = "fake-org"
config.ConfigFile.TargetedSpace.GUID = "fake-space"
})
})
Context("when running a v2 command", func() {
Context("when the cloud controller client encounters an invalid token response", func() {
It("refreshes the token", func() {
session := helpers.CF("unbind-service", "app", "service")
Eventually(session.Err).Should(Say("App app not found"))
Eventually(session).Should(Exit(1))
})
})
Context("when the UAA client encounters an invalid token response", func() {
It("refreshes the token", func() {
username, _ := helpers.GetCredentials()
session := helpers.CF("create-user", username, helpers.NewPassword())
Eventually(session.Err).Should(Say(fmt.Sprintf("user %s already exists", username)))
Eventually(session).Should(Exit(0))
})
})
})
Context("when running a v3 command", func() {
Context("when the cloud controller client encounters an invalid token response", func() {
It("refreshes the token", func() {
session := helpers.CF("-v", "run-task", "app", "'echo banana'")
Eventually(session.Err).Should(Say("App app not found"))
Eventually(session).Should(Exit(1))
})
})
})
})
})
Describe("client grant type", func() {
BeforeEach(func() {
helpers.LoginCFWithClientCredentials()
})
Context("when the token is invalid", func() {
BeforeEach(func() {
helpers.SetConfig(func(config *configv3.Config) {
config.ConfigFile.AccessToken = helpers.InvalidAccessToken()
config.ConfigFile.TargetedOrganization.GUID = "fake-org"
config.ConfigFile.TargetedSpace.GUID = "fake-space"
})
})
Context("when running a v2 refactored command", func() {
Context("when the cloud controller client encounters an invalid token response", func() {
It("refreshes the token", func() {
session := helpers.CF("unbind-service", "app", "service")
Eventually(session.Err).Should(Say("App app not found"))
Eventually(session).Should(Exit(1))
})
})
Context("when the UAA client encounters an invalid token response", func() {
It("refreshes the token", func() {
username := helpers.NewUsername()
session := helpers.CF("create-user", username, helpers.NewPassword())
Eventually(session).Should(Say("OK"))
Eventually(session).Should(Exit(0))
})
})
})
Context("when running a v2 unrefactored command", func() {
Context("when the cloud controller client encounters an invalid token response", func() {
It("refreshes the token", func() {
username, _ := helpers.GetCredentials()
session := helpers.CF("quotas")
Eventually(session).Should(Say("Getting quotas as %s", username))
Eventually(session).Should(Say("OK"))
Eventually(session).Should(Exit(0))
})
})
})
Context("when running a v3 command", func() {
Context("when the cloud controller client encounters an invalid token response", func() {
It("refreshes the token", func() {
session := helpers.CF("-v", "run-task", "app", "'echo banana'")
Eventually(session.Err).Should(Say("App app not found"))
Eventually(session).Should(Exit(1))
})
})
})
})
})
})