This article is about CodeShip Pro.

Parallel Testing

You will need roughly 3 minutes to read this article.

Parallelizing on CodeShip Pro

One of the ways CodeShip Pro makes it easy to get faster and more powerful build pipelines is with an open-ended approach to parallelization.

On CodeShip Pro, you can parallelize any commands you want, and at any point in your pipeline you wish. You can also parallelize as much as you want to - the only barrier is the resources on the host machine.

The pricing for CodeShip Pro is centered around what size build machine you need, essentially the CPU and memory resources you need available. Every build and every group of containers use a unique amount of resources, but as a rule of thumb the more you have running at once, the more CPU and memory resources you’ll need.

Setting Up Parallel Steps

To set up your parallel steps in CodeShip Pro, you will be making changes to your codeship-services.yml file.

A parallel step group is just defined by using the type: parallel header and then nesting all steps you want parallelized underneath, as seen in this example:

- type: parallel
  - service: app
    command: ./script/ci/ci.parallel spec
  - service: app
    command: ./script/ci/ci.parallel plugin
  - service: app
    command: ./script/ci/ci.parallel qunit

Parallelizing Test Specs

To break a larger test suite into parallelized groups of test specs running simultaneously, you’ll want to call your individual specs via separate commands rather than invoking the test suite overall:

- type: parallel
  - service: app
    command: rspec tests/frontend
  - service: app
    command: rspec tests/backend
  - service: app
    command: rspec tests/api

Parallel Modules

In addition to parallelizing explicitly in your codeship-services.yml, most popular frameworks offer modules that you can install to parallelize within the codebase itself.

While we do not officially support or integrate with any of these modules, many CodeShip users find success speeding their tests up by using them. Note that in many cases these modules create additional strain on your machine resource usage, so you will want to keep an eye on this as misconfiguration can result in a resource max out that ultimately slows your builds down or causes failures.




Common Issues

If builds are running slow or failing intermittently and you think memory or CPU constraints may be a cause, you can contact our helpdesk, and we can investigate your resource usage and see if a larger build machine makes sense.

Or, if you just want to upgrade to a larger build machine or try a larger machine out in a trial period, you can contact our account team.

Need more help?

Contact our support team or post on Stack Overflow using the tag #codeship. Did you check the status page and changelog?

There are also several code examples and sample projects available for you to get started with.

Article not helpful?

Does this article need improvement? If so, please send feedback or submit a pull request!