Modify

Opened 5 years ago

Last modified 4 years ago

#18204 new defect

Weird results from JoinNodeWayActionTest unit test

Reported by: GerdP Owned by: team
Priority: normal Milestone:
Component: Unit tests Version:
Keywords: Cc: ris

Description

Follow up of ticket:18189#comment:17
A unit test that tests a method which uses MainApplication.getMap().mapView may run into trouble when it doesn't use something like

        // setup a reasonable screen size
        MainApplication.getMap().mapView.setBounds(new Rectangle(1920, 1080));

before executing code that uses e.g. NavigatableComponent.getNearestWaySegments()
Without the above statement the height and width of the mapView are 0 and class NavigatableComponent doesn't seem to care about this.

I've written a patch to log an error when NavigatableComponent.getNearestWaySegments() or
NavigatableComponent.getNearestNodes() is used with a very small mapView but other methods may also suffer.
I'd prefer to have a reasonable value for width and height when unit tests are executed but I have no idea where this has to be implemented.

Attachments (1)

18204.patch (2.6 KB ) - added by GerdP 5 years ago.
experimental patch

Download all attachments as: .zip

Change History (12)

by GerdP, 5 years ago

Attachment: 18204.patch added

experimental patch

comment:1 by Don-vip, 5 years ago

Cc: ris added

comment:2 by ris, 5 years ago

I'm slightly surprised you didn't also find yourself needing to also call

mapView.addNotify();
mapView.doLayout();

to get things to start behaving themselves, but I guess your tests must skirt around needing that.

If you wanted to add something like this, the place to look would be somewhere around https://josm.openstreetmap.de/browser/josm/trunk/test/unit/org/openstreetmap/josm/testutils/JOSMTestRules.java#L577 . It might seem like it might best fit in one of the methods like JOSMFixture.initContentPane() or JOSMFixture.initMainPanel(), but note people keep saying they want to get rid of JOSMFixture entirely.

One thing people probably don't want to do is add any setup steps that will slow down the 99% of tests that don't need this, but I expect you'd be safe simply adding a setBounds call...?

Version 0, edited 5 years ago by ris (next)

comment:3 by GerdP, 5 years ago

@ris
getMap() returns null unless a layer is added.
I found that MapFrame is initialised with a hard coded 400x400 size:
https://josm.openstreetmap.de/browser/josm/trunk/src/org/openstreetmap/josm/gui/MapFrame.java#L200

A simple solution for the problem would be to do the same in the MapView constructor.

I see no performance issues as the setBounds() call simply sets the two int fields. Also, the MapView constructor isn't called frequently.

comment:4 by ris, 5 years ago

You mean the real MapView constructor?

comment:5 by GerdP, 5 years ago

Yes. I'm struggling with my Eclipse installation, the debugging ignores some breakpoints, so I still try to understand the effect of this change, but it did not seem to change the normal JOSM execution, as this overwrites the values again with real screen values.

comment:6 by ris, 5 years ago

Yeah, my position on this is the same as it was in comment 2. As for "random failures", as much as I tried to remove inter-test dependencies and side effects, I wasn't totally successful and I'm certain a few of these remain. I mentioned a way of trying to narrow this down in https://josm.openstreetmap.de/ticket/16796#comment:48

Last edited 5 years ago by ris (previous) (diff)

comment:7 by GerdP, 5 years ago

In 15561/josm:

see #18204: add code to initialize mapview to prevent random unit test results

comment:8 by GerdP, 5 years ago

In 15563/josm:

see #18204: revert r15561 which didn't help, add .projection() instead.
If this also doesn't help I'll disable the tests as I really don't know how to find out what's wrong here.

comment:9 by ris, 5 years ago

Yes, I wouldn't be surprised if this test needed .projection().

Incidentally this is why I put a lot of work into getting pre-merge tests working in github with travis and appveyor (https://travis-ci.org/openstreetmap/josm/ https://ci.appveyor.com/project/don-vip/josm), so we had ways of fixing the CI that didn't involve experimental permanent commits. In 2019, the way of getting code merged to a project is to open a "pull request"/"merge request"/etc, which will get multi-platform CI run on it from the moment the ticket is opened. And importantly, merge will not be allowed until the CI passes. I can't even begin to describe what this workflow has done for my productivity in recent years.

I can't say what the current status of the travis/appveyor support is - I stopped because I just didn't get buy-in from anyone else and it doesn't work as a one-man-battle.

comment:10 by GerdP, 5 years ago

In 15575/josm:

see #18204: - ignore tests until a fix is provided

comment:11 by simon04, 4 years ago

Summary: Weird results from unit testWeird results from JoinNodeWayActionTest unit test

Modify Ticket

Change Properties
Set your email in Preferences
Action
as new The owner will remain team.
as The resolution will be set. Next status will be 'closed'.
to The owner will be changed from team to the specified user.
Next status will be 'needinfo'. The owner will be changed from team to GerdP.
as duplicate The resolution will be set to duplicate. Next status will be 'closed'. The specified ticket will be cross-referenced with this ticket.
The owner will be changed from team to anonymous. Next status will be 'assigned'.

Add Comment


E-mail address and name can be saved in the Preferences .
 
Note: See TracTickets for help on using tickets.