什么是ThinkSNS ?

ThinkSNS(简称TS),一款全平台综合性社交系统,为国内外大中小企业和创业者提供社会化软件研发及技术解决方案。

关于 Overtrue 的拼音库 overtrue/pinyin 为何 travis 为 error_第1张图片1.png

这是 https://github.com/overtrue/pinyin 首页 README 中的持续集成状态。

之前有朋友问我,这个 travis 状态时 error 能用么?肯定是能用,我们来看下 travis 上什么地方错误了:

关于 Overtrue 的拼音库 overtrue/pinyin 为何 travis 为 error_第2张图片2.png

已经显示出来了,其中单元测试失败的是 php 5.5 和 php 5.6 我们随便点击一个进去看看
3.png

超过 10m 没有收到输出,所以 travis 认为构建是有问题的。其实吧~确实有问题,个人也苦恼了很久,没有收到输出的构建是 tests/GeneratorFileDictLoaderTest.php 这个测试类测试的是 Overtrue\Pinyin\GeneratorFileDictLoader 这个加载器。

解释下这个加载器,因为拼音库是基于词库的,而词库非常大,在很多场景下内存中是不允许载入这么多的数据的。所以这个加载器利用 php5.5+ 的 Generator (生成器)特性来生成数据,而生成数据的代价就是需要大量的磁盘 IO 以及增加 >90% 的允许时间。(PHP 官方文档中有说明)。

travis 认为构建失败原因:这个问题本身可能存在于 PHP 5.5 & 5.6 的文件系统(看 PHP 改动日志是有改动的)造成了假死,再加上 travis 本身 IO 能力比较低。所以造成生成器同时打开多个文件流之后就假死了。

如何修复
额~我是来搞笑的。。。。并不知道如何解决构建失败的问题,这个问题我曾经 fork 超哥的库该代码,也并没有找到好的解决方法。

可能删除这种「生成器」加载器会好吧

其实我特地发这篇文章,是想让超哥看到,研究下怎么让构建跑通

往期研发日记传送门:

《ThinkSNS+基于 Laravel master 分支【研发日记一】》

《ThinkSNS+研发中前端的抉择(webpack/Vue)踩坑日记【研发日记二】》

《基于 Laravel Route 的 ThinkSNS+ Component【研发日记三】》

《如何做到 Laravel 配置可以网站后台配置【研发日记四】》

《ThinkSNS+ 如何计算字符显示长度【研发日记五】》

《基于 Laravel 的 ThinkSNS+ alpha.2 版本发布【研发日记六】》

《聊聊 Laravel 5.5 的 「自动发现」和此刻心情【研发日记七】》

《继:我朝特有需求之--英文字符占 0.5 个,中文字符占 1 个【研发日记八】》

《利用 Docker 包 Laradock 服务器部署 Laravel & ThinkSNS+ 等程序实战(多项目)【研发日记九】》