From ad0755584a4dce9422c5e37d767d366bc5c5eeb2 Mon Sep 17 00:00:00 2001 From: adamrtalbot <12817534+adamrtalbot@users.noreply.github.com> Date: Thu, 5 Dec 2024 16:24:35 +0000 Subject: [PATCH] Can't run gradle on the train so I'm just gonna send it Signed-off-by: adamrtalbot <12817534+adamrtalbot@users.noreply.github.com> --- .../cloud/azure/batch/AzBatchService.groovy | 4 +- .../azure/batch/AzBatchTaskHandler.groovy | 7 ++++ .../cloud/azure/config/AzBatchOpts.groovy | 2 + .../azure/batch/AzBatchTaskHandlerTest.groovy | 39 +++++++++++++++++++ 4 files changed, 50 insertions(+), 2 deletions(-) diff --git a/plugins/nf-azure/src/main/nextflow/cloud/azure/batch/AzBatchService.groovy b/plugins/nf-azure/src/main/nextflow/cloud/azure/batch/AzBatchService.groovy index e8f6415a59..66ae83723f 100644 --- a/plugins/nf-azure/src/main/nextflow/cloud/azure/batch/AzBatchService.groovy +++ b/plugins/nf-azure/src/main/nextflow/cloud/azure/batch/AzBatchService.groovy @@ -392,8 +392,8 @@ class AzBatchService implements Closeable { throw new IllegalArgumentException("Missing Azure Blob storage SAS token") final container = task.getContainer() - if( !container ) - log.warn "Missing container image for process: $task.name" + if( !container && config.batch().requireContainer ) + throw new IllegalArgumentException("Missing container image for process: $task.name\nYou can disable this behaviour setting `azure.batch.requireContainer=false` in the nextflow config file") final taskId = "nf-${task.hash.toString()}" // get the pool config final pool = getPoolSpec(poolId) diff --git a/plugins/nf-azure/src/main/nextflow/cloud/azure/batch/AzBatchTaskHandler.groovy b/plugins/nf-azure/src/main/nextflow/cloud/azure/batch/AzBatchTaskHandler.groovy index 50832f2129..594577b43c 100644 --- a/plugins/nf-azure/src/main/nextflow/cloud/azure/batch/AzBatchTaskHandler.groovy +++ b/plugins/nf-azure/src/main/nextflow/cloud/azure/batch/AzBatchTaskHandler.groovy @@ -60,6 +60,7 @@ class AzBatchTaskHandler extends TaskHandler implements FusionAwareTask { this.outputFile = task.workDir.resolve(TaskRun.CMD_OUTFILE) this.errorFile = task.workDir.resolve(TaskRun.CMD_ERRFILE) this.exitFile = task.workDir.resolve(TaskRun.CMD_EXIT) + validateConfiguration() } /** only for testing purpose - DO NOT USE */ @@ -69,6 +70,12 @@ class AzBatchTaskHandler extends TaskHandler implements FusionAwareTask { return executor.batchService } + void validateConfiguration() { + if (!task.container && config.batch().requireContainer ) { + throw new ProcessUnrecoverableException("No container image specified for process $task.name -- Either specify the container to use in the process definition or with 'process.container' value in your config. You can disable this behaviour setting `azure.batch.requireContainer=false` in the nextflow config file") + } + } + protected BashWrapperBuilder createBashWrapper() { fusionEnabled() ? fusionLauncher() diff --git a/plugins/nf-azure/src/main/nextflow/cloud/azure/config/AzBatchOpts.groovy b/plugins/nf-azure/src/main/nextflow/cloud/azure/config/AzBatchOpts.groovy index 358c70413d..efb68b51c0 100644 --- a/plugins/nf-azure/src/main/nextflow/cloud/azure/config/AzBatchOpts.groovy +++ b/plugins/nf-azure/src/main/nextflow/cloud/azure/config/AzBatchOpts.groovy @@ -54,6 +54,7 @@ class AzBatchOpts implements CloudTransferOptions { Boolean deleteJobsOnCompletion Boolean deletePoolsOnCompletion Boolean deleteTasksOnCompletion + Boolean requireContainer CopyToolInstallMode copyToolInstallMode Map pools @@ -67,6 +68,7 @@ class AzBatchOpts implements CloudTransferOptions { location = config.location autoPoolMode = config.autoPoolMode allowPoolCreation = config.allowPoolCreation + requireContainer = config.requireContainer ?: true terminateJobsOnCompletion = config.terminateJobsOnCompletion != Boolean.FALSE deleteJobsOnCompletion = config.deleteJobsOnCompletion deletePoolsOnCompletion = config.deletePoolsOnCompletion diff --git a/plugins/nf-azure/src/test/nextflow/cloud/azure/batch/AzBatchTaskHandlerTest.groovy b/plugins/nf-azure/src/test/nextflow/cloud/azure/batch/AzBatchTaskHandlerTest.groovy index 4d2aa5c3e0..70864d7c95 100644 --- a/plugins/nf-azure/src/test/nextflow/cloud/azure/batch/AzBatchTaskHandlerTest.groovy +++ b/plugins/nf-azure/src/test/nextflow/cloud/azure/batch/AzBatchTaskHandlerTest.groovy @@ -18,6 +18,45 @@ import spock.lang.Specification */ class AzBatchTaskHandlerTest extends Specification { + def 'should validate config' () { + when: + def task = Mock(TaskRun) { getName() >> 'foo'; } + and: + new AzBatchTaskHandler(task: task) + .validateConfiguration() + then: + def e = thrown(ProcessUnrecoverableException) + e.message.startsWith('No container image specified for process foo') + + + when: + task = Mock(TaskRun) { getName() >> 'foo'; getContainer() >> 'ubuntu' } + and: + new AzBatchTaskHandler(task: task) + .validateConfiguration() + then: + noExceptionThrown() + } + + def 'should ignore missing container if disabled' () { + when: + def task = Mock(TaskRun) { getName() >> 'foo'; } + and: + new AzBatchTaskHandler(task: task, config: new AzConfig([batch: [requireContainer: false]])) + .validateConfiguration() + then: + noExceptionThrown() + + + when: + task = Mock(TaskRun) { getName() >> 'foo'; getContainer() >> 'ubuntu' } + and: + new AzBatchTaskHandler(task: task) + .validateConfiguration() + then: + noExceptionThrown() + } + def 'should submit task' () { given: def builder = Mock(BashWrapperBuilder)