source: josm/trunk/test/unit/org/openstreetmap/josm/gui/DefaultNameFormatterTest.java@ 7937

Last change on this file since 7937 was 7937, checked in by bastiK, 9 years ago

add subversion property svn:eol=native

  • Property svn:eol-style set to native
File size: 5.4 KB
Line 
1// License: GPL. For details, see LICENSE file.
2package org.openstreetmap.josm.gui;
3
4import static org.hamcrest.CoreMatchers.is;
5import static org.junit.Assert.assertThat;
6import static org.junit.Assert.assertTrue;
7
8import java.io.FileInputStream;
9import java.io.IOException;
10import java.io.InputStream;
11import java.util.ArrayList;
12import java.util.Comparator;
13
14import org.junit.BeforeClass;
15import org.junit.Test;
16import org.openstreetmap.josm.JOSMFixture;
17import org.openstreetmap.josm.TestUtils;
18import org.openstreetmap.josm.data.osm.DataSet;
19import org.openstreetmap.josm.data.osm.OsmPrimitiveType;
20import org.openstreetmap.josm.data.osm.OsmUtils;
21import org.openstreetmap.josm.data.osm.Relation;
22import org.openstreetmap.josm.data.osm.Way;
23import org.openstreetmap.josm.gui.tagging.TaggingPresetReader;
24import org.openstreetmap.josm.gui.tagging.TaggingPresets;
25import org.openstreetmap.josm.io.Compression;
26import org.openstreetmap.josm.io.IllegalDataException;
27import org.openstreetmap.josm.io.OsmReader;
28import org.xml.sax.SAXException;
29
30/**
31 * Unit tests of {@link DefaultNameFormatter} class.
32 *
33 */
34public class DefaultNameFormatterTest {
35
36 /**
37 * Setup tests
38 */
39 @BeforeClass
40 public static void setUpBeforeClass() {
41 JOSMFixture.createUnitTestFixture().init();
42 }
43
44 /**
45 * Non-regression test for ticket <a href="https://josm.openstreetmap.de/ticket/9632">#9632</a>.
46 * @throws IllegalDataException
47 * @throws IOException
48 * @throws SAXException
49 */
50 @Test
51 public void testTicket9632() throws IllegalDataException, IOException, SAXException {
52 String source = "http://josm.openstreetmap.de/josmfile?page=Presets/BicycleJunction&amp;preset";
53 TaggingPresets.addTaggingPresets(TaggingPresetReader.readAll(source, true));
54
55 Comparator<Relation> comparator = DefaultNameFormatter.getInstance().getRelationComparator();
56
57 try (InputStream is = new FileInputStream(TestUtils.getRegressionDataFile(9632, "data.osm.zip"))) {
58 DataSet ds = OsmReader.parseDataSet(Compression.ZIP.getUncompressedInputStream(is), null);
59
60 // Test with 3 known primitives causing the problem. Correct order is p1, p3, p2 with this preset
61 Relation p1 = (Relation) ds.getPrimitiveById(2983382, OsmPrimitiveType.RELATION);
62 Relation p2 = (Relation) ds.getPrimitiveById(550315, OsmPrimitiveType.RELATION);
63 Relation p3 = (Relation) ds.getPrimitiveById(167042, OsmPrimitiveType.RELATION);
64
65 System.out.println("p1: "+DefaultNameFormatter.getInstance().format(p1)+" - "+p1); // route_master ("Bus 453", 6 members)
66 System.out.println("p2: "+DefaultNameFormatter.getInstance().format(p2)+" - "+p2); // TMC ("A 6 Kaiserslautern - Mannheim [negative]", 123 members)
67 System.out.println("p3: "+DefaultNameFormatter.getInstance().format(p3)+" - "+p3); // route(lcn Sal Salier-Radweg(412 members)
68
69 assertTrue(comparator.compare(p1, p2) == -1); // p1 < p2
70 assertTrue(comparator.compare(p2, p1) == 1); // p2 > p1
71
72 assertTrue(comparator.compare(p1, p3) == -1); // p1 < p3
73 assertTrue(comparator.compare(p3, p1) == 1); // p3 > p1
74 assertTrue(comparator.compare(p2, p3) == 1); // p2 > p3
75 assertTrue(comparator.compare(p3, p2) == -1); // p3 < p2
76
77 Relation[] relations = new ArrayList<>(ds.getRelations()).toArray(new Relation[0]);
78
79 TestUtils.checkComparableContract(comparator, relations);
80 }
81 }
82
83 /**
84 * Tests formatting of relation names.
85 */
86 @Test
87 public void testRelationName() {
88 assertThat(getFormattedRelationName("X=Y"), is("relation (0, 0 members)"));
89 assertThat(getFormattedRelationName("name=Foo"), is("relation (\"Foo\", 0 members)"));
90 assertThat(getFormattedRelationName("type=route route=tram ref=123"), is("route (\"123\", 0 members)"));
91 assertThat(getFormattedRelationName("type=multipolygon building=yes"), is("multipolygon (\"building\", 0 members)"));
92 assertThat(getFormattedRelationName("type=multipolygon building=yes ref=123"), is("multipolygon (\"123\", 0 members)"));
93 assertThat(getFormattedRelationName("type=multipolygon building=yes addr:housenumber=123"), is("multipolygon (\"building\", 0 members)"));
94 assertThat(getFormattedRelationName("type=multipolygon building=residential addr:housenumber=123"), is("multipolygon (\"residential\", 0 members)"));
95 }
96
97 /**
98 * Tests formatting of way names.
99 */
100 @Test
101 public void testWayName() {
102 assertThat(getFormattedWayName("building=yes"), is("building (0 nodes)"));
103 assertThat(getFormattedWayName("building=yes addr:housenumber=123"), is("House number 123 (0 nodes)"));
104 assertThat(getFormattedWayName("building=yes addr:housenumber=123 addr:street=FooStreet"), is("House number 123 at FooStreet (0 nodes)"));
105 assertThat(getFormattedWayName("building=yes addr:housenumber=123 addr:housename=FooName"), is("House FooName (0 nodes)"));
106 }
107
108 static String getFormattedRelationName(String tagsString) {
109 return DefaultNameFormatter.getInstance().format((Relation) OsmUtils.createPrimitive("relation " + tagsString))
110 .replace("\u200E", "").replace("\u200F", "");
111 }
112
113 static String getFormattedWayName(String tagsString) {
114 return DefaultNameFormatter.getInstance().format((Way) OsmUtils.createPrimitive("way " + tagsString))
115 .replace("\u200E", "").replace("\u200F", "");
116 }
117}
Note: See TracBrowser for help on using the repository browser.