err := scheduler.BuildLatestInputs(logger, job, resources) Ω(err).ShouldNot(HaveOccurred()) Ω(fakePipelineDB.ScheduleBuildCallCount()).Should(Equal(1)) scheduledBuildID, jobConfig := fakePipelineDB.ScheduleBuildArgsForCall(0) Ω(scheduledBuildID).Should(Equal(128)) Ω(jobConfig).Should(Equal(job)) Ω(factory.CreateCallCount()).Should(Equal(1)) createJob, createResources, createInputs := factory.CreateArgsForCall(0) Ω(createJob).Should(Equal(job)) Ω(createResources).Should(Equal(resources)) Ω(createInputs).Should(Equal(newInputs)) Ω(fakePipelineDB.UseInputsForBuildCallCount()).Should(Equal(1)) usedBuildID, usedInputs := fakePipelineDB.UseInputsForBuildArgsForCall(0) Ω(usedBuildID).Should(Equal(128)) Ω(usedInputs).Should(Equal(newInputs)) Ω(fakeEngine.CreateBuildCallCount()).Should(Equal(1)) builtBuild, plan := fakeEngine.CreateBuildArgsForCall(0) Ω(builtBuild).Should(Equal(db.Build{ID: 128, Name: "42"})) Ω(plan).Should(Equal(createdPlan)) }) It("immediately resumes the build", func() { err := scheduler.BuildLatestInputs(logger, job, resources) Ω(err).ShouldNot(HaveOccurred()) Eventually(createdBuild.ResumeCallCount).Should(Equal(1)) })