The Problems

If you’re using Cypress, Test Cafe, Selenium, or any other testing library for a full-stack webapp, you’ve probably faced significant problems when running them in CI:

1. It’s hard to start webservers in traditional CI

After setting up CI/CD for a webapp, the next step is often creating a copy of the entire app in order to run end-to-end tests.

Without webapp.io, there are two common approaches to doing this in CI:

  • Use your production cloud provider, and create staging environments ($$$, slow)
  • Start the stack for the duration of the pipeline (slow, hard to debug)

How webapp.io solves this problem:

Instead of using a YAML file to configure CI/CD in webapp.io, our users create a Layerfile. Here’s an example:

Layerfile
FROM vm/node:14
COPY . .
RUN npm install
RUN npm run build
RUN BACKGROUND npm run start
EXPOSE WEBSITE localhost:3000

This syntax is borrowed from Docker’s configuration, and makes it really easy to speed up builds. In this case, we’d skip running npm install for subsequent pipelines unless you change package.json.

2. It’s hard to review visual changes

Web apps changes are often subjective. Unit tests won’t tell you if changing color: #fefdfa to color: #dabdab will interfere with contrast and readability on your site.

Ultimately reviewers need to check out the change and try it out themselves in order to determine if it’s ok or not.

How webapp.io solves this problem:

After making their webapp.io configuration, users can add a single EXPOSE WEBSITE localhost:3000 directive to embed a full-stack preview environment directly into every pull request.

3. When builds fail, it’s hard to understand why

Usual CI systems make it hard to debug webapp failures by restricting users to only looking at logs.

How webapp.io solves this problem:

Image of a debugging terminal for a specific CI step

Webapp.io embeds debugging terminals below every failed build automatically.

4. It takes many clicks to get feedback

Most CI/CD systems use a “checks API” to give a pass/fail metric for a pull request.

For example, they might tell you whether a build failed or if a unit test passed.

However, webapps have many numerical metrics like page speed that aren’t necessarily pass/fail.

How webapp.io solves this problem:

Webapp.io allows you to embed customizable widgets into your pull requests so that reviewers can see details about a specific change at a glance.

Image of the drag-and-drop pull request builder

If you’d like to see a demo of webapp.io, you can try a free tutorial by signing up here.