toolkit/javascript/d3/test/geo/mercator-test.js
author Nicolas Sauret <nicolas.sauret@iri.centrepompidou.fr>
Fri, 18 Apr 2014 14:31:58 +0200
changeset 51 79833eaa394a
parent 47 c0b4a8b5a012
permissions -rw-r--r--
set up second level for navigation

require("../env");
require("../../d3");
require("../../d3.geo");

var vows = require("vows"),
    assert = require("assert");

var suite = vows.describe("d3.geo.mercator");

suite.addBatch({
  "mercator": {
    topic: function() {
      return d3.geo.mercator().translate([0, 0]).scale(100);
    },
    "Arctic": function(mercator) {
      var coords = mercator([0, 85]);
      assert.inDelta(coords[0], 0, 1e-6);
      assert.inDelta(coords[1], -49.8362085, 1e-6);
      var lonlat = mercator.invert(coords);
      assert.inDelta(lonlat[0], 0, 1e-6);
      assert.inDelta(lonlat[1], 85, 1e-6);
    },
    "Antarctic": function(mercator) {
      var coords = mercator([0, -85]);
      assert.inDelta(coords[0], 0, 1e-6);
      assert.inDelta(coords[1], 49.8362085, 1e-6);
      var lonlat = mercator.invert(coords);
      assert.inDelta(lonlat[0], 0, 1e-6);
      assert.inDelta(lonlat[1], -85, 1e-6);
    },
    "Hawaii": function(mercator) {
      var coords = mercator([-180, 0]);
      assert.inDelta(coords[0], -50, 1e-6);
      assert.inDelta(coords[1], 0, 1e-6);
      var lonlat = mercator.invert(coords);
      assert.inDelta(lonlat[0], -180, 1e-6);
      assert.inDelta(lonlat[1], 0, 1e-6);
    },
    "Phillipines": function(mercator) {
      var coords = mercator([180, 0]);
      assert.inDelta(coords[0], 50, 1e-6);
      assert.inDelta(coords[1], 0, 1e-6);
      var lonlat = mercator.invert(coords);
      assert.inDelta(lonlat[0], 180, 1e-6);
      assert.inDelta(lonlat[1], 0, 1e-6);
    },
    "Inversion works for non-zero translation": function() {
      var mercator = d3.geo.mercator().translate([123, 99]).scale(100),
          coords = mercator([0, 85]),
          lonlat = mercator.invert(coords);
      assert.inDelta(lonlat[0], 0, 1e-6);
      assert.inDelta(lonlat[1], 85, 1e-6);
    }
  }
});

suite.export(module);