如何通过业力和范围来解决内存错误phantomjs

时间:2014-12-02 00:09:54

标签: phantomjs karma-runner karma-jasmine

我们正在使用karmaphantomjs运行测试上周,我们的测试神秘地开始崩溃phantomJS,错误为-1073741819。

Based on this thread for Chutzpah似乎代码表明PhantomJS存在本机内存故障。

经过进一步调查,我们一直看到幻影在750MB左右的内存中崩溃。

有没有办法配置Karma,以便它不会遇到此限制?或者告诉它冲洗幽灵的方法?

到目前为止,我们只进行了大约1200次测试。我们大约是项目的1/4,所以5000个UI测试似乎不可能。

6 个答案:

答案 0 :(得分:9)

由于发布问题并快速发现答案的StackOverflow现象,我们通过添加gulp任务解决了这个问题。在我们刚刚在命令行运行karma start之前。这打破了一个幻影的单个实例,当达到750MB时崩溃了。

现在我们对每个测试部分都有一个gulp命令,例如: gulp common-testsgulp admin-tests以及gulp customer-tests

然后运行每个分组的单个gulp karma。这允许每个gulp命令都有自己的幻像实例,因此保持在该阈值之下。

答案 1 :(得分:8)

我们遇到了类似的问题。你的方法很有意思,肯定会解决这个问题。但是,请准备好以后再次面对它。

我做了一些调查,发现了记忆增长的原因(至少在我们的例子中)。使用时结果证明:

   beforeEach(inject(SomeActualService)){ .... }

SomeActualService占用的内存不会在describe块的末尾释放,如果你有多个测试文件,你注入相同的服务(或其他可注入的对象),将再次为它分配更多的内存。

我对如何避免这种情况有几点想法: 1.创建模拟对象,除非您在测试该模块的测试中,否则永远不要使用inject来获取真实对象。这将需要编写大量的额外代码。 2.为可注射对象创建自己的跟踪器(仅用于测试)。这样它们只能加载一次并在测试文件之间重用。

忘记提及:我们正在使用angular 1.3.2,Jasmine 2.0并在1000次测试中遇到这个问题。

答案 2 :(得分:7)

在使用PhantomJS 1.9.18的Windows 10上进行大约1037次测试后,我也遇到了这个问题。

在进程的RAM超过大约800-850 MB后,它将显示为ERROR [launcher]: PhantomJS crashed.

这里似乎有一个临时修复:

您可以通过npm install karma-phantomjs2-launcher --save-dev

进行安装

然后需要在karma.conf.js通过

使用它
config.set({
    browsers: ['PhantomJS2'],
    ...
});

这似乎运行相同的测试集,同时仅使用250-550 MB RAM并且不会崩溃。

请注意,此修复程序在Windows和OS X上开箱即用,但不适用于Linux(PhantomJS2二进制文件无法启动)。这会影响对Travis CI的推动。

要在Debian / Ubuntu上解决此问题:

sudo apt-get install libicu52 libjpeg8 libfontconfig libwebp5

答案 3 :(得分:5)

这是PhantomJS的一个问题。根据{{​​3}},PhantomJS仅在页面关闭时运行垃圾收集器,这只在测试运行后才会发生。其他浏览器工作正常,因为他们的垃圾收集器按预期工作。

在这个问题上花了几天之后,我们得出结论,最好的解决方案是将测试分成几组。我们已经动态地为每个目录创建了一个配置文件,并创建了一个运行所有这些配置文件的命令。出于所有意图和目的,它的工作原理相同。

答案 4 :(得分:2)

我们在linux(ubuntu)上遇到了类似的问题,结果是该进程可以管理的内存段数量:

$ cat /proc/sys/vm/max_map_count
65530

然后运行:

$ sudo bash -c 'echo 6553000 > /proc/sys/vm/max_map_count'

请注意该数字乘以100。 这将更改会话设置。如果它解决了问题,您可以为以后的所有会话进行设置:

$ sudo bash -c 'echo vm.max_map_count = 6553000 > /etc/sysctl.d/60-max_map_count.conf'

答案 5 :(得分:0)

回答一个老问题,但希望这有助于......

我有一个构建过程,CI作业只在命令行中运行linux框。所以,似乎PhantomJS是我唯一的选择。我在我的Mac上本地遇到了这个内存问题,但不知怎的,它不会发生在linux盒子上。我的解决方案是向我的package.json添加另一个测试命令以使用Chrome运行karma,并在本地运行以运行我的测试。当推高时,Jenkins将启动常规测试命令,运行PhantomJS。

安装此插件:https://github.com/karma-runner/karma-chrome-launcher

将此添加到package.json

"test": "karma start", "test:chrome": "karma start --browsers Chrome"