logger               *lagertest.TestLogger
	)

	BeforeEach(func() {
		config = defaultConfig()
		client = new(fakes.FakeAPIClient)
		credentialsGenerator = new(fakes.FakeCredentialsGenerator)
		logger = lagertest.NewTestLogger("test")
		broker = rabbitbroker.New(config, client, credentialsGenerator, logger, nil)
	})

	Context("Provision", func() {

		BeforeEach(func() {
			client.GetVhostReturns(nil, fmt.Errorf("vhost does not exist"))
			client.PutVhostReturns(&http.Response{StatusCode: http.StatusNoContent}, nil)
			client.DeleteVhostReturns(&http.Response{StatusCode: http.StatusNoContent}, nil)
			client.UpdatePermissionsInReturns(&http.Response{StatusCode: http.StatusNoContent}, nil)
			client.PutPolicyReturns(&http.Response{StatusCode: http.StatusNoContent}, nil)
			client.PutUserReturns(&http.Response{StatusCode: http.StatusNoContent}, nil)
			client.GetUserReturns(nil, fmt.Errorf(rabbitbroker.NotFoundIdentifier))

			credentialsGenerator.GenerateReturns(rabbitbroker.Credentials{
				Username: "******",
				Password: "******",
			})
		})

		It("returns no error", func() {
			_, err := broker.Provision("my-service-id", brokerapi.ProvisionDetails{}, false)
			Expect(err).NotTo(HaveOccurred())