Getting error "is the SCM parameter correctly set?"

XMLWordPrintable

    Getting error when coverage plugin trying to get the delta coverage

    [Coverage] [-ERROR-] Errors while recording code coverage:
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] Errors from Git Delta:
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] Could not find the specified commit - is the SCM parameter correctly set?
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] org.eclipse.jgit.errors.MissingObjectException: Missing unknown d17aeef565d735a61e9e30a2b901d9fb9b850b81
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] 	at PluginClassLoader for git-client//org.eclipse.jgit.internal.storage.file.WindowCursor.open(WindowCursor.java:136)
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] 	at PluginClassLoader for git-client//org.eclipse.jgit.lib.ObjectReader.open(ObjectReader.java:216)
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] 	at PluginClassLoader for git-client//org.eclipse.jgit.revwalk.RevWalk.parseAny(RevWalk.java:1144)
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] 	at PluginClassLoader for git-client//org.eclipse.jgit.revwalk.RevWalk.parseCommit(RevWalk.java:1055)
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] 	at PluginClassLoader for git-forensics//io.jenkins.plugins.forensics.git.delta.DeltaRepositoryCallback.calculateDelta(DeltaRepositoryCallback.java:90)
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] 	at PluginClassLoader for git-forensics//io.jenkins.plugins.forensics.git.delta.DeltaRepositoryCallback.invoke(DeltaRepositoryCallback.java:72)
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] 	at PluginClassLoader for git-forensics//io.jenkins.plugins.forensics.git.delta.DeltaRepositoryCallback.invoke(DeltaRepositoryCallback.java:42)
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] 	at PluginClassLoader for git-client//org.jenkinsci.plugins.gitclient.AbstractGitAPIImpl.withRepository(AbstractGitAPIImpl.java:28)
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] 	at PluginClassLoader for git-client//org.jenkinsci.plugins.gitclient.CliGitAPIImpl.withRepository(CliGitAPIImpl.java:83)
    [2025-03-14T01:19:38.051Z] [Coverage] [-ERROR-] 	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    [2025-03-14T01:19:38.052Z] [Coverage] [-ERROR-] 	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    [2025-03-14T01:19:38.052Z] [Coverage] [-ERROR-] 	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    [2025-03-14T01:19:38.052Z] [Coverage] [-ERROR-] 	at java.base/java.lang.reflect.Method.invoke(Unknown Source)
    [2025-03-14T01:19:38.052Z] [Coverage] [-ERROR-] 	at hudson.remoting.RemoteInvocationHandler$RPCRequest.perform(RemoteInvocationHandler.java:986)
    [2025-03-14T01:19:38.052Z] [Coverage] [-ERROR-] 	at hudson.remoting.RemoteInvocationHandler$RPCRequest.call(RemoteInvocationHandler.java:961)
    [2025-03-14T01:19:38.052Z] [Coverage] [-ERROR-] 	at hudson.remoting.RemoteInvocationHandler$RPCRequest.call(RemoteInvocationHandler.java:907)
    [2025-03-14T01:19:38.052Z] [Coverage] [-ERROR-] 	at hudson.remoting.UserRequest.perform(UserRequest.java:225)
    [2025-03-14T01:19:38.052Z] [Coverage] [-ERROR-]   ... skipped logging of 8 additional errors ... 
    
    

    We do pass the value to the function like 

    gitOrgRepo : 'ABC/Test-service'
    recordCoverage(scm: $gitOrgRepo)
    // Our repo name is 'ABC/Test-service'
    
    

    We are using function call like 

    void recordCoverage() {
            String buildResultBeforeRecordCoverage = steps.currentBuild.result
            String gitOrgRepo = getGitOrgRepo()
            steps.echo("Discovering Git reference build (scm=${gitOrgRepo}) before calling recordCoverage")
            steps.discoverGitReferenceBuild scm: gitOrgRepo
            Map recordCoverageArgs = [
                    checksAnnotationScope: getChecksAnnotationScope(),
                    checksName: getChecksName(),
                    enabledForFailure: false,
                    failOnError: false,
                    ignoreParsingErrors: false,
                    qualityGates: getQualityGates(),
                    scm: gitOrgRepo,
                    skipPublishingChecks: false,
                    skipSymbolicLinks: false,
                    sourceCodeEncoding: getSourceCodeEncoding(),
                    sourceCodeRetention: 'EVERY_BUILD',
                    sourceDirectories: getSourceDirectories(),
                    useAutoSourceDetect: getSourceAutoDetect(),
                    tools: getTools(),
                    id: getId(),
                    name: getReportName()
            ]
            steps.echo("recording coverage with args=" + recordCoverageArgs)
            //Soring the build status prior to recordCoverage execution
            steps.recordCoverage(recordCoverageArgs)
            setBuildStatus(buildResultBeforeRecordCoverage, true)
        }
    
    

    Internal call to get the scm value is 

    def getGitOrgRepo() {
            String gitOrgRepo = getArgument('gitOrgRepo')
            return gitOrgRepo
        } 

          Assignee:
          Ulli Hafner
          Reporter:
          Yogesh Khandelwal
          Votes:
          2 Vote for this issue
          Watchers:
          6 Start watching this issue

            Created:
            Updated: