"Failed to build the World" on blank new project

hi, I haven’t built a world in a long time and a bunch of stuff has changed such as the introduction of VCC. I couldn’t make VCC work properly, since the window would immediately crash upon startup, but using the CLI I was at least able to download the templates. I then manually copied a template folder to start off as project folder and then installed the VRChat SDK package into it in unity manually. I plopped down a few objects and created some materials, everything first seems to work fine in the in-unity preview player where I can move around.

However, now I want to try and upload it to VRChat and I get a Build Failed error:

screenshot

and in the console:

I’m thinking the only error that may be relevant here is “AssetBundle was not built”, however its stacktrace also doesn’t tell me a lot of information:

[Always] AssetBundle was not built
UnityEngine.Debug:LogError (object,UnityEngine.Object)
VRC.Core.Logger:LogError (string,VRC.Core.DebugLevel,UnityEngine.Object)
VRC.SDK3.Editor.Builder.VRCWorldAssetExporter:ExportCurrentSceneResource (bool,System.Action`1<string>,System.Action`1<object>)
VRC.SDK3.Editor.Builder.VRCWorldBuilder:ExportSceneResourceInternal (bool)
VRC.SDK3.Editor.Builder.VRCWorldBuilder:ExportSceneResource ()
VRC.SDK3.Editor.Builder.VRCWorldBuilder:ExportSceneResourceAndRun ()
VRC.SDK3.Editor.VRCSdkControlPanelWorldBuilder/<Build>d__114:MoveNext () (at ./Packages/com.vrchat.worlds/Editor/VRCSDK/SDK3/VRCSdkControlPanelWorldBuilder.cs:2026)
UnityEngine.UnitySynchronizationContext:ExecuteTasks () (at /home/bokken/build/output/unity/unity/Runtime/Export/Scripting/UnitySynchronizationContext.cs:107)

where the source line is just the VRC_SdkBuilder.RunExportSceneResourceAndRun(); call.

I had working world exports before, but that’s quite a while ago and now I don’t remember if I did it natively on Linux or if I used unity in wine back then, since the Linux version of Unity used to be quite buggy and experimental at that point.

This is using

Unity 2022.3.6f1 (LTS)
  with Windows Build Support (Mono)
  and Linux Build Support (IL2CPP)
Unity Hub 3.6.1 (60ffef8) <- although I doubt this is relevant
vpm 0.1.22 (but only the downloaded template used from it, since the project creation didn't work)

I would share the project folder but it’s 1.3 GB even though there is almost nothing in there, so I don’t really want to do that.

Any ideas how to fix this?

Edit: this also happens if I try with a completely blank project and manually add the VRChat world objects and settings without the template.

Thanks,
WebFreak

3 Likes

I would probably say that the installation of the vrchat sdk package is corrupted and that you either need vcc through GUI or CLI to install the dependency in a cleaner way.

If you create a project from vcc and then try to upload it, do you get the same issue ?

vcc (GUI) doesn’t work as mentioned in my post. Probably using APIs that are not yet supported in wine / proton.

This is on Linux

I have same issue on SDK 3.5.0

+1 (also 3.5.0)
I even tested with the SDK-Provided VRCDefaultWorldScene.

Can you update to 3.5.1 and try again? There were some fixes in that SDK.

Happens on 3.5.1 too.

Edit: I have made a new separate test project. I simply made a new project in the UnityHub, added com.vrchat.worlds, opened the scene Packages/com.vrchat.worlds/Editor/VRCSDK/SDK3/VRCDefaultWorldScene.unity and tried to upload the project.


(the warnings are probably just me trying to upload a scene directly from the Packages folder)

another thing to note is, that the path is a fake one and that I’m using unity via the flatpack. (Using unity from nixos’s package manager does not work for me. Yes I use NixOs.)

Running this persons post through google translate mentions creating a symlink for the scene file: GNU/Linux上で、VRChatプロジェクトをUnity 2022.3.6f1に更新するためのガイド - 半透明狐人間のブログ

So I guess there’s some weird case-sensitivity differences between the Windows/Linux unity. Going into ~/.var/app/com.unity.UnityHub/cache/tmp/DefaultCompany/$project/ and creeating a symlink scene-StandaloneWindows64-scene.vrcw -> scene-standalonewindows64-scene.vrcw does allow me to upload worlds now.

2 Likes

Worked for me, but for some reason this ~/.var/app/com.unity.UnityHub/cache/tmp/DefaultCompany/ directory did not exist for me. My directory was /tmp/DefaultCompany/[my project name]/scene-standalonewindows64-[scene name].vrcw. Also, whenever i create the symlink and upload the world, the symlink gets erased.

I’m running into the same issue trying to upload a world from Linux. I’ve successfully uploaded avatars, but uploading worlds is broken.

The suggested fix of creating a symlink also didn’t work for me, as now I get a new error:

Win32Exception: Cannot find the specified file
System.Diagnostics.Process.StartWithShellExecuteEx (System.Diagnostics.ProcessStartInfo startInfo) (at <715fe43e6c5b4c8a9af6047c51432b3a>:0)
System.Diagnostics.Process.Start () (at <715fe43e6c5b4c8a9af6047c51432b3a>:0)
(wrapper remoting-invoke-with-check) System.Diagnostics.Process.Start()
System.Diagnostics.Process.Start (System.Diagnostics.ProcessStartInfo startInfo) (at <715fe43e6c5b4c8a9af6047c51432b3a>:0)
VRC.SDK3.Editor.Builder.VRCWorldAssetExporter.RunScene (System.String vrcFilePath, System.String pluginFilePath) (at <4397df6781be47a391ad5f43a851954b>:0)
VRC.SDK3.Editor.Builder.VRCWorldAssetExporter.RunExportedSceneResource () (at <4397df6781be47a391ad5f43a851954b>:0)
VRC.SDK3.Editor.Builder.VRCWorldAssetExporter.RunExportedSceneResourceAndCleanupPlugin () (at <4397df6781be47a391ad5f43a851954b>:0)
VRC.SDK3.Editor.Builder.VRCWorldBuilder.ExportSceneResourceAndRun () (at <4397df6781be47a391ad5f43a851954b>:0)
VRC.SDK3.Editor.VRCSdkControlPanelWorldBuilder.Build (System.Boolean runAfterBuild) (at ./Packages/com.vrchat.worlds/Editor/VRCSDK/SDK3/VRCSdkControlPanelWorldBuilder.cs:2203)
VRC.SDK3.Editor.VRCSdkControlPanelWorldBuilder.BuildAndTest () (at ./Packages/com.vrchat.worlds/Editor/VRCSDK/SDK3/VRCSdkControlPanelWorldBuilder.cs:2599)
VRC.SDK3.Editor.VRCSdkControlPanelWorldBuilder+<>c__DisplayClass113_0.<CreateBuildGUI>b__7 () (at ./Packages/com.vrchat.worlds/Editor/VRCSDK/SDK3/VRCSdkControlPanelWorldBuilder.cs:1988)
System.Runtime.CompilerServices.AsyncMethodBuilderCore+<>c.<ThrowAsync>b__7_0 (System.Object state) (at <c3c5b887e5d443c09cc543e880304c86>:0)
UnityEngine.UnitySynchronizationContext+WorkRequest.Invoke () (at /home/bokken/build/output/unity/unity/Runtime/Export/Scripting/UnitySynchronizationContext.cs:153)
UnityEngine.UnitySynchronizationContext.Exec () (at /home/bokken/build/output/unity/unity/Runtime/Export/Scripting/UnitySynchronizationContext.cs:83)
UnityEngine.UnitySynchronizationContext.ExecuteTasks () (at /home/bokken/build/output/unity/unity/Runtime/Export/Scripting/UnitySynchronizationContext.cs:107)
``

Creating a symlink doesn’t seem to do anything in my case, it just gets deleted when I try to upload and I get the AssetBundle error again. Are you 100% sure you entered everything correctly?

I’ll also add that doing everything as directed in FoxHuman’s tutorial, in both the newest and last version of unity and with the latest SDK didn’t help me. I’m guessing the latest SDK presents new compatibility issues that have yet to be found.

Update: After trying and failing to run Unity through wine, I’ve settled with using a VM for now, which is slow and uses all of my RAM, but at least it works. Reeeally hoping this gets some attention from the SDK developers soon.