fix(gradle): Support gradle versions as templates (#13576)

* fix(gradle): Support gradle versions as templates

* More test
This commit is contained in:
Sergei Zharinov 2022-01-16 18:23:14 +03:00 committed by GitHub
parent 0fdede3547
commit ee55afb3d9
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 44 additions and 3 deletions

View file

@ -71,6 +71,12 @@ describe('manager/gradle/shallow/parser', () => {
${'baz = "1.2.3"'} | ${'id "foo.bar" version baz'} | ${{ depName: 'foo.bar', lookupName: 'foo.bar:foo.bar.gradle.plugin', currentValue: '1.2.3' }} ${'baz = "1.2.3"'} | ${'id "foo.bar" version baz'} | ${{ depName: 'foo.bar', lookupName: 'foo.bar:foo.bar.gradle.plugin', currentValue: '1.2.3' }}
${'baz = "1.2.3"'} | ${'id("foo.bar") version baz'} | ${{ depName: 'foo.bar', lookupName: 'foo.bar:foo.bar.gradle.plugin', currentValue: '1.2.3' }} ${'baz = "1.2.3"'} | ${'id("foo.bar") version baz'} | ${{ depName: 'foo.bar', lookupName: 'foo.bar:foo.bar.gradle.plugin', currentValue: '1.2.3' }}
${'baz = "1.3.71"'} | ${'kotlin("jvm") version baz'} | ${{ depName: 'org.jetbrains.kotlin.jvm', lookupName: 'org.jetbrains.kotlin.jvm:org.jetbrains.kotlin.jvm.gradle.plugin', currentValue: '1.3.71' }} ${'baz = "1.3.71"'} | ${'kotlin("jvm") version baz'} | ${{ depName: 'org.jetbrains.kotlin.jvm', lookupName: 'org.jetbrains.kotlin.jvm:org.jetbrains.kotlin.jvm.gradle.plugin', currentValue: '1.3.71' }}
${'z = "1.2.3"'} | ${'id "x.y" version "$z"'} | ${{ depName: 'x.y', lookupName: 'x.y:x.y.gradle.plugin', currentValue: '1.2.3' }}
${''} | ${'id "x.y" version "$z"'} | ${{ depName: 'x.y', skipReason: SkipReason.UnknownVersion, currentValue: 'z' }}
${''} | ${'id "x.y" version "x${y}z"'} | ${{ depName: 'x.y', skipReason: SkipReason.UnknownVersion }}
${'z = "1.2.3"'} | ${'id("x.y") version "$z"'} | ${{ depName: 'x.y', lookupName: 'x.y:x.y.gradle.plugin', currentValue: '1.2.3' }}
${''} | ${'id("x.y") version "$z"'} | ${{ depName: 'x.y', skipReason: SkipReason.UnknownVersion, currentValue: 'z' }}
${''} | ${'id("x.y") version "x${y}z"'} | ${{ depName: 'x.y', skipReason: SkipReason.UnknownVersion }}
`('$input', ({ def, input, output }) => { `('$input', ({ def, input, output }) => {
const { deps } = parseGradle([def, input].join('\n')); const { deps } = parseGradle([def, input].join('\n'));
expect(deps).toMatchObject([output].filter(Boolean)); expect(deps).toMatchObject([output].filter(Boolean));

View file

@ -236,6 +236,29 @@ function processPlugin({
dep.managerData = { fileReplacePosition, packageFile }; dep.managerData = { fileReplacePosition, packageFile };
dep.skipReason = SkipReason.UnknownVersion; dep.skipReason = SkipReason.UnknownVersion;
} }
} else if (pluginVersion.type === TokenType.StringInterpolation) {
const versionTpl = pluginVersion as StringInterpolation;
const children = versionTpl.children;
const [child] = children;
if (child?.type === TokenType.Variable && children.length === 1) {
const varData = variables[child.value];
if (varData) {
const currentValue = varData.value;
const fileReplacePosition = varData.fileReplacePosition;
dep.currentValue = currentValue;
dep.managerData = { fileReplacePosition, packageFile };
} else {
const currentValue = child.value;
const fileReplacePosition = child.offset;
dep.currentValue = currentValue;
dep.managerData = { fileReplacePosition, packageFile };
dep.skipReason = SkipReason.UnknownVersion;
}
} else {
const fileReplacePosition = versionTpl.offset;
dep.managerData = { fileReplacePosition, packageFile };
dep.skipReason = SkipReason.UnknownVersion;
}
} else { } else {
const currentValue = pluginVersion.value; const currentValue = pluginVersion.value;
const fileReplacePosition = pluginVersion.offset; const fileReplacePosition = pluginVersion.offset;
@ -372,6 +395,8 @@ const matcherConfigs: SyntaxMatchConfig[] = [
}, },
{ {
// id 'foo.bar' version '1.2.3' // id 'foo.bar' version '1.2.3'
// id 'foo.bar' version fooBarVersion
// id 'foo.bar' version "$fooBarVersion"
matchers: [ matchers: [
{ {
matchType: TokenType.Word, matchType: TokenType.Word,
@ -381,7 +406,11 @@ const matcherConfigs: SyntaxMatchConfig[] = [
{ matchType: TokenType.String, tokenMapKey: 'pluginName' }, { matchType: TokenType.String, tokenMapKey: 'pluginName' },
{ matchType: TokenType.Word, matchValue: 'version' }, { matchType: TokenType.Word, matchValue: 'version' },
{ {
matchType: [TokenType.String, TokenType.Word], matchType: [
TokenType.String,
TokenType.Word,
TokenType.StringInterpolation,
],
tokenMapKey: 'pluginVersion', tokenMapKey: 'pluginVersion',
}, },
endOfInstruction, endOfInstruction,
@ -390,6 +419,8 @@ const matcherConfigs: SyntaxMatchConfig[] = [
}, },
{ {
// id('foo.bar') version '1.2.3' // id('foo.bar') version '1.2.3'
// id('foo.bar') version fooBarVersion
// id('foo.bar') version "$fooBarVersion"
matchers: [ matchers: [
{ {
matchType: TokenType.Word, matchType: TokenType.Word,
@ -401,7 +432,11 @@ const matcherConfigs: SyntaxMatchConfig[] = [
{ matchType: TokenType.RightParen }, { matchType: TokenType.RightParen },
{ matchType: TokenType.Word, matchValue: 'version' }, { matchType: TokenType.Word, matchValue: 'version' },
{ {
matchType: [TokenType.String, TokenType.Word], matchType: [
TokenType.String,
TokenType.Word,
TokenType.StringInterpolation,
],
tokenMapKey: 'pluginVersion', tokenMapKey: 'pluginVersion',
}, },
endOfInstruction, endOfInstruction,

View file

@ -35,7 +35,7 @@ const lexer = moo.states({
[TokenType.Comma]: ',', [TokenType.Comma]: ',',
[TokenType.Operator]: /(?:==|\+=?|-=?|\/=?|\*\*?|\.+|:)/, // TODO #12870 [TokenType.Operator]: /(?:==|\+=?|-=?|\/=?|\*\*?|\.+|:)/, // TODO #12870
[TokenType.Assignment]: '=', [TokenType.Assignment]: '=',
[TokenType.Word]: { match: /[a-zA-Z$_][a-zA-Z0-9$_]+/ }, // TODO #12870 [TokenType.Word]: { match: /[a-zA-Z$_][a-zA-Z0-9$_]*/ }, // TODO #12870
[TokenType.LeftParen]: { match: '(' }, [TokenType.LeftParen]: { match: '(' },
[TokenType.RightParen]: { match: ')' }, [TokenType.RightParen]: { match: ')' },
[TokenType.LeftBracket]: { match: '[' }, [TokenType.LeftBracket]: { match: '[' },