5

我有一个用于我的 rails 应用程序的黄瓜测试套件,包括大约 500 个场景,它们之间大约有 5000 个步骤。

我已经设置了我的 github 存储库以使用Travis-CI,使用以下.travis.yml.

language: ruby
rvm:
  - "1.9.2"
script:
  - RAILS_ENV=test bundle exec rake db:migrate --trace
  - bundle exec cucumber -f progress -r features features/cards/base_game
  - bundle exec cucumber -f progress -r features features/cards/basic_cards
  - bundle exec cucumber -f progress -r features features/cards/intrigue
  - bundle exec cucumber -f progress -r features features/cards/seaside
  - bundle exec cucumber -f progress -r features features/cards/prosperity
  - bundle exec cucumber -f progress -r features features/cards/interactions
before_script:
  - cp config/database.travis.yml config/database.yml
  - psql -c 'create database dominion_test' -U postgres

如果我只是跑去bundle exec cucumber运行所有案例,我已经将黄瓜执行分开了,因为 Travis 正在抛出内存不足。

然而,我最近的推送产生了一个 Travis 任务,它花费了 50 多分钟来运行我的所有测试,因此被杀死了。我只是对这么多场景不合理,还是我可以做些什么来加快执行速度?

编辑:如果它很重要,我应该澄清我的场景不测试 GUI。他们正在测试纸牌游戏服务器的规则,因此他们直接调用模型方法。

4

1 回答 1

5

经过大量谷歌搜索后,我在Travis' docs的这个页面找到了一个解决方案。

基本上,允许(甚至推荐!)并行运行。使用以下内容.travis.yml,我最终得到了六个并发作业,其中没有一个需要超过 15 分钟,因此它们都运行完成:

language: ruby
rvm:
  - "1.9.2"
env:
  - CARD_SET=base_game
  - CARD_SET=basic_cards
  - CARD_SET=intrigue
  - CARD_SET=seaside
  - CARD_SET=prosperity
  - CARD_SET=interactions
script:
  - RAILS_ENV=test bundle exec rake db:migrate --trace
  - bundle exec cucumber -f progress -r features features/cards/$CARD_SET
before_script:
  - cp config/database.travis.yml config/database.yml
  - psql -c 'create database dominion_test' -U postgres
于 2013-02-28T09:28:05.507 回答