mirror of
https://github.com/actions/setup-java.git
synced 2025-06-30 13:04:13 +00:00
add unit-tests
This commit is contained in:
parent
c3c81d7187
commit
60bf0a87c2
4 changed files with 100 additions and 33 deletions
43
dist/setup/index.js
vendored
43
dist/setup/index.js
vendored
|
@ -4006,30 +4006,49 @@ class JavaBase {
|
|||
}
|
||||
getToolcacheVersionName(version) {
|
||||
if (!this.stable) {
|
||||
const cleanVersion = semver_1.default.clean(version);
|
||||
return `${cleanVersion}-ea`;
|
||||
if (version.includes('+')) {
|
||||
return version.replace('+', '-ea.');
|
||||
}
|
||||
else {
|
||||
return `${version}-ea`;
|
||||
}
|
||||
}
|
||||
return version;
|
||||
// Kotlin and some Java dependencies don't work properly when Java path contains "+" sign
|
||||
// so replace "/hostedtoolcache/Java/11.0.3+4/x64" to "/hostedtoolcache/Java/11.0.3-4/x64" when saves to cache
|
||||
// related issue: https://github.com/actions/virtual-environments/issues/3014
|
||||
return version.replace('+', '-');
|
||||
}
|
||||
findInToolcache() {
|
||||
// we can't use tc.find directly because firstly, we need to filter versions by stability flag
|
||||
// if *-ea is provided, take only ea versions from toolcache, otherwise - only stable versions
|
||||
const availableVersions = tc
|
||||
.findAllVersions(this.toolcacheFolderName, this.architecture)
|
||||
.filter(item => item.endsWith('-ea') === !this.stable);
|
||||
.map(item => {
|
||||
return {
|
||||
version: item
|
||||
.replace('-ea.', '+')
|
||||
.replace(/-ea$/, '')
|
||||
// Kotlin and some Java dependencies don't work properly when Java path contains "+" sign
|
||||
// so replace "/hostedtoolcache/Java/11.0.3-4/x64" to "/hostedtoolcache/Java/11.0.3+4/x64" when retrieves to cache
|
||||
// related issue: https://github.com/actions/virtual-environments/issues/3014
|
||||
.replace('-', '+'),
|
||||
path: util_1.getToolcachePath(this.toolcacheFolderName, item, this.architecture) || '',
|
||||
stable: !item.includes('-ea')
|
||||
};
|
||||
})
|
||||
.filter(item => item.stable === this.stable);
|
||||
const satisfiedVersions = availableVersions
|
||||
.filter(item => util_1.isVersionSatisfies(this.version, item.replace(/-ea$/, '')))
|
||||
.sort(semver_1.default.rcompare);
|
||||
.filter(item => util_1.isVersionSatisfies(this.version, item.version))
|
||||
.filter(item => item.path)
|
||||
.sort((a, b) => {
|
||||
return -semver_1.default.compareBuild(a.version, b.version);
|
||||
});
|
||||
if (!satisfiedVersions || satisfiedVersions.length === 0) {
|
||||
return null;
|
||||
}
|
||||
const javaPath = util_1.getToolcachePath(this.toolcacheFolderName, satisfiedVersions[0], this.architecture);
|
||||
if (!javaPath) {
|
||||
return null;
|
||||
}
|
||||
return {
|
||||
version: util_1.getVersionFromToolcachePath(javaPath),
|
||||
path: javaPath
|
||||
version: satisfiedVersions[0].version,
|
||||
path: satisfiedVersions[0].path
|
||||
};
|
||||
}
|
||||
normalizeVersion(version) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue