mirror of
https://github.com/FoggedLens/iD.git
synced 2026-02-13 01:02:58 +00:00
185 lines
8.1 KiB
JavaScript
185 lines
8.1 KiB
JavaScript
describe('iD.actionStraightenWay', function () {
|
|
var projection = d3.geoMercator();
|
|
|
|
describe('#disabled', function () {
|
|
it('returns falsy for ways with internal nodes near centerline', function () {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 0.01]}),
|
|
iD.osmNode({id: 'c', loc: [2, 0]}),
|
|
iD.osmNode({id: 'd', loc: [3, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c', 'd']})
|
|
]);
|
|
expect(iD.actionStraightenWay(['-'], projection).disabled(graph)).not.to.be.ok;
|
|
});
|
|
|
|
it('returns \'too_bendy\' for ways with internal nodes far off centerline', function () {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 1]}),
|
|
iD.osmNode({id: 'c', loc: [2, 0]}),
|
|
iD.osmNode({id: 'd', loc: [3, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c', 'd']})
|
|
]);
|
|
expect(iD.actionStraightenWay(['-'], projection).disabled(graph)).to.equal('too_bendy');
|
|
});
|
|
|
|
it('returns \'too_bendy\' for ways with coincident start/end nodes', function () {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 0]}),
|
|
iD.osmNode({id: 'c', loc: [2, 0]}),
|
|
iD.osmNode({id: 'd', loc: [0, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c', 'd']})
|
|
]);
|
|
expect(iD.actionStraightenWay(['-'], projection).disabled(graph)).to.equal('too_bendy');
|
|
});
|
|
});
|
|
|
|
|
|
it('deletes empty nodes', function() {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 0.01], tags: {}}),
|
|
iD.osmNode({id: 'c', loc: [2, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c']})
|
|
]);
|
|
|
|
graph = iD.actionStraightenWay(['-'], projection)(graph);
|
|
expect(graph.entity('-').nodes).to.eql(['a', 'c']);
|
|
expect(graph.hasEntity('b')).to.eq(undefined);
|
|
});
|
|
|
|
it('does not delete tagged nodes', function() {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 0.01], tags: {foo: 'bar'}}),
|
|
iD.osmNode({id: 'c', loc: [2, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c']})
|
|
]);
|
|
|
|
graph = iD.actionStraightenWay(['-'], projection)(graph);
|
|
expect(graph.entity('-').nodes).to.eql(['a', 'b', 'c']);
|
|
expect(graph.entity('b').loc[0]).to.be.closeTo(1, 1e-6);
|
|
expect(graph.entity('b').loc[1]).to.be.closeTo(0, 1e-6);
|
|
});
|
|
|
|
it('does not delete nodes connected to other ways', function() {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 0.01]}),
|
|
iD.osmNode({id: 'c', loc: [2, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c']}),
|
|
iD.osmWay({id: '=', nodes: ['b']})
|
|
]);
|
|
|
|
graph = iD.actionStraightenWay(['-'], projection)(graph);
|
|
expect(graph.entity('-').nodes).to.eql(['a', 'b', 'c']);
|
|
expect(graph.entity('b').loc[0]).to.be.closeTo(1, 1e-6);
|
|
expect(graph.entity('b').loc[1]).to.be.closeTo(0, 1e-6);
|
|
});
|
|
|
|
it('straightens multiple, connected ways', function() {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 0.01], tags: {foo: 'bar'}}),
|
|
iD.osmNode({id: 'c', loc: [2, -0.01]}),
|
|
iD.osmNode({id: 'd', loc: [3, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c', 'd']}),
|
|
|
|
iD.osmNode({id: 'e', loc: [4, 0]}),
|
|
iD.osmNode({id: 'f', loc: [5, 0.01], tags: {foo: 'bar'}}),
|
|
iD.osmNode({id: 'g', loc: [6, -0.01]}),
|
|
iD.osmNode({id: 'h', loc: [7, 0]}),
|
|
iD.osmWay({id: '--', nodes: ['d', 'e', 'f', 'g', 'h']})
|
|
]);
|
|
|
|
graph = iD.actionStraightenWay(['-', '--'], projection)(graph);
|
|
expect(graph.entity('-').nodes).to.eql(['a', 'b', 'd']);
|
|
expect(graph.entity('--').nodes).to.eql(['d', 'f', 'h']);
|
|
expect(graph.entity('f').loc[0]).to.be.closeTo(5, 1e-6);
|
|
expect(graph.entity('f').loc[1]).to.be.closeTo(0, 1e-6);
|
|
expect(graph.hasEntity('g')).to.eq(undefined);
|
|
});
|
|
|
|
it('straightens multiple, connected ways going in different directions', function() {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 0.01], tags: {foo: 'bar'}}),
|
|
iD.osmNode({id: 'c', loc: [2, -0.01]}),
|
|
iD.osmNode({id: 'd', loc: [3, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c', 'd']}),
|
|
|
|
iD.osmNode({id: 'e', loc: [4, 0]}),
|
|
iD.osmNode({id: 'f', loc: [5, 0.01], tags: {foo: 'bar'}}),
|
|
iD.osmNode({id: 'g', loc: [6, -0.01]}),
|
|
iD.osmNode({id: 'h', loc: [7, 0]}),
|
|
iD.osmWay({id: '--', nodes: ['h', 'g', 'f', 'e', 'd']})
|
|
]);
|
|
|
|
graph = iD.actionStraightenWay(['-', '--'], projection)(graph);
|
|
expect(graph.entity('-').nodes).to.eql(['a', 'b', 'd']);
|
|
expect(graph.entity('--').nodes).to.eql(['h', 'f', 'd']);
|
|
expect(graph.entity('f').loc[0]).to.be.closeTo(5, 1e-6);
|
|
expect(graph.entity('f').loc[1]).to.be.closeTo(0, 1e-6);
|
|
expect(graph.hasEntity('g')).to.eq(undefined);
|
|
});
|
|
|
|
describe('transitions', function () {
|
|
it('is transitionable', function() {
|
|
expect(iD.actionStraightenWay().transitionable).to.be.true;
|
|
});
|
|
|
|
it('straighten at t = 0', function() {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 0.01], tags: {foo: 'bar'}}),
|
|
iD.osmNode({id: 'c', loc: [2, -0.01]}),
|
|
iD.osmNode({id: 'd', loc: [3, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c', 'd']})
|
|
]);
|
|
|
|
graph = iD.actionStraightenWay(['-'], projection)(graph, 0);
|
|
expect(graph.entity('-').nodes).to.eql(['a', 'b', 'c', 'd']);
|
|
expect(graph.entity('b').loc[0]).to.be.closeTo(1, 1e-6);
|
|
expect(graph.entity('b').loc[1]).to.be.closeTo(0.01, 1e-6);
|
|
expect(graph.entity('c').loc[0]).to.be.closeTo(2, 1e-6);
|
|
expect(graph.entity('c').loc[1]).to.be.closeTo(-0.01, 1e-6);
|
|
});
|
|
|
|
it('straighten at t = 0.5', function() {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 0.01], tags: {foo: 'bar'}}),
|
|
iD.osmNode({id: 'c', loc: [2, -0.01]}),
|
|
iD.osmNode({id: 'd', loc: [3, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c', 'd']})
|
|
]);
|
|
|
|
graph = iD.actionStraightenWay(['-'], projection)(graph, 0.5);
|
|
expect(graph.entity('-').nodes).to.eql(['a', 'b', 'c', 'd']);
|
|
expect(graph.entity('b').loc[0]).to.be.closeTo(1, 1e-6);
|
|
expect(graph.entity('b').loc[1]).to.be.closeTo(0.005, 1e-6);
|
|
expect(graph.entity('c').loc[0]).to.be.closeTo(2, 1e-6);
|
|
expect(graph.entity('c').loc[1]).to.be.closeTo(-0.005, 1e-6);
|
|
});
|
|
|
|
it('straighten at t = 1', function() {
|
|
var graph = iD.coreGraph([
|
|
iD.osmNode({id: 'a', loc: [0, 0]}),
|
|
iD.osmNode({id: 'b', loc: [1, 0.01], tags: {foo: 'bar'}}),
|
|
iD.osmNode({id: 'c', loc: [2, -0.01]}),
|
|
iD.osmNode({id: 'd', loc: [3, 0]}),
|
|
iD.osmWay({id: '-', nodes: ['a', 'b', 'c', 'd']})
|
|
]);
|
|
|
|
graph = iD.actionStraightenWay(['-'], projection)(graph, 1);
|
|
expect(graph.entity('-').nodes).to.eql(['a', 'b', 'd']);
|
|
expect(graph.entity('b').loc[0]).to.be.closeTo(1, 1e-6);
|
|
expect(graph.entity('b').loc[1]).to.be.closeTo(0, 1e-6);
|
|
expect(graph.hasEntity('c')).to.eq(undefined);
|
|
});
|
|
});
|
|
|
|
});
|