Skip to content

The Colonel helps you to handle the smoke in your application

Notifications You must be signed in to change notification settings

larriereguichet/colonel-smoker-bundle

Repository files navigation

Colonel Smoker Bundle

Build Status Scrutinizer Code Quality Code Coverage Latest Stable Version License

logo

The Colonel Smoker is an expert in smoke. He can even tell if your application is smoking before deploying it to production.

The Colonel Smoker find the URLs of your Symfony application (only Symfony is supported now) and looks for 500 errors.

Main features :

  • helps providing requirements parameters for your dynamic URLs
  • uses the routes declared in the Symfony routing by default
  • check for response code
  • check if the resulted html contains dynamic data from your entity

The goal is to ensure that each urls in your application does not contains critical errors. It is especially designed for application which have pages with complex and dynamic data to display.

This bundle relies on Symfony service injection. If your are not familiar with this, you can read documentation here

Installation

composer require --dev lag/colonel-smoker-bundle

Configuration

# config/packages/test/lag_smoker.yaml
lag_smoker:
    host: 'http://127.0.0.1:8000/' # This is the default configuration
    # This route will be used to generated urls to test against
    routes:
        # The homepage route has no parameters and expect a 200 OK response code
        app.homepage: ~
        # The show article requires parameters. They will be provided by the mapping "article"
        app.show_article:
            mapping: article
    # The mapping will be used to generated urls with dynamic parameters
    mapping:
        # This name can be anything, but it has to be unique
        article:
            # This mapping will be used with the Article entity of your application
            entity: App\JK\CmsBundle\Entity\Article
            # The property id in the route parameters (/articles/{id} for example) will be mapped with id property of your entity
            requirements:
                id: id

Usage

  1. First generate the URL cache :
bin/console smoker:generate-cache
  1. Then run the smoke tests :
bin/console smoker:smoke

If you use the Symfony WebServer bundle, dont forget to run bin/console server:start --env=test.

How it works

The Colonel Smoker will read the configuration and use the Symfony routing to build the urls of your application. Urls are stored in a cache. Then he calls each urls and analyze the response to find 500 errors. But it can tests more like if the html contains some static or dynamic values.

For example, if your application handles articles, the Colonel Smoker can check if the page displaying the article contains the article title.

Documentation

  1. Getting started
  2. Build Urls
  3. ResponseHandlers

Reference Configuration

lag_smoker:
    routes:
        app.homepage:
            mapping: null
            provider: symfony
            handlers:
                response_code: 200
        app.show_articles_redirection:
            mapping: article
            provider: my_custom_requirements_provider
            handlers:
                response_code: 302
     mapping:
        article:
            entity: App\JK\CmsBundle\Entity\Article
            provider: symfony
            pattern: 'app.article_'
            excludes:
                - app.article.excluded_routes
            requirements:
                id: id
                categorySlug: category.slug
        

The Colonel relies on the Symfony DomCrawler component and the Goutte client.

Known Issues

In dev environment, we call the Symfony Client to many times when having the server on the same machine (when using the Symfony web server for example), the cache miss to retrieve value and throws an exception. It causes some build failures. A patch is in progress to avoid this.

## Road map

  • Add an option to set a timeout in tests to avoid error with the cache
  • Add a check to see if the web server is running