|
11 | 11 |
|
12 | 12 | import org.elasticsearch.gradle.VersionProperties; |
13 | 13 | import org.elasticsearch.gradle.internal.transport.TransportVersionUtils.MajorMinor; |
| 14 | +import org.elasticsearch.gradle.internal.transport.TransportVersionUtils.TransportVersionDefinition; |
14 | 15 | import org.gradle.api.DefaultTask; |
15 | | -import org.gradle.api.file.RegularFileProperty; |
| 16 | +import org.gradle.api.file.DirectoryProperty; |
16 | 17 | import org.gradle.api.provider.ListProperty; |
17 | 18 | import org.gradle.api.provider.Property; |
18 | 19 | import org.gradle.api.tasks.Input; |
|
26 | 27 | import java.util.ArrayList; |
27 | 28 | import java.util.Collections; |
28 | 29 | import java.util.Comparator; |
| 30 | +import java.util.HashSet; |
29 | 31 | import java.util.List; |
30 | 32 | import java.util.Objects; |
| 33 | +import java.util.Set; |
31 | 34 |
|
32 | 35 | import static org.elasticsearch.gradle.internal.transport.TransportVersionUtils.IdIncrement.PATCH; |
33 | 36 | import static org.elasticsearch.gradle.internal.transport.TransportVersionUtils.IdIncrement.SERVER; |
|
38 | 41 | import static org.elasticsearch.gradle.internal.transport.TransportVersionUtils.writeDefinitionFile; |
39 | 42 |
|
40 | 43 | /** |
41 | | - * This task generates TransportVersionSetData data files that contain information about transport versions. These files |
42 | | - * are added to the server project's resource directory at `server/src/main/resources/org/elasticsearch/transport/`. |
43 | | - * They have the following format: |
44 | | - * <pre> |
45 | | - * Filename: my-transport-version-set.json // Must be the same as the name of the transport version set. |
46 | | - * { |
47 | | - * "name": "my-transport-version-set", // The name of the transport version set used for reference in the code. |
48 | | - * "ids": [ |
49 | | - * 9109000, // The transport version introduced to the main branch. |
50 | | - * 8841059 // The transport version backported to a previous release branch. |
51 | | - * ] |
52 | | - * } |
53 | | - * </pre> |
| 44 | + * This task generates transport version definition files. These files |
| 45 | + * are runtime resources that TransportVersion loads statically. |
| 46 | + * They contain a comma separated list of integer ids. Each file is named the same |
| 47 | + * as the transport version name itself (with the .csv suffix). |
54 | 48 | */ |
55 | | -public abstract class GenerateTransportVersionDataTask extends DefaultTask { |
| 49 | +public abstract class GenerateTransportVersionDefinitionTask extends DefaultTask { |
56 | 50 |
|
57 | 51 | /** |
58 | 52 | * Specifies the directory in which contains all TransportVersionSet data files. |
59 | 53 | * |
60 | 54 | * @return |
61 | 55 | */ |
62 | 56 | @InputDirectory |
63 | | - public abstract RegularFileProperty getDataFileDirectory(); // The plugin should always set this, not optional |
| 57 | + public abstract DirectoryProperty getTransportResourcesDirectory(); // The plugin should always set this, not optional |
64 | 58 |
|
| 59 | + |
| 60 | + // assumption: this task is always run on main, so we can determine the name by diffing with main and looking for new files added in the definition directory |
65 | 61 | /** |
66 | 62 | * Used to set the name of the TransportVersionSet for which a data file will be generated. |
67 | 63 | */ |
68 | 64 | @Input |
69 | | - public abstract Property<String> getTVName(); // The plugin should always set this, not optional |
| 65 | + @Optional |
| 66 | + @Option(option = "name", description = "TBD") |
| 67 | + public abstract Property<String> getTransportVersionName(); // The plugin should always set this, not optional |
70 | 68 |
|
71 | 69 | /** |
72 | 70 | * Used to set the `major.minor` release version for which the specific TransportVersion ID will be generated. |
73 | 71 | * E.g.: "9.2", "8.18", etc. |
74 | 72 | */ |
75 | 73 | @Optional |
76 | 74 | @Input |
77 | | - public abstract ListProperty<String> getMinorVersionsForTV(); |
78 | | - |
79 | | - // TODO can the Option annotation be on getMinorVersionsForTV() so that we don't have a separate getter? |
80 | | - @Optional |
81 | | - @Input |
82 | | - @Option(option = "versions", description = "The minor version(s) for which to generate IDs, e.g. -Pversions=\"9.2,9.1\"") |
83 | | - public abstract ListProperty<String> getMinorVersionsForTVCmdLine(); |
| 75 | + @Option(option = "versions", description = "The minor version(s) for which to generate IDs, e.g. --versions=\"9.2,9.1\"") |
| 76 | + public abstract ListProperty<String> getMinorVersions(); |
84 | 77 |
|
85 | 78 | // @Optional |
86 | 79 | // @Input |
87 | 80 | // public abstract Property<Function<String, IdIncrement>> getIdIncrementSupplier(); |
88 | 81 |
|
89 | 82 | @TaskAction |
90 | 83 | public void generateTransportVersionData() throws IOException { |
91 | | - final Path tvDataDir = Objects.requireNonNull(getDataFileDirectory().getAsFile().get()).toPath(); |
92 | | - final String tvName = Objects.requireNonNull(getTVName().get()); |
93 | | - final var forMinorVersions = getMinorVersionsForTV().getOrElse( |
94 | | - Objects.requireNonNull(getMinorVersionsForTVCmdLine().get()) |
95 | | - ); |
| 84 | + getLogger().lifecycle("Name: " + getTransportVersionName().get()); |
| 85 | + getLogger().lifecycle("Versions: " + getMinorVersions().get()); |
| 86 | + Path resourcesDir = Objects.requireNonNull(getTransportResourcesDirectory().getAsFile().get()).toPath(); |
| 87 | + String name = getTransportVersionName().isPresent() ? getTransportVersionName().get() : findLocalTransportVersionName(); |
| 88 | + Set<String> targetMinorVersions = new HashSet<>(getMinorVersions().isPresent() ? getMinorVersions().get() : findTargetMinorVersions()); |
| 89 | + |
| 90 | + List<Integer> ids = new ArrayList<>(); |
| 91 | + for (String minorVersion : getKnownMinorVersions(resourcesDir)) { |
| 92 | + TransportVersionDefinition latest = TransportVersionUtils.getLatestFile(resourcesDir, minorVersion); |
| 93 | + TransportVersionDefinition newLatest = null; |
| 94 | + |
| 95 | + if (name.equals(latest.name())) { |
| 96 | + if (targetMinorVersions.contains(minorVersion) == false) { |
| 97 | + // regenerate |
| 98 | + } |
| 99 | + } else { |
| 100 | + if (targetMinorVersions.contains(minorVersion)) { |
| 101 | + // increment |
| 102 | + } |
| 103 | + } |
| 104 | + |
| 105 | + if (newLatest != null) { |
| 106 | + assert newLatest.ids().size() == 1; |
| 107 | + TransportVersionUtils.updateLatestFile(resourcesDir, minorVersion, newLatest.name(), newLatest.ids().getFirst()); |
| 108 | + } |
| 109 | + } |
| 110 | + |
| 111 | +/* |
| 112 | + final String tvName = Objects.requireNonNull(getTransportVersionName().get()); |
| 113 | + List<String> minorVersions = getMinorVersions().get(); |
96 | 114 | // final var idIncrementSupplier = Objects.requireNonNull(getIdIncrementSupplier().get()); |
97 | 115 |
|
98 | 116 | // TODO |
@@ -141,6 +159,7 @@ public void generateTransportVersionData() throws IOException { |
141 | 159 | } |
142 | 160 |
|
143 | 161 | writeDefinitionFile(tvDataDir, tvName, ids.stream().sorted(Comparator.reverseOrder()).toList()); |
| 162 | + */ |
144 | 163 | } |
145 | 164 |
|
146 | 165 | private int incrementTVId(int tvID, MajorMinor version) { |
@@ -172,4 +191,22 @@ private Integer retrieveValueInRange(int lowerExclusive, int upperInclusive, Lis |
172 | 191 | } |
173 | 192 | return null; |
174 | 193 | } |
| 194 | + |
| 195 | + private List<String> getKnownMinorVersions(Path resourcesDir) { |
| 196 | + // list files under latest |
| 197 | + return List.of(); |
| 198 | + } |
| 199 | + |
| 200 | + private String findLocalTransportVersionName() { |
| 201 | + // check for missing |
| 202 | + // if none missing, look at git diff against main |
| 203 | + return ""; |
| 204 | + } |
| 205 | + |
| 206 | + private List<String> findTargetMinorVersions() { |
| 207 | + // look for env var indicating github PR link from CI |
| 208 | + // use github api to find current labels, filter down to version labels |
| 209 | + // map version labels to branches |
| 210 | + return List.of(); |
| 211 | + } |
175 | 212 | } |
0 commit comments