如何解决 add-apt-repository: not found 错误
Ubuntu
下执行 add-apt-repository
添加第三方仓库时遇到 add-apt-repository: not found
错误,执行以下命令即可:
1 | sudo apt-get update |
参考:
Ubuntu
下执行 add-apt-repository
添加第三方仓库时遇到 add-apt-repository: not found
错误,执行以下命令即可:
1 | sudo apt-get update |
参考:
Finder
默认并不显示隐藏文件,可以通过如下两种方式开启:
defaults write com.apple.finder AppleShowAllFiles YES
,然后重启 Finder
Finder
中使用快捷键 Shift + Command + "."
参考:
An enum switch case label must be the unqualified name of an enumeration constant
是 Java
中常见的编译错误,基本上 Google
搜索出来的错误场景都是因为在 switch
中使用枚举时搭配了类名造成,例如:
1 | Season season = Season.SPRING; |
然而,如果某个枚举值不存在,也会提示一样的错误,例如:
1 | Season season = Season.SPRING; |
这种情况下的错误提示容易让人摸不着头脑,IntelliJ IDEA
的错误提示则较为友好:Cannot resolve symbol 'SOME_VALUE_DOES_NOT_EXIST'
。对于这种错误场景,实际工作中遇到一个例子:
A
拉了个 some.package
的分支,更新版本号为 a.b-SNAPSHOT
并发布,将其引入 some.app
,推送代码后触发了 some.app
的 Jenkins
构建任务B
也拉了个 some.package
的分支,同样更新版本号为 a.b-SNAPSHOT
并发布,并增加了一个新的枚举值到 SomeEnum
,同样将其引入 some.app
,推送代码后触发了 some.app
的 Jenkins
构建任务,此时任务构建失败,提示编译错误:An enum switch case label must be the unqualified name of an enumeration constant
出现这样的原因是 Jenkins
执行构建任务时执行的编译命令是 mvn compile
,在 A
提交任务时,构建服务器下载了 some.package
的 a.b-SNAPSHOT
版本,由于是 SNAPSHOT
版本,在 B
提交任务时,构建服务器没有重新下载 some.package
,导致服务器中的 some.package
没有 B
新增的修改,从而出现编译错误,解决方法是在编译时增加 -U
参数来强制更新 SNAPSHOT
。
参考:
假设我们希望将 server1
下的 /data1
目录中的数据同步到 server2
下的 /data2
目录,首先需要建立 server1
和 server2
的免密登陆,在 server1
上执行 ssh-keygen
,默认情况会在 ~/.ssh
目录下生成 id_rsa
和 id_rsa.pub
两个文件,然后将 ~/.ssh/id_rsa.pub
文件的内容复制到 server2
的 ~/.ssh/authorized_keys
文件中即可。
接着,就可以使用 rsync
进行数据同步,具体命令为 rsync -az --delete /data1/ server2-user@server2-ip:/data2
,其中 -a
表示递归同步 /data1
下的子文件夹及保留文件的权限、组、软连接等信息,如果不需要这些额外的文件信息而只想要递归同步可以使用 -r
来代替 -a
;-z
表示开启文件压缩来减少网络传输;--delete
表示在 /data1
中删除的文件在 /data2
中也会同步删除。最后需要注意命令中 /data1/
末尾的 /
,加了 /
表示将 /data1
下的所有文件同步到 /data2
,没有 /
则表示将 /data1
这个文件夹同步到 /data2
下,假设 /data1
下有 a
、b
、c
三个文件,两种写法最后的同步区别为:
/data1/
:/data2/a,b,c
/data1
:/data2/data1/a,b,c
最后,我们需要将 rsync
加入到定时任务中进行自动备份。执行 crontab -e
,将定时任务添加到文件中,如每小时执行一次:0 * * * * rsync -az --delete /data1/ server2-user@server2-ip:/data2
。
参考:
野生 NHK NEWS EASY 客户端,无广告,功能还比较单一,只上了 Google Play
,iOS
没有通过:
Flutter
项目打包 iOS
应用的时候遇到个错误:
1 | Building for iOS Simulator, but the linked and embedded framework 'App.framework' was built for iOS. (in target 'Runner' from project 'Runner') |
这个问题在 Flutter
的 GitHub
仓库中也有人提到,解决方法也比较简单,删除 App.framework
文件夹即可,即 rm -rf ios/Flutter/App.framework
。
参考:
对于发布到 Google Play
或者 App Store
的应用,需要提供一份隐私政策的说明,如果不知道怎么写的话推荐一个在线的网站来自动生成隐私政策。通过 App Privacy Policy Generator 只需填写一些关键信息即可生成一份隐私政策说明,最终效果如下:
1 | **Privacy Policy** |
Building Flutter APKs and IPAs on Travis 这篇文章详细介绍了如何在 Travis CI 上为 Flutter 项目打包 Android/iOS 应用,不过实际构建时存在几个问题,原文中的 .travis.yml
配置如下:
1 | matrix: |
这个错误发生在执行 wget http://services.gradle.org/distributions/gradle-3.5-bin.zip
的时候,把 gradle
的下载路径替换成 https
即可。
这个错误发生在下载 Flutter
代码的阶段,原文中的配置会下载 Flutter
的 alpha
分支代码,但是目前 Flutter
的仓库已经没有 alpha
分支,切换到 stable
分支即可,即:git clone https://github.com/flutter/flutter.git -b stable --depth 1
。
详细错误信息如下:
1 | [ ] > Failed to install the following Android SDK packages as some |
这个错误是由于没有同意 Android SDK
的许可证协议,在 before_script
中加入如下配置即可:
1 | yes | sdkmanager "platforms;android-29" |
这个错误在执行 pip install six
时遇到,经过实际验证构建 iOS
应用时并不需要此行配置,所以删掉即可。
原文中的配置使用的是 Xcode 8.3
,最后打包时会提示此错误,将 osx_image
设置为 xcode11
即可。
最后完整可用的 .travis.yml
配置如下:
1 | matrix: |
完整的代码可参考 flutter-travis-build-demo。
最后推荐 Codemagic 这个服务,提供云端打包 Flutter
应用的功能,省去了 Travis CI
配置的步骤,免费用户每月有500分钟的额度来执行构建。
首先执行命令 dotnet new classlib --name App
来创建一个类库程序作为测试的对象,该类库只包含一个 SumService
类:
1 | using System; |
然后创建一个基于 xunit
的单元测试项目来编写测试用例,并将 App
类库项目作为项目引用加入到 App.Tests
项目中:
1 | dotnet new xunit --name App.Tests |
并编写一个测试用例 SumServiceTest
:
1 | using System; |
接着创建一个解决方案,并将 App
和 App.Tests
项目加入到该解决方案中:
1 | dotnet new sln --name App |
最后项目结构如下:
1 | ├── App |
覆盖率测试依赖 coverlet
,在创建单元测试项目时已自动添加了该依赖,执行测试时添加 coverlet
相关的参数即可生成测试覆盖率报告:
1 | dotnet test --collect:"XPlat Code Coverage" |
执行成功后会在 App.Tests/TestResults/{random-string}
目录下生成名为 coverage.cobertura.xml
的测试覆盖率报告。
但是,自动创建的单元测试项目默认添加的 coverlet
依赖是 coverlet.collector
,目前还不支持在控制台中打印测试覆盖率报告:
At the moment VSTest integration doesn’t support all features of msbuild and .NET tool, for instance show result on console, report merging and threshold validation. We’re working to fill the gaps.
如果希望在控制台中打印测试覆盖率报告可将 coverlet.collector
依赖改为 coverlet.msbuild
:
1 | dotnet remove .\App.Tests package coverlet.collector |
然后执行测试命令:
1 | dotnet test /p:CollectCoverage=true |
即可在控制台打印测试覆盖率报告:
1 | Calculating coverage result... |
集成 codecov
需要指定测试覆盖率报告文件的路径,暂不支持 coverlet.msbuild
默认生成的 json
格式的文件,可以在执行测试时添加 /p:CoverletOutputFormat=opencover
参数来生成 opencover
格式的文件,相应的 .appveyor.yml
文件内容如下:
1 | image: Visual Studio 2019 |
使用 coverlet.collector
时每次生成的测试覆盖率报告所在的路径是随机的,所以需要将测试覆盖率报告复制到一个固定的路径中,可以使用如下的 PowerShell
脚本:
1 | $source = "./App.Tests/TestResults" |
相应的 .appveyor.yml
文件内容如下:
1 | image: Visual Studio 2019 |
完整的代码可参考 dotnet-core-coverlet-msbuild-demo 及 dotnet-core-coverlet-collector-demo。
在 Ubuntu
下运行 Puppeteer
遇到了如下错误:
1 | error while loading shared libraries: libX11-xcb.so.1: cannot open shared object file: No such file or directory |
需要安装以下依赖来解决:
1 | sudo apt-get install gconf-service libxext6 libxfixes3 libxi6 libxrandr2 libxrender1 libcairo2 libcups2 libdbus-1-3 libexpat1 libfontconfig1 libgcc1 libgconf-2-4 libgdk-pixbuf2.0-0 libglib2.0-0 libgtk-3-0 libnspr4 libpango-1.0-0 libpangocairo-1.0-0 libstdc++6 libx11-6 libx11-xcb1 libxcb1 libxcomposite1 libxcursor1 libxdamage1 libxss1 libxtst6 libappindicator1 libnss3 libasound2 libatk1.0-0 libc6 ca-certificates fonts-liberation lsb-release xdg-utils wget |
参考: