Troubleshooting
This guide covers common issues you might encounter when using Utsuwa and how to resolve them.
Node.js Version Issues
“Unsupported engine” error
Utsuwa requires Node.js 22 or higher. If you see an error like:
npm error engine Unsupported engine
npm error notsup Required: {"node":">=22.0.0"} You need to update your Node.js version. If you’re using nvm:
nvm install 22
nvm use 22 Or with the project’s .nvmrc:
nvm use Checking your Node version
node --version Should output v22.0.0 or higher.
API Key Configuration
“Invalid API key” error
This usually means your API key is incorrect or expired. Double-check:
- The key is entered correctly (no extra spaces)
- The key hasn’t been revoked
- You’re using the right key for the provider (OpenAI key for OpenAI, etc.)
API key not being saved
All API keys are stored in your browser’s localStorage. If keys aren’t persisting:
- Check if you’re in private/incognito mode
- Clear site data and re-enter the key
- Make sure your browser allows localStorage
Rate limiting
If you’re getting rate limit errors, you may need to:
- Wait a few minutes before retrying
- Check your API provider’s usage dashboard
- Upgrade your API plan if needed
VRM Model Issues
Model not loading
If your VRM model won’t load:
- Check file size - Large models (>50MB) may take longer to load
- Verify the format - Ensure it’s a valid
.vrmfile - Try another model - Test with a different VRM to isolate the issue
- Check the console - Open browser DevTools (F12) and look for errors
Model displays incorrectly
If the model appears distorted or wrong:
- VRM version - Some older VRM 0.x models may have compatibility issues
- Bone structure - Models need standard VRM bone configurations
- Materials - Some custom shaders may not render correctly
Animations not playing
If the idle animation or expressions aren’t working:
- Wait for load - Animations load after the model
- Check VRMA support - Ensure your model supports VRM animations
- Refresh the page - Sometimes a reload fixes animation issues
Text-to-Speech Issues
No audio output
If TTS isn’t producing sound:
- Check browser audio - Make sure the tab isn’t muted
- Verify permissions - Browser may need audio autoplay permission
- Test the provider - Try Web Speech API (no key required) first
- Check API key - For ElevenLabs/other providers, verify the key is valid
Lip-sync not working
If the avatar’s mouth isn’t moving:
- Audio is required - Lip-sync only works when TTS audio plays
- Volume level - Very quiet audio may not trigger lip-sync
- Browser support - Web Audio API must be supported
Voice sounds wrong
- Check voice settings - Different providers have different voices
- Custom voice ID - If using ElevenLabs custom voice, verify the ID
Memory & Performance
App running slowly
Performance issues can stem from:
- Semantic memory model - The embedding model (~23MB) loads on first use
- Large conversation history - Long sessions accumulate data
- VRM model size - Complex models use more GPU resources
Solutions:
- Give the embedding model time to load initially
- Clear old sessions in Settings > Data
- Use simpler VRM models if performance is an issue
Browser storage errors
If you see IndexedDB or storage errors:
- Check available space - Browser storage may be full
- Clear site data - Reset the app’s storage
- Disable private mode - Some storage features don’t work in incognito
Memory usage is high
The app uses memory for:
- Three.js 3D rendering
- VRM model geometry and textures
- Conversation history
- Embedding model for semantic search
If memory is a concern, refresh the page periodically to clear accumulated data.
Common Errors
“Failed to fetch” errors
These usually indicate network problems:
- Check internet connection
- Verify API endpoint - Some providers may be down
- CORS issues - If self-hosting, check CORS configuration
- Firewall/proxy - Corporate networks may block API calls
“Page not found” after deployment
If routes work locally but not in production:
- Check adapter settings - Ensure the SvelteKit adapter is configured correctly
- Verify build output - Check the deployment logs
- Case sensitivity - Some hosts are case-sensitive for file paths
Console shows “Cannot read property of undefined”
This often means something loaded out of order:
- Refresh the page
- Clear browser cache - Hard refresh (Ctrl+Shift+R)
- Check for updates - Pull latest code if self-hosting
Getting More Help
If your issue isn’t covered here:
- Check the GitHub Issues for similar problems
- Open a new issue with:
- Browser and version
- Steps to reproduce
- Any console errors
- Screenshots if relevant