private static async Task <(string newTriggerName, Workflow newTriggerContent)> ProcessAbortRequestAsync(Guid workflowId, ICromwellApiClient cromwellApiClient) { string newTriggerName = null; Workflow newTriggerContent = null; var loggerFactory = new Mock <ILoggerFactory>(); var azureStorage = new Mock <IAzureStorage>(); var repository = new Mock <IRepository <TesTask> >(); loggerFactory .Setup(f => f.CreateLogger(It.IsAny <string>())) .Returns(new Mock <ILogger>().Object); azureStorage .Setup(az => az.GetWorkflowsByStateAsync(WorkflowState.Abort)) .Returns(Task.FromResult(new[] { new TriggerFile { Uri = $"http://tempuri.org/workflows/abort/{workflowId}.json", ContainerName = "workflows", Name = $"abort/{workflowId}.json", LastModified = DateTimeOffset.UtcNow } }.AsEnumerable())); azureStorage .Setup(az => az.DownloadBlobTextAsync(It.IsAny <string>(), $"abort/{workflowId}.json")) .Returns(Task.FromResult(string.Empty)); azureStorage .Setup(az => az.UploadFileTextAsync(It.IsAny <string>(), "workflows", It.IsAny <string>())) .Callback((string content, string container, string blobName) => { newTriggerName = blobName; newTriggerContent = content is not null ? JsonConvert.DeserializeObject <Workflow>(content) : null; }); var cromwellOnAzureEnvironment = new CromwellOnAzureEnvironment(loggerFactory.Object, azureStorage.Object, cromwellApiClient, repository.Object, Enumerable.Repeat(azureStorage.Object, 1)); await cromwellOnAzureEnvironment.ProcessAndAbortWorkflowsAsync(); return(newTriggerName, newTriggerContent); }
public async Task NewWorkflowsThatFailToParseAsJsonAreAnotatedAndMovedToFailedSubdirectory() { const string badJason = @"{'WorkflowUrl': 'https://tempuri.org/inputs/bam-to-unmapped-bams.wdl' 'WorkflowInputsUrl': 'https://tempuri.org/inputs/bam-to-unmapped-bams.inputs.json'}"; const string errPrefix = "\nError(s): "; var cromwellApiClient = new Mock <ICromwellApiClient>(); var triesToPost = false; cromwellApiClient .Setup(ac => ac.PostWorkflowAsync(It.IsAny <string>(), It.IsAny <byte[]>(), It.IsAny <List <string> >(), It.IsAny <List <byte[]> >(), It.IsAny <string>(), It.IsAny <byte[]>(), It.IsAny <string>(), It.IsAny <byte[]>())) .Callback(() => triesToPost = true) .Throws(new Exception("Should never get here.")); string newTriggerName = null; string newTriggerContent = null; var loggerFactory = new Mock <ILoggerFactory>(); var azureStorage = new Mock <IAzureStorage>(); var repository = new Mock <IRepository <TesTask> >(); loggerFactory .Setup(f => f.CreateLogger(It.IsAny <string>())) .Returns(new Mock <ILogger>().Object); azureStorage .Setup(az => az.GetWorkflowsByStateAsync(WorkflowState.New)) .Returns(Task.FromResult(new[] { new TriggerFile { Uri = $"http://tempuri.org/workflows/new/Sample.json", ContainerName = "workflows", Name = $"new/Sample.json", LastModified = DateTimeOffset.UtcNow } }.AsEnumerable())); azureStorage .Setup(az => az.DownloadBlobTextAsync(It.IsAny <string>(), $"new/Sample.json")) .Returns(Task.FromResult(badJason)); azureStorage .Setup(az => az.UploadFileTextAsync(It.IsAny <string>(), "workflows", It.IsAny <string>())) .Callback((string content, string container, string blobName) => { newTriggerName = blobName; newTriggerContent = content; }); var deleted = false; azureStorage .Setup(az => az.DeleteBlobIfExistsAsync(It.IsAny <string>(), $"new/Sample.json")) .Callback(() => deleted = true); var cromwellOnAzureEnvironment = new CromwellOnAzureEnvironment(loggerFactory.Object, azureStorage.Object, cromwellApiClient.Object, repository.Object, Enumerable.Repeat(azureStorage.Object, 1)); await cromwellOnAzureEnvironment.ProcessAndAbortWorkflowsAsync(); Assert.IsTrue(newTriggerName.StartsWith("failed/")); Assert.IsTrue(deleted); Assert.IsFalse(triesToPost); Assert.IsTrue((badJason + errPrefix).Length < newTriggerContent.Length); Assert.IsTrue(newTriggerContent.StartsWith(badJason + errPrefix)); }