Polish GitHubMilestonePlugin
This commit is contained in:
parent
46723a601c
commit
0ec64c0843
|
@ -26,50 +26,41 @@ import org.springframework.gradle.github.RepositoryRef;
|
||||||
public class GitHubMilestonePlugin implements Plugin<Project> {
|
public class GitHubMilestonePlugin implements Plugin<Project> {
|
||||||
@Override
|
@Override
|
||||||
public void apply(Project project) {
|
public void apply(Project project) {
|
||||||
TaskProvider<GitHubMilestoneNextReleaseTask> nextReleaseMilestoneTask = project.getTasks().register("gitHubNextReleaseMilestone", GitHubMilestoneNextReleaseTask.class, new Action<GitHubMilestoneNextReleaseTask>() {
|
TaskProvider<GitHubMilestoneNextReleaseTask> nextReleaseMilestoneTask = project.getTasks().register("gitHubNextReleaseMilestone", GitHubMilestoneNextReleaseTask.class, (gitHubMilestoneNextReleaseTask) -> {
|
||||||
@Override
|
gitHubMilestoneNextReleaseTask.doNotTrackState("API call to GitHub needs to check for new milestones every time");
|
||||||
public void execute(GitHubMilestoneNextReleaseTask gitHubMilestoneNextReleaseTask) {
|
gitHubMilestoneNextReleaseTask.setGroup("Release");
|
||||||
gitHubMilestoneNextReleaseTask.doNotTrackState("API call to GitHub needs to check for new milestones every time");
|
gitHubMilestoneNextReleaseTask.setDescription("Calculates the next release version based on the current version and outputs it to a yaml file");
|
||||||
gitHubMilestoneNextReleaseTask.setGroup("Release");
|
gitHubMilestoneNextReleaseTask.getNextReleaseFile()
|
||||||
gitHubMilestoneNextReleaseTask.setDescription("Calculates the next release version based on the current version and outputs it to a yaml file");
|
.fileProvider(project.provider(() -> project.file("next-release.yml")));
|
||||||
gitHubMilestoneNextReleaseTask.getNextReleaseFile()
|
if (project.hasProperty("gitHubAccessToken")) {
|
||||||
.fileProvider(project.provider(() -> project.file("next-release.yml")));
|
gitHubMilestoneNextReleaseTask
|
||||||
if (project.hasProperty("gitHubAccessToken")) {
|
.setGitHubAccessToken((String) project.findProperty("gitHubAccessToken"));
|
||||||
gitHubMilestoneNextReleaseTask
|
}
|
||||||
.setGitHubAccessToken((String) project.findProperty("gitHubAccessToken"));
|
});
|
||||||
}
|
project.getTasks().register("gitHubCheckMilestoneHasNoOpenIssues", GitHubMilestoneHasNoOpenIssuesTask.class, (githubCheckMilestoneHasNoOpenIssues) -> {
|
||||||
}
|
githubCheckMilestoneHasNoOpenIssues.setGroup("Release");
|
||||||
});
|
githubCheckMilestoneHasNoOpenIssues.setDescription("Checks if there are any open issues for the specified repository and milestone");
|
||||||
project.getTasks().register("gitHubCheckMilestoneHasNoOpenIssues", GitHubMilestoneHasNoOpenIssuesTask.class, new Action<GitHubMilestoneHasNoOpenIssuesTask>() {
|
githubCheckMilestoneHasNoOpenIssues.getIsOpenIssuesFile().value(project.getLayout().getBuildDirectory().file("github/milestones/is-open-issues"));
|
||||||
@Override
|
githubCheckMilestoneHasNoOpenIssues.setMilestoneTitle((String) project.findProperty("nextVersion"));
|
||||||
public void execute(GitHubMilestoneHasNoOpenIssuesTask githubCheckMilestoneHasNoOpenIssues) {
|
if (!project.hasProperty("nextVersion")) {
|
||||||
githubCheckMilestoneHasNoOpenIssues.setGroup("Release");
|
githubCheckMilestoneHasNoOpenIssues.getNextVersionFile().convention(
|
||||||
githubCheckMilestoneHasNoOpenIssues.setDescription("Checks if there are any open issues for the specified repository and milestone");
|
nextReleaseMilestoneTask.flatMap(GitHubMilestoneNextReleaseTask::getNextReleaseFile));
|
||||||
githubCheckMilestoneHasNoOpenIssues.getIsOpenIssuesFile().value(project.getLayout().getBuildDirectory().file("github/milestones/is-open-issues"));
|
}
|
||||||
githubCheckMilestoneHasNoOpenIssues.setMilestoneTitle((String) project.findProperty("nextVersion"));
|
if (project.hasProperty("gitHubAccessToken")) {
|
||||||
if (!project.hasProperty("nextVersion")) {
|
githubCheckMilestoneHasNoOpenIssues.setGitHubAccessToken((String) project.findProperty("gitHubAccessToken"));
|
||||||
githubCheckMilestoneHasNoOpenIssues.getNextVersionFile().convention(
|
}
|
||||||
nextReleaseMilestoneTask.flatMap(GitHubMilestoneNextReleaseTask::getNextReleaseFile));
|
});
|
||||||
}
|
project.getTasks().register("gitHubCheckNextVersionDueToday", GitHubMilestoneNextVersionDueTodayTask.class, (gitHubMilestoneNextVersionDueTodayTask) -> {
|
||||||
if (project.hasProperty("gitHubAccessToken")) {
|
gitHubMilestoneNextVersionDueTodayTask.setGroup("Release");
|
||||||
githubCheckMilestoneHasNoOpenIssues.setGitHubAccessToken((String) project.findProperty("gitHubAccessToken"));
|
gitHubMilestoneNextVersionDueTodayTask.setDescription("Checks if the next release version is due today or past due, will fail if the next version is not due yet");
|
||||||
}
|
gitHubMilestoneNextVersionDueTodayTask.getIsDueTodayFile().value(project.getLayout().getBuildDirectory().file("github/milestones/is-due-today"));
|
||||||
|
gitHubMilestoneNextVersionDueTodayTask.getNextVersionFile().convention(
|
||||||
|
nextReleaseMilestoneTask.flatMap(GitHubMilestoneNextReleaseTask::getNextReleaseFile));
|
||||||
|
if (project.hasProperty("gitHubAccessToken")) {
|
||||||
|
gitHubMilestoneNextVersionDueTodayTask
|
||||||
|
.setGitHubAccessToken((String) project.findProperty("gitHubAccessToken"));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
project.getTasks().register("gitHubCheckNextVersionDueToday", GitHubMilestoneNextVersionDueTodayTask.class, new Action<GitHubMilestoneNextVersionDueTodayTask>() {
|
|
||||||
@Override
|
|
||||||
public void execute(GitHubMilestoneNextVersionDueTodayTask gitHubMilestoneNextVersionDueTodayTask) {
|
|
||||||
gitHubMilestoneNextVersionDueTodayTask.setGroup("Release");
|
|
||||||
gitHubMilestoneNextVersionDueTodayTask.setDescription("Checks if the next release version is due today or past due, will fail if the next version is not due yet");
|
|
||||||
gitHubMilestoneNextVersionDueTodayTask.getIsDueTodayFile().value(project.getLayout().getBuildDirectory().file("github/milestones/is-due-today"));
|
|
||||||
gitHubMilestoneNextVersionDueTodayTask.getNextVersionFile().convention(
|
|
||||||
nextReleaseMilestoneTask.flatMap(GitHubMilestoneNextReleaseTask::getNextReleaseFile));
|
|
||||||
if (project.hasProperty("gitHubAccessToken")) {
|
|
||||||
gitHubMilestoneNextVersionDueTodayTask
|
|
||||||
.setGitHubAccessToken((String) project.findProperty("gitHubAccessToken"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
project.getTasks().register("scheduleNextRelease", ScheduleNextReleaseTask.class, (scheduleNextRelease) -> {
|
project.getTasks().register("scheduleNextRelease", ScheduleNextReleaseTask.class, (scheduleNextRelease) -> {
|
||||||
scheduleNextRelease.doNotTrackState("API call to GitHub needs to check for new milestones every time");
|
scheduleNextRelease.doNotTrackState("API call to GitHub needs to check for new milestones every time");
|
||||||
scheduleNextRelease.setGroup("Release");
|
scheduleNextRelease.setGroup("Release");
|
||||||
|
|
Loading…
Reference in New Issue