2023-07-15 18:55:03 +02:00
import { Utils } from "../../../../src/Utils"
import LayoutConfig from "../../../../src/Models/ThemeConfig/LayoutConfig"
import { BBox } from "../../../../src/Logic/BBox"
import ReplaceGeometryAction from "../../../../src/Logic/Osm/Actions/ReplaceGeometryAction"
2023-02-03 04:48:32 +01:00
import { describe , expect , it } from "vitest"
2023-07-15 18:55:03 +02:00
import { OsmConnection } from "../../../../src/Logic/Osm/OsmConnection"
import { ImmutableStore } from "../../../../src/Logic/UIEventSource"
import { Changes } from "../../../../src/Logic/Osm/Changes"
import FullNodeDatabaseSource from "../../../../src/Logic/FeatureSource/TiledFeatureSource/FullNodeDatabaseSource"
2022-03-23 19:48:06 +01:00
describe ( "ReplaceGeometryAction" , ( ) = > {
2022-09-08 21:40:48 +02:00
const grbStripped = {
id : "grb" ,
title : {
nl : "GRB import helper" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
description : "Smaller version of the GRB theme" ,
language : [ "nl" , "en" ] ,
2022-03-23 19:48:06 +01:00
socialImage : "img.jpg" ,
2022-09-08 21:40:48 +02:00
version : "0" ,
startLat : 51.0249 ,
startLon : 4.026489 ,
startZoom : 9 ,
clustering : false ,
overrideAll : {
minzoom : 19 ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
layers : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
id : "type_node" ,
2022-03-23 19:48:06 +01:00
source : {
2022-09-08 21:40:48 +02:00
osmTags : "type=node" ,
2022-03-23 19:48:06 +01:00
} ,
2023-10-12 16:55:26 +02:00
pointRendering : null ,
lineRendering : [ { } ] ,
2022-09-08 21:40:48 +02:00
override : {
calculatedTags : [
2022-03-23 19:48:06 +01:00
"_is_part_of_building=feat.get('parent_ways')?.some(p => p.building !== undefined && p.building !== '') ?? false" ,
"_is_part_of_grb_building=feat.get('parent_ways')?.some(p => p['source:geometry:ref'] !== undefined) ?? false" ,
"_is_part_of_building_passage=feat.get('parent_ways')?.some(p => p.tunnel === 'building_passage') ?? false" ,
"_is_part_of_highway=!feat.get('is_part_of_building_passage') && (feat.get('parent_ways')?.some(p => p.highway !== undefined && p.highway !== '') ?? false)" ,
"_is_part_of_landuse=feat.get('parent_ways')?.some(p => (p.landuse !== undefined && p.landuse !== '') || (p.natural !== undefined && p.natural !== '')) ?? false" ,
2022-09-08 21:40:48 +02:00
"_moveable=feat.get('_is_part_of_building') && !feat.get('_is_part_of_grb_building')" ,
2022-03-23 19:48:06 +01:00
] ,
2023-10-12 16:55:26 +02:00
pointRendering : [
2022-03-23 19:48:06 +01:00
{
2023-10-12 16:55:26 +02:00
marker : [
{
icon : "square" ,
color : "#cc0" ,
} ,
] ,
2023-06-20 10:40:27 +02:00
iconSize : "5,5" ,
2022-09-08 21:40:48 +02:00
location : [ "point" ] ,
} ,
2022-03-23 19:48:06 +01:00
] ,
2022-09-08 21:40:48 +02:00
passAllFeatures : true ,
} ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
id : "osm-buildings" ,
name : "All OSM-buildings" ,
source : {
osmTags : "building~*" ,
maxCacheAge : 0 ,
} ,
calculatedTags : [ "_surface:strict:=feat.get('_surface')" ] ,
2023-10-12 16:55:26 +02:00
lineRendering : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
width : {
render : "2" ,
mappings : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
if : "fixme~*" ,
then : "5" ,
} ,
] ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
color : {
render : "#00c" ,
mappings : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
if : "fixme~*" ,
then : "#ff00ff" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=house" ,
then : "#a00" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=shed" ,
then : "#563e02" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : {
or : [ "building=garage" , "building=garages" ] ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
then : "#f9bfbb" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=yes" ,
then : "#0774f2" ,
} ,
] ,
} ,
} ,
2022-03-23 19:48:06 +01:00
] ,
2022-09-08 21:40:48 +02:00
title : "OSM-gebouw" ,
tagRenderings : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
id : "building type" ,
freeform : {
key : "building" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
render : "The building type is <b>{building}</b>" ,
question : {
en : "What kind of building is this?" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
mappings : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
if : "building=house" ,
then : "A normal house" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=detached" ,
then : "A house detached from other building" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=semidetached_house" ,
then : "A house sharing only one wall with another house" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=apartments" ,
then : "An apartment building - highrise for living" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=office" ,
then : "An office building - highrise for work" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=apartments" ,
then : "An apartment building" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=shed" ,
then : "A small shed, e.g. in a garden" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=garage" ,
then : "A single garage to park a car" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=garages" ,
then : "A building containing only garages; typically they are all identical" ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
if : "building=yes" ,
then : "A building - no specification" ,
} ,
] ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
id : "grb-housenumber" ,
render : {
nl : "Het huisnummer is <b>{addr:housenumber}</b>" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
question : {
nl : "Wat is het huisnummer?" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
freeform : {
key : "addr:housenumber" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
mappings : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
if : {
and : [ "not:addr:housenumber=yes" , "addr:housenumber=" ] ,
} ,
then : {
nl : "Geen huisnummer" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
} ,
] ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
id : "grb-unit" ,
question : "Wat is de wooneenheid-aanduiding?" ,
render : {
nl : "De wooneenheid-aanduiding is <b>{addr:unit}</b> " ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
freeform : {
key : "addr:unit" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
mappings : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
if : "addr:unit=" ,
then : "Geen wooneenheid-nummer" ,
} ,
] ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
id : "grb-street" ,
render : {
nl : "De straat is <b>{addr:street}</b>" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
freeform : {
key : "addr:street" ,
} ,
question : {
nl : "Wat is de straat?" ,
2022-03-23 19:48:06 +01:00
} ,
} ,
{
2022-09-08 21:40:48 +02:00
id : "grb-fixme" ,
render : {
nl : "De fixme is <b>{fixme}</b>" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
question : {
nl : "Wat zegt de fixme?" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
freeform : {
key : "fixme" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
mappings : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
if : {
and : [ "fixme=" ] ,
} ,
then : {
nl : "Geen fixme" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
} ,
] ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
id : "grb-min-level" ,
render : {
nl : "Dit gebouw begint maar op de {building:min_level} verdieping" ,
} ,
question : {
nl : "Hoeveel verdiepingen ontbreken?" ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
freeform : {
key : "building:min_level" ,
type : "pnat" ,
2022-03-23 19:48:06 +01:00
} ,
} ,
2022-09-08 21:40:48 +02:00
"all_tags" ,
2022-03-23 19:48:06 +01:00
] ,
2022-09-08 21:40:48 +02:00
filter : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
id : "has-fixme" ,
options : [
2022-03-23 19:48:06 +01:00
{
2022-09-08 21:40:48 +02:00
osmTags : "fixme~*" ,
question : "Heeft een FIXME" ,
} ,
] ,
} ,
] ,
2022-03-23 19:48:06 +01:00
} ,
{
2022-09-08 21:40:48 +02:00
id : "grb" ,
description : "Geometry which comes from GRB with tools to import them" ,
source : {
osmTags : {
and : [ "HUISNR~*" , "man_made!=mast" ] ,
2022-03-23 19:48:06 +01:00
} ,
2022-09-08 21:40:48 +02:00
geoJson :
"https://betadata.grbosm.site/grb?bbox={x_min},{y_min},{x_max},{y_max}" ,
geoJsonZoomLevel : 18 ,
mercatorCrs : true ,
maxCacheAge : 0 ,
} ,
name : "GRB geometries" ,
title : "GRB outline" ,
calculatedTags : [
2022-03-23 19:48:06 +01:00
"_overlaps_with_buildings=feat.overlapWith('osm-buildings').filter(f => f.feat.properties.id.indexOf('-') < 0)" ,
"_overlaps_with=feat.get('_overlaps_with_buildings').filter(f => f.overlap > 1 /* square meter */ )[0] ?? ''" ,
"_osm_obj:source:ref=feat.get('_overlaps_with')?.feat?.properties['source:geometry:ref']" ,
"_osm_obj:id=feat.get('_overlaps_with')?.feat?.properties?.id" ,
"_osm_obj:source:date=feat.get('_overlaps_with')?.feat?.properties['source:geometry:date'].replace(/\\//g, '-')" ,
"_osm_obj:building=feat.get('_overlaps_with')?.feat?.properties?.building" ,
"_osm_obj:addr:street=(feat.get('_overlaps_with')?.feat?.properties ?? {})['addr:street']" ,
"_osm_obj:addr:housenumber=(feat.get('_overlaps_with')?.feat?.properties ?? {})['addr:housenumber']" ,
"_osm_obj:surface=(feat.get('_overlaps_with')?.feat?.properties ?? {})['_surface:strict']" ,
"_overlap_absolute=feat.get('_overlaps_with')?.overlap" ,
"_reverse_overlap_percentage=Math.round(100 * feat.get('_overlap_absolute') / feat.get('_surface'))" ,
"_overlap_percentage=Math.round(100 * feat.get('_overlap_absolute') / feat.get('_osm_obj:surface'))" ,
"_grb_ref=feat.properties['source:geometry:entity'] + '/' + feat.properties['source:geometry:oidn']" ,
"_imported_osm_object_found= feat.properties['_osm_obj:source:ref'] == feat.properties._grb_ref" ,
"_grb_date=feat.properties['source:geometry:date'].replace(/\\//g,'-')" ,
"_imported_osm_still_fresh= feat.properties['_osm_obj:source:date'] == feat.properties._grb_date" ,
"_target_building_type=feat.properties['_osm_obj:building'] === 'yes' ? feat.properties.building : (feat.properties['_osm_obj:building'] ?? feat.properties.building)" ,
"_building:min_level= feat.properties['fixme']?.startsWith('verdieping, correct the building tag, add building:level and building:min_level before upload in JOSM!') ? '1' : ''" ,
2022-09-08 21:40:48 +02:00
"_intersects_with_other_features=feat.intersectionsWith('generic_osm_object').map(f => \"<a href='https://osm.org/\"+f.feat.properties.id+\"' target='_blank'>\" + f.feat.properties.id + \"</a>\").join(', ')" ,
2022-03-23 19:48:06 +01:00
] ,
2022-09-08 21:40:48 +02:00
tagRenderings : [ ] ,
2023-10-12 16:55:26 +02:00
pointRendering : [
2022-03-23 19:48:06 +01:00
{
2023-10-12 16:55:26 +02:00
marker : [
{
icon : "./assets/themes/grb/housenumber_blank.svg" ,
} ,
] ,
2023-06-20 10:40:27 +02:00
iconSize : "50,50" ,
2022-09-08 21:40:48 +02:00
location : [ "point" , "centroid" ] ,
} ,
] ,
} ,
] ,
2022-03-23 19:48:06 +01:00
}
const coordinates = < [ number , number ] [ ] > [
2022-09-08 21:40:48 +02:00
[ 3.216690793633461 , 51.21474084112525 ] ,
[ 3.2167256623506546 , 51.214696737309964 ] ,
[ 3.2169999182224274 , 51.214768983537674 ] ,
[ 3.2169650495052338 , 51.21480720678671 ] ,
[ 3.2169368863105774 , 51.21480090625335 ] ,
[ 3.2169489562511444 , 51.21478074454077 ] ,
[ 3.216886594891548 , 51.214765203214625 ] ,
[ 3.2168812304735184 , 51.21477192378873 ] ,
[ 3.2168644666671753 , 51.214768983537674 ] ,
[ 3.2168537378311157 , 51.21478746511261 ] ,
[ 3.216690793633461 , 51.21474084112525 ] ,
2022-03-23 19:48:06 +01:00
]
const targetFeature = {
type : "Feature" ,
properties : { } ,
geometry : {
type : "Polygon" ,
2022-09-08 21:40:48 +02:00
coordinates : [ coordinates ] ,
} ,
2022-03-23 19:48:06 +01:00
}
const wayId = "way/160909312"
Utils . injectJsonDownloadForTests (
"https://www.openstreetmap.org/api/0.6/map.json?bbox=3.2166673243045807,51.21467321525788,3.217007964849472,51.21482442824023" ,
{
2022-09-08 21:40:48 +02:00
version : "0.6" ,
generator : "CGImap 0.8.6 (1549677 spike-06.openstreetmap.org)" ,
copyright : "OpenStreetMap and contributors" ,
attribution : "http://www.openstreetmap.org/copyright" ,
license : "http://opendatacommons.org/licenses/odbl/1-0/" ,
bounds : { minlat : 51.2146732 , minlon : 3.2166673 , maxlat : 51.2148244 , maxlon : 3.217008 } ,
elements : [
{
type : "node" ,
id : 1612385157 ,
lat : 51.2148016 ,
lon : 3.2168453 ,
timestamp : "2018-04-30T12:26:00Z" ,
version : 3 ,
changeset : 58553478 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 1728816256 ,
lat : 51.2147111 ,
lon : 3.2170233 ,
timestamp : "2017-07-18T22:52:44Z" ,
version : 2 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 1728816287 ,
lat : 51.2146408 ,
lon : 3.2167601 ,
timestamp : "2021-10-29T16:24:43Z" ,
version : 3 ,
changeset : 113131915 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 1728823481 ,
lat : 51.2146968 ,
lon : 3.2167242 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 5 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 1728823499 ,
lat : 51.2147127 ,
lon : 3.2170302 ,
timestamp : "2017-07-18T22:52:45Z" ,
version : 2 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 1728823501 ,
lat : 51.2148696 ,
lon : 3.2168941 ,
timestamp : "2017-07-18T22:52:45Z" ,
version : 2 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 1728823514 ,
lat : 51.2147863 ,
lon : 3.2168551 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 5 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 1728823522 ,
lat : 51.2148489 ,
lon : 3.2169012 ,
timestamp : "2017-07-18T22:52:45Z" ,
version : 2 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 1728823523 ,
lat : 51.2147578 ,
lon : 3.2169995 ,
timestamp : "2017-07-18T22:52:45Z" ,
version : 2 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 1728823543 ,
lat : 51.2148075 ,
lon : 3.2166445 ,
timestamp : "2017-07-18T22:52:46Z" ,
version : 3 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 1728823544 ,
lat : 51.2148553 ,
lon : 3.2169315 ,
timestamp : "2017-07-18T22:52:46Z" ,
version : 2 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 1728823549 ,
lat : 51.2147401 ,
lon : 3.2168877 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 5 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978288376 ,
lat : 51.2147306 ,
lon : 3.2168928 ,
timestamp : "2017-07-18T22:52:21Z" ,
version : 1 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 4978288381 ,
lat : 51.2147638 ,
lon : 3.2168856 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 4 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978288382 ,
lat : 51.2148189 ,
lon : 3.216912 ,
timestamp : "2017-07-18T22:52:21Z" ,
version : 1 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 4978288385 ,
lat : 51.2148835 ,
lon : 3.2170623 ,
timestamp : "2017-07-18T22:52:21Z" ,
version : 1 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 4978288387 ,
lat : 51.2148904 ,
lon : 3.2171037 ,
timestamp : "2017-07-18T22:52:21Z" ,
version : 1 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 4978289383 ,
lat : 51.2147678 ,
lon : 3.2169969 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 4 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978289384 ,
lat : 51.2147684 ,
lon : 3.2168674 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 4 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978289386 ,
lat : 51.2147716 ,
lon : 3.2168811 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 4 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978289388 ,
lat : 51.2148115 ,
lon : 3.216966 ,
timestamp : "2021-11-02T23:38:13Z" ,
version : 7 ,
changeset : 113306325 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978289391 ,
lat : 51.2148019 ,
lon : 3.2169194 ,
timestamp : "2017-07-18T22:52:21Z" ,
version : 1 ,
changeset : 50391526 ,
user : "catweazle67" ,
uid : 1976209 ,
} ,
{
type : "node" ,
id : 9219974337 ,
lat : 51.2148449 ,
lon : 3.2171278 ,
timestamp : "2021-11-02T23:40:52Z" ,
version : 1 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 9219979643 ,
lat : 51.2147405 ,
lon : 3.216693 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 1 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 9219979646 ,
lat : 51.2148043 ,
lon : 3.2169312 ,
timestamp : "2021-11-02T23:38:13Z" ,
version : 2 ,
changeset : 113306325 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 9219979647 ,
lat : 51.2147792 ,
lon : 3.2169466 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 1 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "way" ,
id : 160909311 ,
timestamp : "2021-12-23T12:03:37Z" ,
version : 6 ,
changeset : 115295690 ,
user : "s8evq" ,
uid : 3710738 ,
nodes : [
1728823481 , 1728823549 , 4978288376 , 1728823523 , 1728823499 , 1728816256 ,
1728816287 , 1728823481 ,
] ,
tags : {
"addr:city" : "Brugge" ,
"addr:country" : "BE" ,
"addr:housenumber" : "106" ,
"addr:postcode" : "8000" ,
"addr:street" : "Ezelstraat" ,
building : "house" ,
"source:geometry:date" : "2015-07-09" ,
"source:geometry:ref" : "Gbg/2391617" ,
} ,
} ,
{
type : "way" ,
id : 160909312 ,
timestamp : "2021-11-02T23:38:13Z" ,
version : 4 ,
changeset : 113306325 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
nodes : [
9219979643 , 1728823481 , 1728823549 , 4978289383 , 4978289388 , 9219979646 ,
9219979647 , 4978288381 , 4978289386 , 4978289384 , 1728823514 , 9219979643 ,
] ,
tags : {
"addr:city" : "Brugge" ,
"addr:country" : "BE" ,
"addr:housenumber" : "108" ,
"addr:postcode" : "8000" ,
"addr:street" : "Ezelstraat" ,
building : "house" ,
"source:geometry:date" : "2018-10-02" ,
"source:geometry:ref" : "Gbg/5926383" ,
} ,
} ,
{
type : "way" ,
id : 160909315 ,
timestamp : "2021-12-23T12:03:37Z" ,
version : 8 ,
changeset : 115295690 ,
user : "s8evq" ,
uid : 3710738 ,
nodes : [
1728823543 , 1728823501 , 1728823522 , 4978288382 , 1612385157 , 1728823514 ,
9219979643 , 1728823543 ,
] ,
tags : {
"addr:city" : "Brugge" ,
"addr:country" : "BE" ,
"addr:housenumber" : "110" ,
"addr:postcode" : "8000" ,
"addr:street" : "Ezelstraat" ,
building : "house" ,
name : "La Style" ,
shop : "hairdresser" ,
"source:geometry:date" : "2015-07-09" ,
"source:geometry:ref" : "Gbg/5260837" ,
} ,
} ,
{
type : "way" ,
id : 508533816 ,
timestamp : "2021-12-23T12:03:37Z" ,
version : 7 ,
changeset : 115295690 ,
user : "s8evq" ,
uid : 3710738 ,
nodes : [
4978288387 , 4978288385 , 1728823544 , 1728823522 , 4978288382 , 4978289391 ,
9219979646 , 4978289388 , 9219974337 , 4978288387 ,
] ,
tags : {
building : "yes" ,
"source:geometry:date" : "2015-07-09" ,
"source:geometry:ref" : "Gbg/5260790" ,
} ,
} ,
] ,
2022-03-23 19:48:06 +01:00
}
)
2022-09-08 21:40:48 +02:00
Utils . injectJsonDownloadForTests ( "https://www.openstreetmap.org/api/0.6/way/160909312/full" , {
version : "0.6" ,
generator : "CGImap 0.8.6 (2407324 spike-06.openstreetmap.org)" ,
copyright : "OpenStreetMap and contributors" ,
attribution : "http://www.openstreetmap.org/copyright" ,
license : "http://opendatacommons.org/licenses/odbl/1-0/" ,
elements : [
{
type : "node" ,
id : 1728823481 ,
lat : 51.2146968 ,
lon : 3.2167242 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 5 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 1728823514 ,
lat : 51.2147863 ,
lon : 3.2168551 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 5 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 1728823549 ,
lat : 51.2147401 ,
lon : 3.2168877 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 5 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978288381 ,
lat : 51.2147638 ,
lon : 3.2168856 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 4 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978289383 ,
lat : 51.2147678 ,
lon : 3.2169969 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 4 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978289384 ,
lat : 51.2147684 ,
lon : 3.2168674 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 4 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978289386 ,
lat : 51.2147716 ,
lon : 3.2168811 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 4 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 4978289388 ,
lat : 51.2148115 ,
lon : 3.216966 ,
timestamp : "2021-11-02T23:38:13Z" ,
version : 7 ,
changeset : 113306325 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 9219979643 ,
lat : 51.2147405 ,
lon : 3.216693 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 1 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 9219979646 ,
lat : 51.2148043 ,
lon : 3.2169312 ,
timestamp : "2021-11-02T23:38:13Z" ,
version : 2 ,
changeset : 113306325 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "node" ,
id : 9219979647 ,
lat : 51.2147792 ,
lon : 3.2169466 ,
timestamp : "2021-11-02T23:37:11Z" ,
version : 1 ,
changeset : 113305401 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
} ,
{
type : "way" ,
id : 160909312 ,
timestamp : "2021-11-02T23:38:13Z" ,
version : 4 ,
changeset : 113306325 ,
user : "Pieter Vander Vennet" ,
uid : 3818858 ,
nodes : [
9219979643 , 1728823481 , 1728823549 , 4978289383 , 4978289388 , 9219979646 ,
9219979647 , 4978288381 , 4978289386 , 4978289384 , 1728823514 , 9219979643 ,
] ,
tags : {
2022-03-23 19:48:06 +01:00
"addr:city" : "Brugge" ,
"addr:country" : "BE" ,
"addr:housenumber" : "108" ,
"addr:postcode" : "8000" ,
"addr:street" : "Ezelstraat" ,
2022-09-08 21:40:48 +02:00
building : "house" ,
2022-03-23 19:48:06 +01:00
"source:geometry:date" : "2018-10-02" ,
2022-09-08 21:40:48 +02:00
"source:geometry:ref" : "Gbg/5926383" ,
} ,
} ,
] ,
} )
Utils . injectJsonDownloadForTests (
"https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/latlon2country/0.0.0.json" ,
"be"
2022-03-23 19:48:06 +01:00
)
2022-09-08 21:40:48 +02:00
it ( "should move nodes accordingly" , async ( ) = > {
2022-03-23 19:48:06 +01:00
2022-09-08 21:40:48 +02:00
const bbox = new BBox ( [
[ 3.2166673243045807 , 51.21467321525788 ] ,
[ 3.217007964849472 , 51.21482442824023 ] ,
2022-03-23 19:48:06 +01:00
] )
2022-09-08 21:40:48 +02:00
const url = ` https://www.openstreetmap.org/api/0.6/map.json?bbox= ${ bbox . minLon } , ${ bbox . minLat } , ${ bbox . maxLon } , ${ bbox . maxLat } `
const data = await Utils . downloadJson ( url )
2023-06-01 02:52:21 +02:00
const fullNodeDatabase = new FullNodeDatabaseSource ( )
fullNodeDatabase . handleOsmJson ( data , 0 , 0 , 0 )
2023-04-15 02:28:24 +02:00
const changes = new Changes ( {
dryRun : new ImmutableStore ( true ) ,
2023-06-14 20:39:36 +02:00
osmConnection : new OsmConnection ( ) ,
2023-04-15 02:28:24 +02:00
} )
2023-04-07 03:54:11 +02:00
const osmConnection = new OsmConnection ( {
dryRun : new ImmutableStore ( true ) ,
2022-09-08 21:40:48 +02:00
} )
2023-04-07 03:54:11 +02:00
const action = new ReplaceGeometryAction (
{ osmConnection , fullNodeDatabase } ,
targetFeature ,
wayId ,
{
theme : "test" ,
}
)
2022-03-23 19:48:06 +01:00
2022-09-08 21:40:48 +02:00
const closestIds = await action . GetClosestIds ( )
2023-02-03 04:48:32 +01:00
expect ( closestIds . closestIds ) . toEqual ( [
2022-09-08 21:40:48 +02:00
9219979643 ,
1728823481 ,
4978289383 ,
4978289388 ,
9219979646 ,
9219979647 ,
4978288381 ,
4978289386 ,
4978289384 ,
1728823514 ,
undefined ,
] )
2022-03-23 19:48:06 +01:00
2023-02-03 04:48:32 +01:00
expect ( closestIds . reprojectedNodes . size ) . toEqual ( 1 )
2022-09-08 21:40:48 +02:00
const reproj = closestIds . reprojectedNodes . get ( 1728823549 )
2023-02-03 04:48:32 +01:00
expect ( reproj . projectAfterIndex ) . toEqual ( 1 )
expect ( reproj . newLon ) . toEqual ( 3.2168880864669203 )
expect ( reproj . newLat ) . toEqual ( 51.214739524104694 )
expect ( closestIds . detachedNodes . size ) . toEqual ( 0 )
2023-04-07 03:54:11 +02:00
const changed = await action . Perform ( changes )
expect ( changed [ 11 ] . changes [ "coordinates" ] ) . toEqual ( [
2022-09-08 21:40:48 +02:00
[ 3.216690793633461 , 51.21474084112525 ] ,
[ 3.2167256623506546 , 51.214696737309964 ] ,
[ 3.2168880864669203 , 51.214739524104694 ] ,
[ 3.2169999182224274 , 51.214768983537674 ] ,
[ 3.2169650495052338 , 51.21480720678671 ] ,
[ 3.2169368863105774 , 51.21480090625335 ] ,
[ 3.2169489562511444 , 51.21478074454077 ] ,
[ 3.216886594891548 , 51.214765203214625 ] ,
[ 3.2168812304735184 , 51.21477192378873 ] ,
[ 3.2168644666671753 , 51.214768983537674 ] ,
[ 3.2168537378311157 , 51.21478746511261 ] ,
[ 3.216690793633461 , 51.21474084112525 ] ,
] )
} )
2022-03-23 19:48:06 +01:00
} )