run-cap-on-android
v1.0.3
Published
Builds a capacitor app on WSL and starts it on the Windows Android emulator.
Downloads
441
Readme
run-cap-on-android
https://user-images.githubusercontent.com/23533178/162486231-7c22ed5e-0b39-4fe0-ba44-32ef5dc4c0f5.mp4
run-cap-on-android
is a command line tool to improve DX when developing Capacitor apps on WSL.
As of April 2022, Android Studio still has very poor support for WSL2. You can open projects from WSL, but the Gradle sync will fail. This means there is no way to quickly run your Capacitor app on an Android emulator without first copying your entire project to the Windows filesystem.
run-cap-on-android
uses currently available functionality in ADB to build and install your capacitor app on an Emulator running on Windows.
Install
npm install run-cap-on-android -D
# or
yarn add run-cap-on-android -D
and then add the following to your package.json
:
"scripts": {
// ... other scripts
"cap-on-android": "run-cap-on-android -id com.myapp"
}
then run:
npm run cap-on-android
# or
yarn run cap-on-android
Installing Gradle
WSL should have access to the gradle
command. If it's not installed, you can install the latest verson using the sdkman package manager.
Installing adb
adb
needs to be installed and added to your $PATH on both Windows and WSL.
On Windows
adb
and emulator
should come installed with Android Studio, but often times it's not automatically added to the $PATH. You can check this by opening CMD and typing adb
.
To add adb to your $PATH:
- Search your start menu for "Edit the system environment variables".
- Click on "Environment Variables".
- In the table, select the row with
Path
and click on "Edit". - Add two more lines:
%USERPROFILE%\AppData\Local\Android\sdk\platform-tools
and
%USERPROFILE%\AppData\Local\Android\sdk\emulator
Save and close everything. After restarting your terminal you should be able to run both the adb
and emulator
commands.
Usage
Usage: run-cap-on-android [options]
Options:
-id, --applicationId your app\'s id e.g. com.mycoolapp
-a, --androidFolder the android folder relative to the project root (default:
<folder with package.json>/android/app/build/outputs/apk/debug/app-debug.apk)
-s, --sdk location of the android sdk
(default:/mnt/c/Users/<your username>/AppData/Local/Android/Sdk )
applicationId
This is the only required option. It depends on how you've set up your app and if you have different versions/names when making staging builds.
androidFolder
Defaults to the /android
folder in your project root (wherever you ran the command from).
sdk
Defaults to the SDK installed by Android Studio, you can specify a Windows path or a WSL path, both will work.