Bas van Erp created MRESOLVER-634:
-------------------------------------

             Summary: updatePolicy is ignored for version-range metadata 
requests
                 Key: MRESOLVER-634
                 URL: https://issues.apache.org/jira/browse/MRESOLVER-634
             Project: Maven Resolver
          Issue Type: Bug
          Components: Resolver
         Environment: Maven 3.9.9, Fedora & MacOS
            Reporter: Bas van Erp


maven-metadata.xml is refetched for every dependency which uses version-ranges 
if the {{resolver-status.properties}} file's "lastUpdated" property is _before_ 
last midnight (local time, for some reason).

It ignores all updatePolicy configs in settings.xml

I have tried diving into the code, but as I'm not a programmer, I couldn't 
really wrap my head around it.
h2. Setup
 * Have a {{settings.xml}} with {{<updatePolicy>never</updatePolicy>}} for 
everything.
 * Have a {{pom.xml}} with a dependency which uses a version-range.
 * Run {{mvn validate}} to trigger the resolver and make sure all metadata and 
dependencies are downloaded and the Maven cache is warmed up.

h2. Correct
 * Use [https://www.epochconverter.com/] to create a millisecond timestamp for 
*today* (local-time): 00:00:01
 * Replace the {{xxx.xml.lastUpdated=###}} timestamp in the 
{{resolver-status.properties}} file of the dependency which is referenced in 
the pom.xml
 * Run {{mvn validate -X}} to trigger the resolver. It should return something 
like: "Skipped remote request for x:y/maven-metadata.xml, locally cached 
metadata up-to-date"
 * Good

h2. Wrong
 * Use [https://www.epochconverter.com/] to create a millisecond timestamp for 
*yesterday* (local-time): 23:59:59
 * Replace the {{xxx.xml.lastUpdated=###}} timestamp in the 
{{resolver-status.properties}} file of the dependency which is referenced in 
the pom.xml
 * The resolver will download the maven-metadata.xml again. Every day.

h2. Impact

We have some dependencies which version ranges for a lot of transitive 
dependencies, and I hate it for multiple reasons. But to add insult to injury, 
every night the first build will refetch all these metadata files in order to 
see if version resolution needs to change.

I have found no way to block this, since version-ranges seem to bypass 
repository updatePolicy settings.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to