From e1d294d96ea7a64dd1cb96052d5570fbcfcc8d77 Mon Sep 17 00:00:00 2001 From: Robert Munteanu Date: Thu, 14 Sep 2023 17:44:20 +0200 Subject: [PATCH 1/3] feat: mavenPropertyVersions regexManager --- .../presets/internal/regex-managers.spec.ts | 48 +++++++++++++++++++ lib/config/presets/internal/regex-managers.ts | 15 ++++++ 2 files changed, 63 insertions(+) diff --git a/lib/config/presets/internal/regex-managers.spec.ts b/lib/config/presets/internal/regex-managers.spec.ts index 13a947bec990c3..f4464c5150f961 100644 --- a/lib/config/presets/internal/regex-managers.spec.ts +++ b/lib/config/presets/internal/regex-managers.spec.ts @@ -232,4 +232,52 @@ describe('config/presets/internal/regex-managers', () => { }); }); }); + + describe('finds dependencies in pom.xml properties', () => { + const regexManager = presets['mavenPropertyVersions'].regexManagers?.[0]; + + it(`find dependencies in file`, async () => { + const fileContent = codeBlock` + + 9.3 + + + 4.0.10 + + + 4.4.6 + `; + + const res = await extractPackageFile( + fileContent, + 'pom.xml', + regexManager! + ); + + expect(res?.deps).toMatchObject([ + { + currentValue: '9.3', + datasource: 'maven', + depName: 'org.ow2.asm:asm', + replaceString: + '\n9.3', + }, + { + currentValue: '4.0.10', + datasource: 'maven', + depName: 'org.codehaus.groovy:groovy', + replaceString: + '\n4.0.10', + versioning: 'semver', + }, + { + currentValue: '4.4.6', + datasource: 'docker', + depName: 'mongo', + replaceString: + '\n4.4.6', + }, + ]); + }); + }); }); diff --git a/lib/config/presets/internal/regex-managers.ts b/lib/config/presets/internal/regex-managers.ts index e50074ab597a80..29b255f3eba507 100644 --- a/lib/config/presets/internal/regex-managers.ts +++ b/lib/config/presets/internal/regex-managers.ts @@ -44,6 +44,21 @@ export const presets: Record = { }, ], }, + mavenPropertyVersions: { + description: 'Update `*.version` properties in `pom.xml` files.', + regexManagers: [ + { + customType: 'regex', + datasourceTemplate: + '{{#if datasource}}{{{datasource}}}{{else}}maven{{/if}}', + fileMatch: ['^pom\\.xml$'], + matchStrings: [ + '\\s+<.*?\\.version>(?.*?)<\\/.*?\\.version>', + ], + versioningTemplate: '{{#if versioning}}{{{versioning}}}{{/if}}', + }, + ], + }, tfvarsVersions: { description: 'Update `*_version` variables in `.tfvars` files.', regexManagers: [ From 0518a40cbb3ee1e01764d7414c7fb1de7c312842 Mon Sep 17 00:00:00 2001 From: Robert Munteanu Date: Thu, 14 Sep 2023 22:25:42 +0200 Subject: [PATCH 2/3] Update lib/config/presets/internal/regex-managers.ts Co-authored-by: Michael Kriese --- lib/config/presets/internal/regex-managers.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/config/presets/internal/regex-managers.ts b/lib/config/presets/internal/regex-managers.ts index 29b255f3eba507..6587fd9cacc01d 100644 --- a/lib/config/presets/internal/regex-managers.ts +++ b/lib/config/presets/internal/regex-managers.ts @@ -53,7 +53,7 @@ export const presets: Record = { '{{#if datasource}}{{{datasource}}}{{else}}maven{{/if}}', fileMatch: ['^pom\\.xml$'], matchStrings: [ - '\\s+<.*?\\.version>(?.*?)<\\/.*?\\.version>', + '\\s+<.*?\\.version>(?.*?)<\\/.*?\\.version>', ], versioningTemplate: '{{#if versioning}}{{{versioning}}}{{/if}}', }, From ee3f0093019690d1f8eae6a5b322519668f8223a Mon Sep 17 00:00:00 2001 From: Robert Munteanu Date: Tue, 19 Sep 2023 17:11:43 +0200 Subject: [PATCH 3/3] Update lib/config/presets/internal/regex-managers.ts Co-authored-by: Johannes Feichtner <343448+Churro@users.noreply.github.com> --- lib/config/presets/internal/regex-managers.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/config/presets/internal/regex-managers.ts b/lib/config/presets/internal/regex-managers.ts index 6587fd9cacc01d..ac9bff0f4369dd 100644 --- a/lib/config/presets/internal/regex-managers.ts +++ b/lib/config/presets/internal/regex-managers.ts @@ -53,7 +53,7 @@ export const presets: Record = { '{{#if datasource}}{{{datasource}}}{{else}}maven{{/if}}', fileMatch: ['^pom\\.xml$'], matchStrings: [ - '\\s+<.*?\\.version>(?.*?)<\\/.*?\\.version>', + '\\s+<.+\\.version>(?.+)<\\/.+\\.version>', ], versioningTemplate: '{{#if versioning}}{{{versioning}}}{{/if}}', },