Did some testing and learned something new. Roll20 is more decentralized than i thought. Images are directly uploaded from the client/browser to Amazon s3. For each image 5 versions are uploaded to s3: mini, thumb, med, max and original.
Two 9.9MB sized assets "SDT Cathedral 1 Roof Snow 22x16.png" and "CTBR Dead Forest Map Section 5 30x30.jpg" were uploaded and when the asset became visible on the map Z was pressed to load the original image. Assets where selected by size from my sizable Gabriel Pickard collection.
Ran the test multiple times and performance is very, very unpredictable. One moment it's under a minute, and another moment it takes over 15 minutes. Test were run in Chrome and Firefox with same results. Some of the tests where captured with OBS and are available for analysis by Roll20 on request.
One run the png was uploaded within 20 seconds, it became visible on the map and Z was pressed to load the original image. 11 MB of data was sent to the network and 11 MB of data was received. Which is kind of half of what i expected (maybe the result of http gzip compression?).
Then the jpg was uploaded and it took 18 minutes to upload (and Z was again pressed).
This time 56 MB of data was sent and 56 MB of data was received. The jpg that was yielded by pressing Z has the jpg extension, but is in fact a png of 42 MB large. When there are network issues, more data exacerbates the effects.
I reran the test at least 20 times... even with chrome and firefox next to each other. Was it only the first image that uploads fastafter a fresh Roll20 start? No. Sometimes the jpg upload in chrome overtook the png upload in firefox (and vice versa). Somehow it looks like s3 decides to throttle certain uploads.
This is a very complex problem. Due to the decentralized nature of the upload, it is very hard for the developers to trace and test. But it is a customer experience disaster that affects paying customers most (as these probably GM most and upload most).
For now my solution would be (when you have a sufficient fast ISP): keep the network monitor open while uploading large images. If the progress bar stalls halfway, the network speed on the sysmonitor drops to a low line for 10 seconds. Press F5 and start again.