在Shell脚本中还原Nuget软件包时,Dotnet命令失败

时间:2020-10-27 10:16:14

标签: shell nuget-package-restore dotnet-cli

上下文

我目前正在扩展公司的shell脚本,以在构建服务器上构建.net解决方案。 该解决方案由多个项目组成,有些项目需要构建和发布,而有些则不需要。 这些项目的框架也有所不同,因为有些项目是用.net Framework编写的,而最新版本是.net Core编写的。 我已将Shell脚本扩展为以下内容:

msbuild.exe VirtualLaundry.sln

#Build .net framework projects 

for project in Planbord Webportal WebportalCentraal RFIDReader
do
    mkdir -pv publish/$project
    msbuild.exe /t:"Build" /p:PipelineDependsOnBuild=False /p:UseWPP_CopyWebApplication=True /p:PrecompileBeforePublish=True /p:OutDir="$(cygpath -aw $project/bin)" /p:WebProjectOutputDir="$(cygpath -aw publish/$project)" $project/$project.csproj
    rm -rf publish/$project/App_GlobalResources
    rm -f $project.zip
    
    mkdir -pv publish/$project/Config
    cp -v source/$project/Web.config publish/$project/Config

    echo "test" > publish/$project/versie.txt
    if [[ ${shortversion:0:1} == [0-9] ]]
    then
            echo ${shortversion} > publish/$project/versie.txt
    fi
    
    (cd publish/$project && zip -r ../../$project.zip .)
done

# Build .net Core projects
echo Building .Net Core projects
for project in VL.API
do
    echo $PWD
    dotnet publish $project/$project.csproj -o publish 
done

# Zip .net Core projects and remove old build output
for project in VL.API
do
    echo $PWD
    cd publish
    zip -r ../VL.API.zip ./
    cd ..
rm -r publish
done

问题

执行此shell时,它将返回以下错误:

+ echo Building .Net Core projects
Building .Net Core projects
+ for project in VL.API
+ echo /home/90105-091/build/p-019-220/release/source
/home/90105-091/build/p-019-220/release/source
+ dotnet publish VL.API/VL.API.csproj -o publish
Microsoft (R) Build Engine version 16.7.0+7fb82e5b2 for .NET
Copyright (C) Microsoft Corporation. All rights reserved.

  Determining projects to restore...
C:\Program Files\dotnet\sdk\3.1.403\NuGet.targets(128,5): error : Unable to load the service index for source https://api.nuget.org/v3/index.json. [C:\home\90105-091\build\p-019-220\release\source\VL.API\VL.API.csproj]
C:\Program Files\dotnet\sdk\3.1.403\NuGet.targets(128,5): error :   Value cannot be null. (Parameter 'path1') [C:\home\90105-091\build\p-019-220\release\source\VL.API\VL.API.csproj]

起初,我以为服务器已阻止了Nuget API地址(https://api.nuget.org/v3/index.json),但我已经解决了该问题。 我已经在堆栈溢出和Internet上的其他位置搜索了解决方案,但是这些解决方案不起作用或不适用于我的问题。

裁判:

我怀疑CLI可能没有显示其他问题,但是坦率地说,我不确定。

但是我的问题是(可能)导致此问题的原因?

1 个答案:

答案 0 :(得分:0)

经过反复的研究,我发现脚本中引发的错误是由对NuGetScratch文件夹的访问权限引起的,我的Windows帐户无权访问该文件夹。由于Nuget从该锁文件夹还原软件包,因此无法还原任何软件包,因此构建失败。更改访问权限后,错误消失了,所以我唯一的猜测就是“ Value不能为null。(参数'path1')”错误是某种程度上的通用错误,实际上并没有显示出潜在的问题。

相关问题