本文整理匯總了Golang中github.com/cloudfoundry/bosh-init/config.StemcellRepo.Save方法的典型用法代碼示例。如果您正苦於以下問題:Golang StemcellRepo.Save方法的具體用法?Golang StemcellRepo.Save怎麽用?Golang StemcellRepo.Save使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/cloudfoundry/bosh-init/config.StemcellRepo
的用法示例。
在下文中一共展示了StemcellRepo.Save方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1:
It("ignores DiskNotFound errors", func() {
mockCloud.EXPECT().DeleteDisk("fake-disk-cid").Return(bicloud.NewCPIError("delete_disk", bicloud.CmdError{
Type: bicloud.DiskNotFoundError,
Message: "fake-disk-not-found-message",
}))
err := deployment.Delete(fakeStage)
Expect(err).ToNot(HaveOccurred())
})
})
})
Context("when a current stemcell exists", func() {
BeforeEach(func() {
deploymentStateService.Save(biconfig.DeploymentState{})
stemcellRecord, err := stemcellRepo.Save("fake-stemcell-name", "fake-stemcell-version", "fake-stemcell-cid")
Expect(err).ToNot(HaveOccurred())
stemcellRepo.UpdateCurrent(stemcellRecord.ID)
})
It("deletes the stemcell", func() {
mockCloud.EXPECT().DeleteStemcell("fake-stemcell-cid")
err := deployment.Delete(fakeStage)
Expect(err).ToNot(HaveOccurred())
})
Context("when current stemcell has been deleted manually (outside of bosh)", func() {
It("deletes the stemcell (to ensure related resources are released by the CPI)", func() {
mockCloud.EXPECT().DeleteStemcell("fake-stemcell-cid")
示例2:
})
Context("no orphan disk or stemcell records exist", func() {
var (
currentDiskRecord biconfig.DiskRecord
currentStemcellRecord biconfig.StemcellRecord
)
BeforeEach(func() {
var err error
currentDiskRecord, err = diskRepo.Save("fake-disk-cid", 100, nil)
Expect(err).ToNot(HaveOccurred())
err = diskRepo.UpdateCurrent(currentDiskRecord.ID)
Expect(err).ToNot(HaveOccurred())
currentStemcellRecord, err = stemcellRepo.Save("fake-stemcell-name", "fake-stemcell-version", "fake-stemcell-cid")
Expect(err).ToNot(HaveOccurred())
err = stemcellRepo.UpdateCurrent(currentStemcellRecord.ID)
Expect(err).ToNot(HaveOccurred())
})
It("does not delete anything", func() {
err := deploymentManager.Cleanup(fakeStage)
Expect(err).ToNot(HaveOccurred())
diskRecord, found, err := diskRepo.FindCurrent()
Expect(err).ToNot(HaveOccurred())
Expect(found).To(BeTrue())
Expect(diskRecord).To(Equal(currentDiskRecord))
stemcellRecord, found, err := stemcellRepo.FindCurrent()
示例3:
Expect(err).To(HaveOccurred())
Expect(err.Error()).To(ContainSubstring("fake-save-error"))
Expect(fakeStage.PerformCalls[0].Name).To(Equal("Uploading stemcell 'fake-stemcell-name/fake-stemcell-version'"))
Expect(fakeStage.PerformCalls[0].Error).To(HaveOccurred())
Expect(fakeStage.PerformCalls[0].Error.Error()).To(MatchRegexp("Finding existing stemcell record in repo: .*fake-save-error.*"))
})
Context("when the stemcell record exists in the stemcellRepo (having been previously uploaded)", func() {
var (
foundStemcellRecord biconfig.StemcellRecord
)
BeforeEach(func() {
var err error
foundStemcellRecord, err = stemcellRepo.Save("fake-stemcell-name", "fake-stemcell-version", "fake-existing-cid")
Expect(err).ToNot(HaveOccurred())
})
It("returns the existing cloud stemcell", func() {
stemcell, err := manager.Upload(expectedExtractedStemcell, fakeStage)
Expect(err).ToNot(HaveOccurred())
foundStemcell := NewCloudStemcell(foundStemcellRecord, stemcellRepo, fakeCloud)
Expect(stemcell).To(Equal(foundStemcell))
})
It("does not re-upload the stemcell to the infrastructure", func() {
_, err := manager.Upload(expectedExtractedStemcell, fakeStage)
Expect(err).ToNot(HaveOccurred())
Expect(fakeCloud.CreateStemcellInputs).To(HaveLen(0))
})