source: josm/trunk/test/functional/mapcss/performance/PerformanceTest.groovy @ 7040

Last change on this file since 7040 was 4087, checked in by bastiK, 12 years ago

PaintVisitor refactoring, includes hook for external MapRenderers (author: Gubaer)

  • Property svn:eol-style set to native
File size: 4.3 KB
Line 
1
2// License: GPL. For details, see LICENSE file.
3package mapcss.performance;
4
5import static org.junit.Assert.*
6
7import java.awt.Graphics2D
8import java.awt.image.BufferedImage
9
10import org.junit.*
11import org.openstreetmap.josm.Main
12import org.openstreetmap.josm.data.Bounds
13import org.openstreetmap.josm.data.osm.DataSet
14import org.openstreetmap.josm.data.osm.visitor.paint.StyledMapRenderer
15import org.openstreetmap.josm.gui.MainApplication
16import org.openstreetmap.josm.gui.layer.OsmDataLayer
17import org.openstreetmap.josm.gui.mappaint.MapPaintStyles
18import org.openstreetmap.josm.gui.mappaint.mapcss.MapCSSStyleSource
19import org.openstreetmap.josm.gui.preferences.SourceEntry
20import org.openstreetmap.josm.io.OsmReader
21
22/**
23 * This performance tests measures the time for a full run of MapPaintVisitor.visitAll()
24 * against a test data set using a test style.
25 *
26 */
27class PerformanceTest {
28
29    /* ------------------------ configuration section  ---------------------------- */
30    /**
31    * The path to the JOSM home environment
32    */
33   def static JOSM_HOME="/my/josm/home/dir"
34   
35   /**
36    * The path to the style file used for rendering.
37    */
38   def static STYLE_FILE="/my/test-style.mapcss"
39
40   /**
41    * The data file to be rendered
42    */
43   def static DATA_FILE = "/my/test-data.osm"
44    /* ------------------------ / configuration section  ---------------------------- */     
45   
46    def DataSet ds
47   
48    def static boolean checkTestEnvironment() {
49          File f = new File(JOSM_HOME)
50          if  (!f.isDirectory() || !f.exists()) {
51              fail("JOSM_HOME refers to '${JOSM_HOME}. This is either not a directory or doesn't exist.\nPlease update configuration settings in the unit test file.")             
52          }
53         
54          f = new File(STYLE_FILE);
55          if ( !f.isFile() || ! f.exists()) {
56              fail("STYLE_FILE refers to '${STYLE_FILE}. This is either not a file or doesn't exist.\nPlease update configuration settings in the unit test file.")
57          }
58         
59          f = new File(DATA_FILE);
60          if ( !f.isFile() || ! f.exists()) {
61              fail("DATA_FILE refers to '${DATA_FILE}. This is either not a file or doesn't exist.\nPlease update configuration settings in the unit test file.")
62          }
63    }
64   
65    @BeforeClass
66    public static void createJOSMFixture(){
67        checkTestEnvironment()
68        System.setProperty("josm.home", JOSM_HOME)
69        MainApplication.main(new String[0])
70    }
71   
72    def timed(Closure c){
73        long before = System.currentTimeMillis()
74        c()
75        long after = System.currentTimeMillis()
76        return after - before
77    }
78   
79    def  loadStyle() {
80        print "Loading style '$STYLE_FILE' ..."
81        MapCSSStyleSource source = new MapCSSStyleSource(
82            new SourceEntry(
83                new File(STYLE_FILE).toURI().toURL().toString(),
84                "test style",
85                "a test style",
86                true // active
87            )
88        )
89        source.loadStyleSource()
90        if (!source.errors.isEmpty()) {
91            fail("Failed to load style file ''${STYLE_FILE}''. Errors: ${source.errors}")
92        }
93        MapPaintStyles.getStyles().clear()
94        MapPaintStyles.getStyles().add(source)
95        println "DONE"
96    }
97   
98    def loadData() {
99        print "Loading data file '$DATA_FILE' ..."
100        new File(DATA_FILE).withInputStream {
101            InputStream is ->
102            ds = OsmReader.parseDataSet(is,null)
103        }
104        Main.main.addLayer(new OsmDataLayer(ds,"test layer",null /* no file */));
105        println "DONE"
106    }
107   
108    @Test
109    public void measureTimeForStylePreparation() {
110        loadStyle()
111        loadData()
112       
113        def mv = Main.map.mapView
114       
115        BufferedImage img = mv.createImage(mv.getWidth(), mv.getHeight())
116        Graphics2D g = img.createGraphics()
117        g.setClip(0,0, mv.getWidth(), mv.getHeight())
118        def visitor = new StyledMapRenderer()
119        visitor.setNavigatableComponent(Main.map.mapView)
120        visitor.setGraphics(g)
121
122        print "Rendering ..."
123        long time = timed {
124            visitor.render(ds, false, new Bounds(-90,-180,90,180))
125        }
126        println "DONE"
127        println "data file : ${DATA_FILE}"
128        println "style file: ${STYLE_FILE}"
129        println ""
130        println "Rendering took $time ms."       
131    }
132}
Note: See TracBrowser for help on using the repository browser.