public void WaitForAll_with_longrunning_jobs()
        {
            //arrange
            var          job      = Helper.GetLongRunningJob(TimeSpan.FromMilliseconds(100)).Object;
            var          job1     = Helper.GetLongRunningJob(TimeSpan.FromMilliseconds(400)).Object;
            IWorkflowJob workflow = Builder.BuildWorkflow(Helper.GetJobId())
                                    .WithOption(WhenFailure.ContinueOn, ShareContext.Parent)
                                    .AddJob(job)
                                    .ThenAdd(job1)
                                    .ThenAdd(Helper.GetFakeJob().Object)
                                    .ThenAdd(Helper.GetFakeJob().Object)
                                    .ThenAdd(Helper.GetFakeJob().Object)
                                    .ThenAdd(Helper.GetFakeJob().Object)
                                    .ThenAdd(Helper.GetFakeJob().Object)
                                    .NothingElse().Create() as IWorkflowJob;

            //act
            IWorkflowRunner runner = new SequentialRunner().Start(workflow);

            runner.WaitForAll();

            //assert
            Assert.NotNull(runner);
            Assert.NotNull(runner.Current);
            Assert.Equal(workflow, runner.Current);
            Assert.True(runner.GetStatus(workflow.Id) == JobStatus.Completed);
        }
        public void GetResult_with_longrunning_jobs_failure()
        {
            //arrange
            IWorkflowJob workflow = Builder.BuildWorkflow(Helper.GetJobId())
                                    .WithOption(WhenFailure.StopOrExitJob, ShareContext.Parent)
                                    .AddJob(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                    .ThenAdd(Helper.GetWorkflowJob(noOfJobs: 5))
                                    .ThenAdd(Helper.GetFakeJob().Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromSeconds(2)).Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromMilliseconds(1)).Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromMilliseconds(1)).Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromMilliseconds(1)).Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromMilliseconds(1)).Object)
                                    .ThenAdd(Helper.GetFakeJob(status: JobStatus.CompletedWithError).Object)
                                    .ThenAdd(Helper.GetFakeJob().Object)
                                    .NothingElse().Create() as IWorkflowJob;

            //act
            IWorkflowRunner runner = new SequentialRunner().Start(workflow);

            runner.WaitForAll();
            var actual = runner.GetResult(workflow.Id);

            //assert
            Assert.NotNull(runner);
            Assert.NotNull(runner.Current);
            Assert.Equal(workflow, runner.Current);
            Assert.True(actual.Status == JobStatus.CompletedWithError);
            Assert.NotNull(actual.Error);
        }
        public void SoftStop_with_longrunning_jobs()
        {
            //arrange
            var          job             = Helper.GetFakeJob().Object;
            var          job_not_started = Helper.GetLongRunningJob(TimeSpan.FromMilliseconds(5000)).Object;
            IWorkflowJob workflow        = Builder.BuildWorkflow(Helper.GetJobId())
                                           .WithOption(WhenFailure.ContinueOn, ShareContext.Parent)
                                           .AddJob(job)
                                           .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                           .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                           .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                           .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                           .ThenAdd(job_not_started)
                                           .NothingElse().Create() as IWorkflowJob;

            //act
            IWorkflowRunner runner = new SequentialRunner().Start(workflow);

            runner.SoftStop();
            Thread.Sleep(2500);
            var actual = runner.GetStatus(job.Id);

            //assert
            Assert.NotNull(runner);
            Assert.NotNull(runner.Current);
            Assert.Equal(workflow, runner.Current);
            Assert.True(runner.GetStatus(workflow.Id) == JobStatus.Stoped);
            Assert.True(JobStatus.Completed == actual);
            Assert.True(JobStatus.NotStarted == runner.GetStatus(job_not_started.Id));
        }
        public void GetStatus_returns_stopped()
        {
            //arrange
            IWorkflowJob workflow = Builder.BuildWorkflow(Helper.GetJobId())
                                    .WithOption(WhenFailure.StopOrExitJob, ShareContext.Parent)
                                    .AddJob(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                    .ThenAdd(Helper.GetWorkflowJob(noOfJobs: 5))
                                    .ThenAdd(Helper.GetFakeJob().Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromSeconds(1)).Object)
                                    .ThenAdd(Helper.GetLongRunningJob(TimeSpan.FromMilliseconds(10000)).Object)
                                    .ThenAdd(Helper.GetFakeJob().Object)
                                    .NothingElse().Create() as IWorkflowJob;

            //act
            IWorkflowRunner runner = new SequentialRunner().Start(workflow);

            runner.SoftStop();
            Thread.Sleep(2500);
            var actual = runner.GetStatus(workflow.Id);

            //assert
            Assert.NotNull(runner);
            Assert.NotNull(runner.Current);
            Assert.Equal(workflow, runner.Current);
            Assert.True(actual == JobStatus.Stoped);
        }
        public void Start_with_nested_longrunning_jobs_has_random_failures()
        {
            //arrange
            var workflow = Helper.GetNestedWorkflowWithRandomStatus(TimeSpan.FromMilliseconds(1000), 10);

            //act
            IWorkflowRunner runner = new SequentialRunner().Start(workflow);

            //assert
            Assert.NotNull(runner);
            Assert.NotNull(runner.Current);
            Assert.Equal(workflow, runner.Current);
            Assert.True(runner.GetStatus(workflow.Id) == JobStatus.Running);
        }
        public void Start_with_nested_longrunning_jobs()
        {
            //arrange
            var workflow = Helper.GetNestedWorkflow(5);

            //act
            IWorkflowRunner runner = new SequentialRunner().Start(workflow);

            //assert
            Assert.NotNull(runner);
            Assert.NotNull(runner.Current);
            Assert.Equal(workflow, runner.Current);
            Assert.True(runner.GetStatus(workflow.Id) == JobStatus.Running);
        }
示例#7
0
        static void Main(string[] args)
        {
            Console.WriteLine("Running sequential workflow.");
            SampleDocumentApprovalWorkflow wf1 = new SampleDocumentApprovalWorkflow();
            SequentialRunner sequentialRunner  = new SequentialRunner();

            sequentialRunner.AddWorkflow(wf1);

            Workflow.WorkflowEngine.Execute(sequentialRunner);
            Console.WriteLine("Sequential workflow finished.");

            /*Console.WriteLine("Running repeated workflow.");
             * SampleDocumentApprovalWorkflow wf2 = new SampleDocumentApprovalWorkflow();
             * RepeatedRunner repeatedRunner = new RepeatedRunner(3);
             * repeatedRunner.AddWorkflow(wf2);
             *
             * WorkflowEngine.Execute(repeatedRunner);
             * Console.WriteLine("Repeated workflow finished.");*/
        }
        public void GetStatus_returns_failure()
        {
            //arrange
            IWorkflowJob workflow = Builder.BuildWorkflow(Helper.GetJobId())
                                    .WithOption(WhenFailure.StopOrExitJob, ShareContext.Parent)
                                    .AddJob(Helper.GetFakeJob().Object)
                                    .ThenAdd(Helper.GetWorkflowJob(noOfJobs: 2))
                                    .ThenAdd(Helper.GetFakeJob(status: JobStatus.CompletedWithError).Object)
                                    .ThenAdd(Helper.GetWorkflowJob(noOfJobs: 5))
                                    .ThenAdd(Helper.GetFakeJob().Object)
                                    .NothingElse().Create() as IWorkflowJob;

            //act
            IWorkflowRunner runner = new SequentialRunner().Start(workflow);

            runner.WaitForAll();
            var actual = runner.GetStatus(workflow.Id);

            //assert
            Assert.NotNull(runner);
            Assert.NotNull(runner.Current);
            Assert.Equal(workflow, runner.Current);
            Assert.True(actual == JobStatus.CompletedWithError);
        }