3月7日,微软发布了Visual Studio 2017 RTM,与之一起发布的还有.NET Core Runtime 1.1.0以及.NET Core SDK 1.0.0,尽管这些并不是最新版,但也已经从preview版本升级到了正式版。所以,在安装Visual Studio 2017时如果启用了.NET Core开发的相关功能,那么在安装完成后,你可以在命令行直接执行dotnet.exe,此时你可以看到.NET Core版本是1.1.0,而如果是执行dotnet.exe --version命令,那么你看到的SDK版本将会是1.0.0(并不带preview字样)。

在此介绍如何查看.NET Core SDK版本,主要是源于一件非常有趣的事情,而这件事对于.NET Core项目从老的xproj+project.json迁移到csproj有一定的影响。如果你曾经使用Visual Studio 2015 + .NET Core Tools for Visual Studio + .NET Core SDK开发过项目,并希望在全新的Visual Studio 2017中继续开发的话,了解一下这方面的内容还是很有必要的。

总的来说,迁移一个.NET Core项目,大致有以下几个步骤:

  • 迁移准备
  • 使用Visual Studio 2017对项目进行单项升级
  • 在Jenkins CI服务器上安装最新版的.NET Core SDK
  • 修改Jenkins CI系统编译任务,成功完成编译与发布

下面我就以自己的一个开源项目HAL为例,简单介绍一下各个步骤的做法。

迁移准备

HAL项目本来就是托管在Github上的一个开源项目,为了能够平滑地实现项目迁移,并确保Jenkins CI能够正常工作,在进行项目迁移之前,我首先在Github上新建了一个分支(branch)。Github中创建分支的成本是很低的,在一切调试通过之后,将分支合并(merge)到主分支后,直接删掉就行了。

Github中分支创建完成后,更新本地代码库,完成代码同步。

在Visual Studio 2017中打开并升级.NET Core项目

在我之前有篇简文中介绍过,在安装了Visual Studio 2017 RC之后,如何还能继续在Visual Studio 2015中打开并编译xproj项目,因为当安装完Visual Studio 2017后,dotnet.exe已经升级到1.0.0的版本,此时的dotnet.exe已经是使用MSBuild进行项目编译,它并不认识xproj+project.json这样的项目类型和文档组织结构,因此,在Visual Studio 2015中即使能够打开xproj项目文件,也无法正常编译。当时的解决方案是,在项目的根目录级别创建一个global.json文件,在文件中显式指定.NET Core SDK的版本,使得在项目编译时,强制使用老版本的.NET Core SDK,于是问题也就得到了解决。对于如何修改global.json以指定SDK的版本,这里就不多介绍了,请参考这篇文章

对于这个问题,我们可以做一个实验,假定你的机器上装有Visual Studio 2015 + .NET Core Tools for Visual Studio 2015 + preview版本的.NET Core SDK,同时装有Visual Studio 2017。那么,当你直接在命令行执行dotnet.exe --version命令,你会看到,.NET Core SDK的版本为1.0.0:

如果你进入到一个在global.json中指定了SDK版本的项目的根目录下,同样执行dotnet.exe --version命令,你会发现,此时的SDK版本却是global.json中指定的版本:

OK,如果你之前有修改global.json文件使得xproj项目能够继续在Visual Studio 2015中打开并编译的话,现在就需要去掉global.json文件中对SDK版本的显式声明,否则,在Visual Studio 2017中进行项目迁移的时候,将无法正常完成。因为此时Visual Studio会使用旧版本的SDK,而这个版本的SDK没有migrate功能。

总的来说,在Visual Studio 2017中迁移xproj还是比较平滑稳定的,一般不会遇到稀奇古怪的问题,只需要确认单向迁移就行了。在迁移完成后,会产生新的解决方案文件(sln)。

在Jenkins服务器上安装新的.NET Core SDK

当Visual Studio 2017成功完成项目迁移之后,就可以把代码提交到Github上的临时分支了,这样就能在Jenkins上进行构建测试。在此之前,需要安装新版本的.NET Core SDK。安装过程很简单,到dotnet官方网站上根据Jenkins master或者slave的操作系统选择相应的.NET Core SDK进行下载安装即可。安装完成后,可以使用dotnet --version命令,确认.NET Core SDK已经正确安装。

修改Jenkins系统编译任务

就HAL项目而言,我首先在Jenkins中克隆了编译任务(build job),然后修改这个编译任务,使得它能从Github中的临时分支获取代码。整个过程也没有出现什么难以解决的问题,原有的dotnet restore/build/pack等命令也能够正常继续使用,不过你会发现,编译过程已经使用Microsoft Build Engine(MSBuild)了。

需要注意的是,原来基于xUnit的dotnet test,有一个-xml的隐藏参数,它能够产生JUnit XML格式的单元测试结果报告,但在.NET Core SDK 1.0下,这个参数就不能用了,有个解决办法是使用-l(--logger)参数,它能够产生MSTest格式的单元测试报告,此时,在Jenkins中安装一个MSTest的插件,就能够继续将测试报告显示在主页上。

最后,在Github中,将临时分支合并到主线分支,并在Jenkins中手动修改主线分支对应的build job,最后把克隆的build job删除即可。不建议继续沿用克隆的build job,那样会造成编译版本的混乱。

.NET Core项目从xproj+project.json向csproj迁移简介的更多相关文章

  1. .NET Core 构建配置文件从 project.json 到 .csproj

    从 .NET Core SDK 1.0 Preview 3 build 004056 开始,.NET Core 弃用 project.json,回归 .csproj,主要原因是为了兼容 MSBuild ...

  2. [.NET Core 24]把project.json迁移到.csproj

    链接:https://blog.jetbrains.com/dotnet/2017/04/04/rider-eap-update-csproj-based-net-core-support-migra ...

  3. LostRoutes项目日志——编辑project.json

    第一个Scene编译后运行会报错: Uncaught TypeError: Cannot read property 'style' of null 这是因为没有在project.json中包含已经编 ...

  4. 难以接受你的改变:从project.json到.csproj

    自从微软做了一个艰难的决定——.NET Core彻底放弃project.json,全面改回.csproj——至今,虽然赞美之声不断,但我依然不喜欢也难以接受这样的改变. 难以接受主要有两方面的原因: ...

  5. 将 Net 项目升级 Core项目经验:(二)修复迁移后Net Standard项目中的错误

    修复迁移后Net Standard项目中的错误 接上一章,项目编译结果如下: 解决依赖dll引用 在Net Framework项目的引用如下: 各引用和作用: log4net(1.10.0.0) 用于 ...

  6. .NET Core 工具从 project.json 移动到基于 MSBuild 的项目后的使用

    .NET Core 从preview 4 开始弃用project.json 可以从这下载最新版本: https://github.com/dotnet/cli 使用VS2017 RC新建.net co ...

  7. [asp.net core]project.json(1)

    摘要 前面介绍了使用vs2015新建asp.net core web的内容,这篇文章学习下project.json文件的内容. project.json 原文:https://docs.microso ...

  8. [C#] .NET Core项目修改project.json来引用其他目录下的源码等文件的办法 & 解决多框架时 project.json 与 app.config冲突的问题

    作者: zyl910 一.缘由 项目规模大了后,经常会出现源码文件分布在不同目录的情况,但.NET Core项目默认只有项目目录下的源码文件,且不支持"Add As Link"方式 ...

  9. .NET Core项目修改project.json来引用其他目录下的源码等文件的办法 & 解决多框架时 project.json 与 app.config冲突的问题

    作者: zyl910 一.缘由 项目规模大了后,经常会出现源码文件分布在不同目录的情况,但.NET Core项目默认只有项目目录下的源码文件,且不支持“Add As Link”方式引入文件.这时需要手 ...

随机推荐

  1. promise/bluebird源码

    本作品采用知识共享署名 4.0 国际许可协议进行许可.转载保留声明头部与原文链接https://luzeshu.com/blog/bluebirdsource 本博客同步在http://www.cnb ...

  2. SQL SERVER 运维日记-数据库备份

    概述 昨天下午突然看到,<炉石传说>游戏数据库发生宕机并引发数据丢失事故的新闻.刚看到时,满满的不可思议.暴雪啊,网易啊. 都是很牛叉的公司.他们出的游戏我都是很喜欢的. 当我看到,第一时 ...

  3. 浅谈stream数据流

    汴水流,泗水流,流到瓜州古渡头, 吴山点点愁.    我们知道水是源源不断的, 抽刀断水水更流, 斩不断, 理还乱,  是水流.(技术贴, 本文权当读者没学过古诗). 在一些语言里, 我们的前辈把数据 ...

  4. Jenkins添加用户

    新建用户 Jenkins刚开始的界面是允许访客进行所有操作的,这时Jenkins是有安全隐患的,也不容易去管理.这时,我们需要管理Jenkins的权限,对它的权限进行设置.关于Jenkins权限设置的 ...

  5. static的加载先后顺序

    1.静态变量的声明和赋值是分开的,静态变量会先被声明,赋值操做被放在了静态代码块中. 2.静态变量的赋值和静态代码块的执行顺序和代码的先后书写顺序相关. 3.静态代码块优先执行,其次构造方法,最后普通 ...

  6. 提升iOS审核通过率之“IPv6兼容测试”

    作者:jingle 腾讯系统测试工程师 商业转载请联系腾讯WeTest授权,非商业转载请注明出处. 原文链接:http://wetest.qq.com/lab/view/285.html 一.背景 在 ...

  7. ubuntu ssh-keygen Permission denied

    ubuntu下生成github上的ssh keys,执行: ssh-keygen 直接执行: sudo chown user1:user1 /home/user1/.ssh -R 成功生成.

  8. 在java中的Try Catch块-------------异常处理(2)

    1. Try块是什么? Try块是一块可能产生异常的代码块,一个Try块可能跟着Catch块或者Finally块,或者两者. Try块的语义: try{ //statements that may c ...

  9. .c与.cpp的区别解析

    这几天在练习数据结构等知识的时候,有时遇见文件保存为c后缀则能编译通过,有时又是保存cpp后缀才能通过.对于这个都没能区分清,是自己的基本功问题,于是百度了一下.幸好有许多和我一样有问题的人. 其实简 ...

  10. 第三章:初识Jquery

    一.Jquery的优势 体积小,压缩后只有100KB左右 强大的选择器 出色的DOM封装 可靠的事件处理机制 出色的浏览器兼容性 使用隐式迭代简化编程 丰富的插件支持 二.Jquery语法 三.DOM ...