It("logs a message stating that it is provisioning", func() {
			_, err := broker.Provision("my-service-id", brokerapi.ProvisionDetails{}, false)
			Expect(err).NotTo(HaveOccurred())
			Expect(logger.LogMessages()).To(ContainElement(ContainSubstring("Asked to provision a service: my-service-id")))
		})

		It("returns a dashboard url", func() {
			provisionedSpec, err := broker.Provision("my-service-id", brokerapi.ProvisionDetails{}, false)
			Expect(err).NotTo(HaveOccurred())
			Expect(provisionedSpec.DashboardURL).To(MatchRegexp(`https://%s/#/login/[a-zA-Z0-9\-]+/[a-zA-Z0-9\-]+`, config.Rabbitmq.ManagementDomain))
		})

		It("checks whether the host exist", func() {
			_, err := broker.Provision("my-service-id", brokerapi.ProvisionDetails{}, false)
			Expect(client.GetVhostCallCount()).To(Equal(1))
			Expect(client.GetVhostArgsForCall(0)).To(Equal("my-service-id"))
			Expect(err).NotTo(HaveOccurred())
		})

		Context("when the vhost exists", func() {
			It("returns ErrInstanceAlreadyExists error", func() {
				client.GetVhostReturns(&rabbithole.VhostInfo{}, nil)
				_, err := broker.Provision("my-service-id", brokerapi.ProvisionDetails{}, false)
				Expect(err).To(Equal(brokerapi.ErrInstanceAlreadyExists))
				Expect(client.PutVhostCallCount()).To(Equal(0))
			})
		})

		It("creates a vhost", func() {
			_, err := broker.Provision("my-service-id", brokerapi.ProvisionDetails{}, false)
			Expect(client.PutVhostCallCount()).To(Equal(1))