-
-
Notifications
You must be signed in to change notification settings - Fork 358
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Upload bulk of answer in a single changeset #21
Comments
Why?
…On 21 March 2017 14:55:13 CET, Haikuch ***@***.***> wrote:
when working offline and collecting several answers, they will be
uploaded each in single changesets. I would be better to collect them
in one single upload changeset.
--
You are receiving this because you are subscribed to this thread.
Reply to this email directly or view it on GitHub:
#21
--
Diese Nachricht wurde von meinem Android-Mobiltelefon mit K-9 Mail gesendet.
|
Uploading each change in a single atomic commit is a feature, actually. It allows the app to easily resolve conflicts (which it already does), a feature I wouldn't want to miss for a surveyor tool that claims to work offline. So, I won't change this. |
Sorry, but this isn't an argument. And if you just group one feature (e.g. Add building levels) to one changeset? Your app is just fine ... for single dedicated tasks. But if you have 500 tasks about "add building levels" in your village, it doesn't really make sense to atomic commits |
To elaborate on my "Why?":
What is the gain here that justifies to invest the effort to change the working implementation away from easy conflict handling, easy stats generation (the number next to the star) and atomic commits?
…On 23 March 2017 14:19:03 CET, Harald Hartmann ***@***.***> wrote:
> Also, having one changeset per change is actually also easier to
implement.
Sorry, but this isn't an argument.
And if you just group one feature (e.g. Add building levels) to one
changeset?
Your app is just fine ... for single dedicated tasks. But if you have
500 tasks about "add building levels" in your village, it doesn't
really make sense to atomic commits
--
You are receiving this because you modified the open/close state.
Reply to this email directly or view it on GitHub:
#21 (comment)
--
Diese Nachricht wurde von meinem Android-Mobiltelefon mit K-9 Mail gesendet.
|
I know what atomic commits are and what their advantages (conflict handling is a bit easier) are. But a bulk changeset has it's advantages, too. E.g. metadata (changeset comment, source, created_by, etc.) only one. And in my example of 500 "add building levels" commits, where the metadata of the changeset and the data itself are approximately equal, you pump up the database 499 times with useless informations.
What's the gain of having thousands of stars? This sounds like gamification, what's next, TopTen, Leaderboard and so on? Do we really want to have this in OSM? |
Or otherwise, will there be a version for experienced mappers? And i hope you don't misunterstand me: the app, especially the idea behind (getting things complete) is great, because the workflow is simple. Currently my workflow would be e.g. fieldpapers, surveying, scanning, load and edit in josm and upload the changes ... so a few more steps as with your simple (smartphone ui experienced) app. In the meantime i've also used vespucci and others, but there you have to manually type in so much informations on the small smartphone keyboard .. doesn't really make much fun |
What's the gain of having thousands of stars? This sounds like gamification, what's next, TopTen, Leaderboard and so on?
That's the plan
…On 23 March 2017 16:43:07 CET, Harald Hartmann ***@***.***> wrote:
I know what atomic commits are and what their advantages (conflict
handling is a bit easier) are.
But a bulk changeset has it's advantages, too. E.g. metadata (changeset
comment, source, created_by, etc.) only one. And in my example of 500
"add building levels" commits, where the metadata of the changeset and
the data itself are approximately equal, you pump up the database 499
times with useless informations.
> easy stats generation (the number next to the star)
What's the gain of having thousands of stars? This sounds like
gamification, what's next, TopTen, Leaderboard and so on? Do we really
want to have this in OSM?
--
You are receiving this because you modified the open/close state.
Reply to this email directly or view it on GitHub:
#21 (comment)
--
Diese Nachricht wurde von meinem Android-Mobiltelefon mit K-9 Mail gesendet.
|
I plan to add an advanced mode later that exposes a "raw input" (i.e. for opening hours, roof shapes etc) and maybe add an unobtrusive but limited way to add new POIs... But that depends on a number of other things that need to be implemented first. Perhaps you could open a ticket and explain what else you'd like to see in such an advanced mode. That ticket can serve as a brainstorming.
…On 23 March 2017 16:57:50 CET, Harald Hartmann ***@***.***> wrote:
Or otherwise, will there be a version for experienced mappers?
And i hope you don't misunterstand me: the app, especially the idea
behind (getting things complete) is great, because the workflow is
simple. Currently my workflow would be e.g. fieldpapers, surveying,
scanning, load and edit in josm and upload the changes ... so a few
more steps as with your simple (smartphone ui experienced) app. In the
meantime i've also used vespucci and others, but there you have to
manually type in so much informations on the small smartphone keyboard
.. doesn't really make much fun
--
You are receiving this because you modified the open/close state.
Reply to this email directly or view it on GitHub:
#21 (comment)
--
Diese Nachricht wurde von meinem Android-Mobiltelefon mit K-9 Mail gesendet.
|
Hm, apparently people can easily generate several changesets per minute (complaint on German forum here: https://forum.openstreetmap.org/viewtopic.php?id=57855&action=new). This impacts the ability of the community to do quality control; the idea of changesets is to combine several similar edits into one. I don't quite buy the "easier to handle conflicts" - are you aware that it is possible to open ONE changeset, then upload several diffs, then close that changeset again? If some uploads fail, that doesn't mean the whole changeset fails. That should be simple enough to implement, and then group several edits in the same region with the same task type. It may be a little more programming effort, but you don't want a community that rejects edits from StreetComplete because the application is considered "hostile". Playing friendly can be well worth the effort. |
woodpeck wrote:
In addition, you can first do a |
Actually, the question is rather what is the damage that your application is doing to OSM in order do avoid a little more work for StreetComplete to behave correctly - like every other editor. One could say that you are abusing the change set mechanism - at least you are not using it in the way it is intended, grouping some connected edits together. By creating a CS for every edit you are disrupting the mechanics of OSM and all tools which are evaluating change sets, tracking changes or comparing different versions. This has been noted by the community and within 7 days your editor has already triggered two forum topics with complaints (already linked above in this issue). When writing a tool for OSM it is wise to follow the intended patterns of OSM and avoid breaking existing tooling and mechanisms. As woodpeck said, sometimes there was a need to prohibit abusive applications from causing damage to OSM. This had to be done for edits with copyright infringements, tools with excessive accesses to the API and some mass downloaders. But I don't think that you want StreetComplete to join that list. |
Ah. No, that escaped my mind. Well, that makes it a lot easier to implement, actually. (It is still a bigger feature though, from the perspective of a one-man project). The argument about swamping QA tools is certainly a valid one, as the (bulk of) QA tools are built around the assumption that any changeset will have a certain information content, as @NopMap explained. This doesn't hold true currently for StreetComplete. So, don't worry, I am on your side, guys. It just takes good arguments, not threats, to convince me. So, regarding solving this issue, there are several things that should be discussed. I am open for input. Currently, answered quests are "fire and forget". As soon it is answered, it is uploaded, done. The user neither has to worry about when/if his change gets applied nor somehow look after that it will be applied.
|
westnordost wrote:
There is no best answer how large changesets should be. Ask four people and you will get five different responses. The following is my personal opinion. If the size of the changesets is similar to the size of those generated by MAPS.ME, it is ok. If the edited objects are in the same area, the number of changes per changeset might be larger. Have a look how large the bounding boxes of changeset of normal mappers using iD or JOSM are. Other people might have different opinions so, don't hard-code any thresholds, use variables set in one single source code file to make changing them easier. I currently don't expect you to expose these settings to your users. Please fix this issue ASAP. People have started writing changeset comments to all the users of your application to stop using it because it disturbs the way quality assurance at OSM works. Here are a few examples:
You can find a full list of these comments here. Sorry for being harsh but if QA is hindered, I am not amuse anymore. If I see the need to prevent further disturbtion by your application, I will not ask the DWG to block your users because it is not their fault. Instead, I will ask DWG to ask the OWG to block your application in a manner similar to this. If you don't see any progress in this issue within 48 hours, I will ask the DWG/OWG to disable the access for your application to the OSM API until the release of 0.6. You are welcome to invite the community at the German forum for doing beta testing with an improved version using the Dev API. |
@westnordost I know it sounds hard, but since you are still running a public beta it might be a good idea to add all releases into your blacklist until 0.6 is finished? You are well prepared from that side :) |
One idea could be to integrate it as a user-workflow:
I think it's definitely no problem to let users keep a single mapping tour open for several days and decide on their own when to submit it. since submitting takes a little time to write a sentence or two, they (we) won't spam it anymore. for convienience, you can still add an "auto-commit every 24hours" mode with a generic commit message stating it was auto-commited from the last 24hrs. |
Hm, you are basically saying, however I implement it, there will always be people who scandalize how it is implemented. This is not too encouraging. :-( Anyway. The upload process is a critical section of the app and the implementation of the feature request adds complexity right there. It would be irresponsible to hastily bring out a new version, as unsolved bugs there can lead to much worse things than clumsy changesets. Such as the very ticket you link, which actually destroys data. Proper implementation and testing cannot be done under time pressure, lest in two days. So, I suggest you open a ticket at DWG right away so they can discuss whether this behavior warrants a block until the feature is implemented or not. While I see that it is important that this feature is done, I do not share the same opinion as you about the criticality of it. Anyway, I leave this decision up to DWG. Perhaps, within that discussion, they could also say how they'd like the changesets to look best. It doesn't make sense that I implement one thing now, and that is still not optimal. As @ax3l mentioned, I implemented an own mechanism to block versions, so users would get a message that is a bit more informative. |
Changesets are force-closed automatically after 24h and after 1h if no further changes have been uploaded. If there will be no further input, I think I will do it in a way like @ax3l suggested, only simpler. I do not want to expose users to the notion of changesets, changeset comments etc. if not necessary:
|
@westnordost wrote:
I don't expect that the DWG will tell you what's the best way and how large your changesets should be (@woodpeck's posting above was not marked as a posting on behalf of DWG). That's not how they do their work. Their task is to ensure that people treat fair each other, no insults happen, edit wars are solved. They usually don't tell you how to edit data and which tagging scheme to use. Although, I forwarded this issue to DWG to decide whether a block is reasonable or not. |
be aware that from the OSM community point of view, this is not relevant anyway as you stated in the points below. for others: one of the features of this app is to count the number completed quests of a user (number of added OSM tags). We need to find an other way to get that from the accumulated data then, so he first tries to get the according changesets (with "survey with StreetComplete" in its comment) for a user, then counts number of changes within. I would still suggest to use the changeset's |
Sorry, I don't know what you want to say. In German, perhaps? |
that last part is a note for others/OSM people that follow your thread so they know why you are interested in "number of edited tags" of a user (aka "quests") - this is something not of interest for them but they need to understand your reasoning. |
Ah, misunderstanding. I meant "cannot be distinguished anymore" in the sense that people reading the history cannot see at first glance what was being changed. |
Ah all right. As I understood they don't care anyway and just check the total aggregated change of affected nodes in an area at once, not individual tags groups one after an other. So that's good.
|
…in MapDataDao and test cases for that Prerequisite for work on streetcomplete/StreetComplete#21
If I'm not mistaken, OSMAnd caches any edits and then just opens, fills and immediately closes a changeset on upload. This might be a viable route to go here as well, esp. if network connection is a concern. edit: once that functionality is in place, there's plenty of flexiblity on how you aggregate edits into the changesets (e.g. by time, type, locale, ...) |
Yes, as I described above one could go exactly the same way by exposing a list of closed quests (editable until upload) and even add a changeset summary on upload if the user wishes so. |
@derfasthirnlosenick Now you could test it if you like. For me, that's it for today. Only did some very rough testing so far. |
@westnordost Had some crash issues with the debug build (mostly when searching for quests), release seems to work - no idea why. |
I'm very interested in those crashlogs
Am 6. April 2017 08:31:48 MESZ schrieb derfasthirnlosenick <notifications@github.com>:
…
@westnordost Had some crash issues with the debug build (mostly when
searching for quests), release seems to work - no idea why.
Changeset creation works like a charm, incl. split by type of quest
(tried it out with opening hours and street surface) Also switching
between quest-types works. Will test how the auto-closing behaves.
Great job!
--
You are receiving this because you were mentioned.
Reply to this email directly or view it on GitHub:
#21 (comment)
--
Diese Nachricht wurde von meinem Android-Mobiltelefon mit K-9 Mail gesendet.
|
Stupid question, but how can I extract them? The journal file in the cache isn't very telling..
Am 6. April 2017 13:39:23 MESZ schrieb Tobias Zwick <notifications@github.com>:
…I'm very interested in those crashlogs
Am 6. April 2017 08:31:48 MESZ schrieb derfasthirnlosenick
***@***.***>:
***@***.*** Had some crash issues with the debug build (mostly when
>searching for quests), release seems to work - no idea why.
>Changeset creation works like a charm, incl. split by type of quest
>(tried it out with opening hours and street surface) Also switching
>between quest-types works. Will test how the auto-closing behaves.
>Great job!
>
>--
>You are receiving this because you were mentioned.
>Reply to this email directly or view it on GitHub:
>#21 (comment)
--
Diese Nachricht wurde von meinem Android-Mobiltelefon mit K-9 Mail
gesendet.
--
You are receiving this because you were mentioned.
Reply to this email directly or view it on GitHub:
#21 (comment)
|
The easiest way is to look into the output in Android studio, you can filter by application.
Otherwise, if you have adb, it's i.e.
adb shell logcat -d > /sdcard/mylog.txt
and then pull it from the smartphone to your computer.
The last thing you can do is to have an application like SysLog run in the background.
Am 6. April 2017 16:05:03 MESZ schrieb derfasthirnlosenick <notifications@github.com>:
…Stupid question, but how can I extract them? The journal file in the
cache isn't very telling..
Am 6. April 2017 13:39:23 MESZ schrieb Tobias Zwick
***@***.***>:
>I'm very interested in those crashlogs
>
>Am 6. April 2017 08:31:48 MESZ schrieb derfasthirnlosenick
***@***.***>:
***@***.*** Had some crash issues with the debug build (mostly when
>>searching for quests), release seems to work - no idea why.
>>Changeset creation works like a charm, incl. split by type of quest
>>(tried it out with opening hours and street surface) Also switching
>>between quest-types works. Will test how the auto-closing behaves.
>>Great job!
>>
>>--
>>You are receiving this because you were mentioned.
>>Reply to this email directly or view it on GitHub:
>>#21 (comment)
>
>--
>Diese Nachricht wurde von meinem Android-Mobiltelefon mit K-9 Mail
>gesendet.
>
>--
>You are receiving this because you were mentioned.
>Reply to this email directly or view it on GitHub:
>#21 (comment)
--
You are receiving this because you were mentioned.
Reply to this email directly or view it on GitHub:
#21 (comment)
--
Diese Nachricht wurde von meinem Android-Mobiltelefon mit K-9 Mail gesendet.
|
recompiled in debug - can't reproduce the crashes. odd (but not really bad news). will try again later. |
@westnordost I don't understand why you want to push grouped by changed tags. Just for the changeset message? :) Afaik, the idea about change sets is to adjust, e.g. a building or buildings of an area with several tags at once and then upload those collectively. You could do the same by aggregating your current changeset message(s) into one. |
I think what @ax3l wanted to is, is the same I thought when I read your post about changeset commons. For example: added 3 building levels and one road surface would result in a list with
But the app seems like a really fast way to add certain things. I'm looking forward to use it ones the changeset are fixed =) |
Phew, actually you are a bit late to the party. I spent this week implementing the solution I proposed in the linked German forum thread, after asking if anyone had a strong reason to oppose it. Now that the app is (about to) use the changeset mechanic as it is intended, everything else is a matter of taste. I do not intend to discuss and topple over the whole implementation again because there are people who prefer to have it all in one changeset now. Just so that you better understand my decision, here are some reasons for segregating changesets along quest types:
Ok, I talked too much about why "as few changesets as possible" is not the golden way. As promised, my reasons for segregating changesets along quest types:
OK? |
Thank you for posting the reasoning! If nobody in the forum subjected then that should be fine indeed. |
Thank you, Axel. Almost forgot: 0.6 is out now, get it while it is hot! |
Almost forgot: 0.6 is out now, get it while it is hot!
Wuhu! How long does it take fdroid to show it? :)
|
No idea, we'll find out. |
I dig a bit into it and opened a PR to their repositories: https://gitlab.com/fdroid/fdroiddata/merge_requests/2170 (the metadata-bot of f-droid finds it too, but seems to visit it with quite a large interval) |
That's cool, thank you! |
btw: the fdroid repo did build and distribute the 0.7 release yesterday |
when working offline and collecting several answers, they will be uploaded each in single changesets. I would be better to collect them in one single upload changeset.
The text was updated successfully, but these errors were encountered: