當前位置: 首頁>>代碼示例>>Golang>>正文


Golang Step.Cancel方法代碼示例

本文整理匯總了Golang中github.com/cloudfoundry-incubator/executor/depot/steps.Step.Cancel方法的典型用法代碼示例。如果您正苦於以下問題:Golang Step.Cancel方法的具體用法?Golang Step.Cancel怎麽用?Golang Step.Cancel使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在github.com/cloudfoundry-incubator/executor/depot/steps.Step的用法示例。


在下文中一共展示了Step.Cancel方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1:

			throttleChan = make(chan struct{}, numOfConcurrentMonitorSteps)
			doneChan = make(chan struct{}, 1)
			fakeStep = new(fakes.FakeStep)
			fakeStep.PerformStub = func() error {
				throttleChan <- struct{}{}
				<-doneChan
				return nil
			}
			checkFunc = func() steps.Step {
				return fakeStep
			}

		})

		AfterEach(func() {
			step.Cancel()
		})

		It("throttles concurrent health check", func() {
			for i := 0; i < 5; i++ {
				go step.Perform()
			}

			Consistently(fakeStep.PerformCallCount).Should(Equal(0))
			clock.Increment(501 * time.Millisecond)

			Eventually(func() int {
				return len(throttleChan)
			}).Should(Equal(numOfConcurrentMonitorSteps))
			Consistently(func() int {
				return len(throttleChan)
開發者ID:snowsnail,項目名稱:executor,代碼行數:31,代碼來源:monitor_step_test.go

示例2: runStepProcess

func (store *GardenStore) runStepProcess(
	logger lager.Logger,
	step steps.Step,
	hasStartedRunning <-chan struct{},
	gardenContainer garden.Container,
	guid string,
) {
	process := ifrit.Invoke(ifrit.RunFunc(func(signals <-chan os.Signal, ready chan<- struct{}) error {
		logger := logger.Session("run-step-process")
		logger.Info("started")
		defer logger.Info("finished")
		seqComplete := make(chan error)

		close(ready)

		go func() {
			seqComplete <- step.Perform()
		}()

		result := executor.ContainerRunResult{}

		toldToStop := false

	OUTER_LOOP:
		for {
			select {
			case <-signals:
				signals = nil
				toldToStop = true

				logger.Info("signaled")
				step.Cancel()

			case <-hasStartedRunning:
				hasStartedRunning = nil
				logger.Info("transitioning-to-running")
				err := store.transitionToRunning(logger, gardenContainer)
				if err != nil {
					logger.Error("failed-transitioning-to-running", err)
					result.Failed = true
					result.FailureReason = err.Error()
					break OUTER_LOOP
				}
				logger.Info("succeeded-transitioning-to-running")

			case err := <-seqComplete:
				if err == nil {
					logger.Info("step-finished-normally")
				} else if toldToStop {
					logger.Info("step-cancelled")
					result.Stopped = true
				} else {
					logger.Info("step-finished-with-error", lager.Data{"error": err.Error()})
					result.Failed = true
					result.FailureReason = err.Error()
				}

				break OUTER_LOOP
			}
		}

		logger.Info("transitioning-to-complete")
		err := store.transitionToComplete(logger, gardenContainer, result)
		if err != nil {
			logger.Error("failed-transitioning-to-complete", err)
			return nil
		}
		logger.Info("succeeded-transitioning-to-complete")

		return nil
	}))

	store.processesL.Lock()
	store.runningProcesses[guid] = process
	numProcesses := len(store.runningProcesses)
	store.processesL.Unlock()

	logger.Info("stored-step-process", lager.Data{"num-step-processes": numProcesses})
}
開發者ID:snowsnail,項目名稱:executor,代碼行數:79,代碼來源:garden_store.go


注:本文中的github.com/cloudfoundry-incubator/executor/depot/steps.Step.Cancel方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。