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)