test.integration.js 2.29 KB
Newer Older
Thitichaipun Wutthisak committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
/*jshint node:true*/
/*jshint mocha:true*/
/*global assert:true*/
describe('integration', function () {
  'use strict';

  var port = 8045; /* teststatic default port 8080 may be occupied on many systems */
  var webshot = require('webshot'),
      path = require('path'),
      gm = require('gm'),
      tmp = require('tmp-sync'),
      mkdirp = require('mkdirp').sync,
      cp = require('cp').sync,
      imgur = require('imgur-node-api'),
      server = require('testatic')('./', port),
      WEBSHOT_OPTIONS = { renderDelay: process.env.DELAY || 2500, windowSize: { width: 1366, height: 768 }},
      WEBSHOT_FAILED_DIR = path.join('test', 'fixtures', 'shots') + path.sep,
      dir;

  beforeEach(function () {
    dir = tmp.in() + path.sep;
  });

  afterEach(function () {
    tmp.clean();
  });

  after(function () {
    server.close();
  });

  mkdirp(WEBSHOT_FAILED_DIR);

  [
    'bubble',
    'scatter',
    'dataset-override',
    'horizontal-bar-chart',
    '29-tabs',
    '57-hex-colours',
    '54-not-enough-colours',
    '51-pie-update-colours',
    'configure-line-chart',
    'custom-directive',
    'charts'
  ].forEach(function (name) {
    it('compares screenshots for: ' + name, function (done) {
      var image = dir + name + '.png',
          url = 'http://localhost:' + port + '/test/fixtures/' + name + '.html',
          expected = path.join('test', 'fixtures', name + '.png');

      webshot(url, image, WEBSHOT_OPTIONS, function (err) {
        if (err) return done(err);
        gm.compare(expected, image, process.env.TOLERANCE || 0.00001, function (err, isEqual) {
          if (err) return done(err);
          if (! isEqual) {
            var failed = WEBSHOT_FAILED_DIR + name + '-failed.png',
                msg = 'Expected screenshots to be similar. Screenshot saved to ' + failed;
            cp(image, failed);
            if (process.env.CI && process.env.IMGUR_ID) {
              imgur.setClientID(process.env.IMGUR_ID);
              imgur.upload(image, function (err, res) {
                if (err) return done(err);
                assert.fail(isEqual, true, msg + ', uploaded to ' + res.data.link);
              });
            } else {
              assert.fail(isEqual, true, msg);
            }
            return;
          }
          done();
        });
      });
    });
  });
});