Search Unity

Bug Builds randomly ~250MB too small

Discussion in 'Editor & General Support' started by Brady, Mar 30, 2022.

  1. Brady

    Brady

    Joined:
    Sep 25, 2008
    Posts:
    2,474
    In the last few months, I've started having the problem of almost every second or third build being about 250MB smaller than it's supposed to be, and it seems to be missing different random things each time based on the fact this missing content results in different bugs at runtime if I try to run the build.

    It happens for both platforms I'm building to (PC and Android), and there doesn't seem to be any way to predict when it will happen. The only solution is to try the build again and check the final size.

    This has been happening for several LTS releases in the last several months, the latest of which is 2019.4.34f1.

    Does anyone have any clue why this would happen or how to prevent it?
     
  2. Kurt-Dekker

    Kurt-Dekker

    Joined:
    Mar 16, 2013
    Posts:
    38,689
    Hm, I wonder if your asset database is corrupted subtly in some way. Have you tried a Reimport All on the project?

    Otherwise, try building it again and again and keep track of the build report (google for how) and see if they differ in some meaningful way.
     
  3. Brady

    Brady

    Joined:
    Sep 25, 2008
    Posts:
    2,474
    Yes, I've done several Reimport Alls since this began happening. That's because every time I upgrade Unity versions, there are random prefabs that inexplicably break all throughout the project, and the only way to fix them is to reimport them, but since it's random, I can't hope to know which ones need reimporting, so the only safe thing is to reimport everything.

    But I'll see if comparing build reports turns up any clues.
     
  4. Kurt-Dekker

    Kurt-Dekker

    Joined:
    Mar 16, 2013
    Posts:
    38,689
    Are you using source control? Are you using it correctly? Are you properly source-controlling ALL meta files? The meta files are pretty much the only glue holding anything together in Unity.

    Some info about Missing script warnings, GUIDs, renaming GUIDs, etc:

    https://forum.unity.com/threads/problem-with-git-and-missing-scripts.1090876/#post-7024801
    https://forum.unity.com/threads/scr...ead-after-loading-editor.998413/#post-6487297
    https://forum.unity.com/threads/scr...ead-after-loading-editor.998413/#post-6488230

    EVERYTHING in Unity is connected to the above GUID. It is super-easy to inadvertently change it by renaming outside of Unity. Don't do that. Instead:

    - close Visual Studio (important!)
    - rename the file(s) in Unity
    - in Unity do Assets -> Open C# Project to reopen Visual Studio
    - now rename the actual classes, and MAKE SURE THE FILE NAMES DO NOT CHANGE!

    If you are NOT using source control while you do this, renaming files is an EXTREMELY dangerous process. Use source control at all times so that you can trivially revert if you miss a critical step and damage your project.

    Please consider using proper industrial-grade enterprise-qualified source control in order to guard and protect your hard-earned work.

    Personally I use git (completely outside of Unity) because it is free and there are tons of tutorials out there to help you set it up as well as free places to host your repo (BitBucket, Github, Gitlab, etc.).

    You can also push git repositories to other drives: thumb drives, USB drives, network drives, etc., effectively putting a complete copy of the repository there.

    As far as configuring Unity to play nice with git, keep this in mind:

    https://forum.unity.com/threads/prefab-links-keep-getting-dumped-on-git-pull.646600/#post-7142306

    Here's how I use git in one of my games, Jetpack Kurt:

    https://forum.unity.com/threads/2-steps-backwards.965048/#post-6282497

    Using fine-grained source control as you work to refine your engineering:

    https://forum.unity.com/threads/whe...grammer-example-in-text.1048739/#post-6783740

    Share/Sharing source code between projects:

    https://forum.unity.com/threads/your-techniques-to-share-code-between-projects.575959/#post-3835837

    Setting up an appropriate .gitignore file for Unity3D:

    https://forum.unity.com/threads/removing-il2cpp_cache-from-project.1084607/#post-6997067

    Generally setting Unity up (includes above .gitignore concepts):

    https://thoughtbot.com/blog/how-to-git-with-unity

    It is only simple economics that you must expend as much effort into backing it up as you feel the work is worth in the first place.

    "Use source control or you will be really sad sooner or later." - StarManta on the Unity3D forum boards
     
    Jmonroe likes this.
  5. Brady

    Brady

    Joined:
    Sep 25, 2008
    Posts:
    2,474
    @Kurt-Dekker yes, we have been using Plastic SCM for several years now. The issue doesn't arise when making any changes such as renaming, moving, etc. It's usually just when we upgrade Unity versions and it has to reimport assets. When it does, it often breaks random prefabs, some of which haven't been touched in ages, nor any of their dependencies. There's no apparent reason at all for why those particular prefabs break.