Skip to content

Commit

Permalink
User needs ability to specify app version when creating schedule
Browse files Browse the repository at this point in the history
This update allows user to specify version.label=<version.number>
Tests were also updated because the original settings assumed that the
 appregistry was real instance instead of being mocked. Thus the find would always return null.
And in this case the tests returned a false positive.
Now that the mocks are in place it excercises all the code.
Also added explicit test if user does not set the version number.  Some of the tests do this,
but wanted an explicit test to verify this.

resolves #5705
  • Loading branch information
cppwfs committed Jun 6, 2024
1 parent 44f8757 commit d803f83
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 20 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright 2018-2023 the original author or authors.
* Copyright 2018-2024 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -321,7 +321,7 @@ public void schedule(
deployerDeploymentProperties,
commandLineArgs,
scheduleName,
getTaskResource(taskDefinitionName));
getTaskResource(taskDefinitionName, version));

launcher.getScheduler().schedule(scheduleRequest);

Expand Down Expand Up @@ -588,7 +588,7 @@ private static Map<String, String> extractAndQualifySchedulerProperties(Map<Stri
(fromWildcard, fromApp) -> fromApp));
}

protected Resource getTaskResource(String taskDefinitionName) {
protected Resource getTaskResource(String taskDefinitionName, String version) {
TaskDefinition taskDefinition = this.taskDefinitionRepository.findById(taskDefinitionName)
.orElseThrow(() -> new NoSuchTaskDefinitionException(taskDefinitionName));
AppRegistration appRegistration = null;
Expand All @@ -603,8 +603,14 @@ protected Resource getTaskResource(String taskDefinitionName) {
}
appRegistration = new AppRegistration(ComposedTaskRunnerConfigurationProperties.COMPOSED_TASK_RUNNER_NAME, ApplicationType.task, composedTaskUri);
} else {
appRegistration = this.registry.find(taskDefinition.getRegisteredAppName(),
if(version != null) {
appRegistration = this.registry.find(taskDefinition.getRegisteredAppName(),
ApplicationType.task, version);
}
else {
appRegistration = this.registry.find(taskDefinition.getRegisteredAppName(),
ApplicationType.task);
}
}
Assert.notNull(appRegistration, "Unknown task app: " + taskDefinition.getRegisteredAppName());
return this.registry.getAppResource(appRegistration);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright 2020-2021 the original author or authors.
* Copyright 2020-2024 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand All @@ -17,6 +17,7 @@
package org.springframework.cloud.dataflow.server.service.impl;

import java.net.URI;
import java.net.URISyntaxException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
Expand Down Expand Up @@ -75,6 +76,7 @@
import static org.junit.jupiter.api.Assertions.assertThrows;
import static org.mockito.ArgumentMatchers.any;
import static org.mockito.ArgumentMatchers.anyString;
import static org.mockito.ArgumentMatchers.eq;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
Expand Down Expand Up @@ -162,18 +164,13 @@ public class DefaultSchedulerServiceMultiplatformTests {

@BeforeEach
public void setup() throws Exception {
this.appRegistry.save("demo",
ApplicationType.task,
"1.0.0.",
new URI("file:src/test/resources/apps/foo-task"),
new URI("file:src/test/resources/apps/foo-task"),
null);
this.appRegistry.save("demo2",
ApplicationType.task,
"1.0.0",
new URI("file:src/test/resources/apps/foo-task"),
new URI("file:src/test/resources/apps/foo-task"),
null);

when(this.appRegistry.find(
eq("demo"), eq(ApplicationType.task), eq("1.0.0"))).thenReturn(new AppRegistration("demo",
ApplicationType.task, new URI("file:src/test/resources/apps/foo-task")));
when(this.appRegistry.find(
eq("demo2"), eq(ApplicationType.task), eq("1.0.0"))).thenReturn(new AppRegistration("demo2",
ApplicationType.task, new URI("file:src/test/resources/apps/foo-task")));

taskDefinitionRepository.save(new TaskDefinition(BASE_DEFINITION_NAME, "demo"));
taskDefinitionRepository.save(new TaskDefinition(CTR_DEFINITION_NAME, "demo && demo2"));
Expand All @@ -182,7 +179,7 @@ public void setup() throws Exception {
this.testProperties = new HashMap<>();
this.testProperties.put(DATA_FLOW_SCHEDULER_PREFIX + "AAAA", "* * * * *");
this.testProperties.put(DATA_FLOW_SCHEDULER_PREFIX + "EXPRESSION", "* * * * *");
this.testProperties.put("version." + BASE_DEFINITION_NAME, "boot2");
this.testProperties.put("version." + BASE_DEFINITION_NAME, "1.0.0");
this.resolvedProperties = new HashMap<>();
this.resolvedProperties.put(DEPLOYER_PREFIX + "AAAA", "* * * * *");
this.resolvedProperties.put(DEPLOYER_PREFIX + "EXPRESSION", "* * * * *");
Expand All @@ -200,6 +197,13 @@ public void testSchedule() {
verifyScheduleExistsInScheduler(createScheduleInfo(BASE_SCHEDULE_NAME));
}

@Test
public void testScheduleWithNoVersion() {
this.testProperties.remove("version." + BASE_DEFINITION_NAME);
schedulerService.schedule(BASE_SCHEDULE_NAME, BASE_DEFINITION_NAME, this.testProperties, this.commandLineArgs, KUBERNETES_PLATFORM);
verifyScheduleExistsInScheduler(createScheduleInfo(BASE_SCHEDULE_NAME));
}

@Test
public void testScheduleWithLongNameOnKuberenetesPlatform() {
assertThrows(IllegalArgumentException.class, () -> {
Expand Down Expand Up @@ -416,15 +420,19 @@ public void testScheduleWithCommandLineArguments() throws Exception {
}

@Test
public void testScheduleWithoutCommandLineArguments() {
public void testScheduleWithoutCommandLineArguments() throws URISyntaxException {
List<String> args = getCommandLineArguments(new ArrayList<>());
assertThatCommandLineArgsHaveNonDefaultArgs(args, "--app.timestamp");
}

private List<String> getCommandLineArguments(List<String> commandLineArguments) {
private List<String> getCommandLineArguments(List<String> commandLineArguments) throws URISyntaxException {
Scheduler mockScheduler = mock(SimpleTestScheduler.class);
TaskDefinitionRepository mockTaskDefinitionRepository = mock(TaskDefinitionRepository.class);
AppRegistryService mockAppRegistryService = mock(AppRegistryService.class);
when(mockAppRegistryService.find(
eq("timestamp"), eq(ApplicationType.task), eq("1.0.0"))).
thenReturn(new AppRegistration("timestamp", ApplicationType.task,
new URI("file:src/test/resources/apps/timestamp-task")));

AggregateExecutionSupport mockAggExecSupport = mock(AggregateExecutionSupport.class);
when(mockAggExecSupport.findSchemaVersionTarget(anyString(), anyString(), any(TaskDefinition.class)))
Expand Down

0 comments on commit d803f83

Please sign in to comment.