This Python script was developed for use on a project to deploy 1,200 Google Nexus 7 tablets. It helps automate the process of upgrading the Android OS, installing apps and copying files onto the tablet. It uses Python's multiprocessing module and can operate on multiple tablets connected to a computer via a USB hub. It has been tested with up to 8 tablets connected to host computers running Mac OS/X and Windows 7.
I don't see any reason this script couldn't be used on other Android tablets. However, I've only got access to the Nexus 7, and I don't know all the magic button sequences for other Android tablets. ;-)
Actually that's not true -- I was able to test the app and file installation options on a Samsung Galaxy Tab 2, and both worked fine.
###Disclaimer Proceed at your own risk! I take no responsibility if you brick your own tablet. That said, I've run this many, many, many times on numerous Nexus 7 tablets, and I have not bricked one tablet.
###GNU General Public License This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.
Our project had a few specific requirements worth noting, including a) rooting the tablet was not approved, and b) users were not required to have Google accounts to use the tablet.
We received a large shipment of Nexus 7 tablets (2012 Wi-Fi edition, a.k.a. "nakasi") running Android 4.2. First, we wanted to upgrade them all to run Android 4.4. Second, we wanted to be able to patch the tablets with what would otherwise be an OTA upgrade (e.g. 4.4.0 to 4.4.2). (We work in very low-bandwidth environments, and even 10 tablets doing an OTA upgrade would swamp our Internet connection.) Third, we wanted to be able to pre-install a bunch of apps. Fourth, we wanted the ability to copy a set of files onto the tablet.
Some of of the apps we pre-installed were custom/in-house developed. Others were free apps available in the Play store. Because our users were not required to have Google accounts, we found the APK Extractor to be useful to work with this requirement. On a test tablet, we could login to a Google account, install an app via the Play store, then extract the APK for that app.
At this time, Android does not seem to offer a lot of automation for bulk deployments like ours. We experimented with things like adb backup/restore in an effort to clone tablets, however ultimatley went with the approach below.
This script can be used 1) to upgrade the Android OS, and 2) install a series apps are available locally on disk as APK files, and 3) copy files onto the tablet.
This script requires Python 3 (Python 3.3.2 at the time of this writing). The original version of this script was developed using Python 2.7.5, but I switched to Python 3 to better leverage Python's multiprocessing capabilities.
Listed below are some runtimes I observed upgrading the Android OS (4.2 to 4.3) on 5 tablets, connected via a 7-port Plugble USB 3.0 hub to my MacBook Pro (2.9 GHz i7 running OS/X 10.9):
-
./n7p.py completed - 2 tablet(s) in 0:04:00.172587
-
./n7p.py completed - 3 tablet(s) in 0:04:28.856906
-
./n7p.py completed - 4 tablet(s) in 0:05:01.472792
-
./n7p.py completed - 5 tablet(s) in 0:05:38.462541
We've run this script with up to 8 tablets connected by a single USB hub. However, with more and more tablets reading or debugging the script's output can get a little tricky.
This script has been run successfully on Mac computers running OS/X 10.8 and 10.9 and a PC running Windows 7 Starter Edition.
- Install the Android SDK.
- Update the paths in the .ini file (n7.ini) -- see Edit Config File below.
- If upgrading the Android OS, download a Factory image of Android that is appropriate for your tablet
- Install or confirm you are using Python 3 (e.g.
python -V
or maybepython3 -V
) should return something that shows the version of Python you are running) - If patching the Android OS, download a .zip file containing the patch -- normally this is available online shortly after an official Android OTA update.
- Connect any number of tablets to your computer via a USB hub.
- Windows users will probably need to install USB drivers for the Nexus 7. These can be downloaded from Google - see also Windows Driver Note below.
Edit the included sample config file (n7.ini) to include:
-
Path to your adb executable
-
Path to your fastboot executable
-
Path to your copy of the bootloader
-
Path to your copy of the Android OS image
-
Path to your copy of the Android OS patch file
-
Path to your directory of APK files
-
Listing of files to push onto the tablet in the form of source-destination, can be of variable length
If no configuration file is specified, the script assumes a file named n7.ini
is in the same directory as the script itself. An alternate configuration file can be specified using the "-c" parameter, e.g. ./n7p.py -c OTHERFILE
- where OTHERFILE is a file in the same structure as the included n7.ini.
- Update config file, as appropriate.
- Boot each tablet into the Android bootloader by holding the down volume button and press the power button.
- Run the script with the "-u" parameter, e.g.
./n7p.py -u
- When each tablet is complete, it will reboot into the new version of Android. Complete the setup wizard. Note that the final step (e.g. with the
-w update
parameters) can take several minutes to copy the update file (several hundred megabytes). During this time there is not much in the way of visible indicators that something is actually happening on the tablet.
- The script will unlock the bootloader,de but manual intervention on each tablet is required. Check for prompts on each tablet's screen -- you will need to press the power button to unlock the bootloader. The script will then continue.
- Update config file, as appropriate.
- Boot each tablet into the Android recovery mode by holding the down volume button and press the power button, use the volume up/down and choose Recovery mode. Press the power button to enter recovery mode. The tablet should restart and end with an Android logo with a exclamation mark. See also: Guide: How to Use “adb sideload” to Update a Nexus Without Root or Custom Recovery
- Press Volume Up and Power buttons at the same time to bypass this screen and enter stock recovery.
- With Volume Down, highlight “apply update from ADB.” Press Power to choose it.
- Run the script with the "-p" parameter, e.g.
./n7p.py -p
- After the script completes, note that each tablet will verify the integrity of the patch file and then apply the patch, a process that may take several minutes. When the patch is complete, use the power button to manually choose the option to reboot.
- Verify Android version in System settings. Note patching fails if the patch is not for the correct version of Android (e.g. 4.4.2 patch applied to Android 4.3.0).
Windows did not recognize my tablet when it was booted into recovery mode -- e.g. three low beeps -- and as a result I could not patch the OS as adb could not see any tablets. See Windows doesn't recognize Nexus 7 in recovery mode). Koushik Dutta's Universal ADB Driver for Windows worked great for me on Windows 7.
- If you flashed the tablet (as above) or just unboxed it, you will need to complete the Android setup wizard.
- Once your tablet is ready to use, access Settings and scroll down to About tablet - tap to select.
- Scroll down to the bottom again to Build number, tap this 7 times to enable Developer mode.
- Return to Settings and choose Developer Options. Tap to enable USB Debugging. Press OK to continue. Press OK to allow connections from your computer.
- Tap to disable Verify apps over USB. Press the home button to exit Settings.
- Update config file, as appropriate.
- Once all your tablets are prepped, run the script with no parameters, e.g.
./n7p.py -a
- Confirm apps were installed.
On my Windows computer, Windows seemed to recognize my device -- e.g. low beep/high beep -- but adb could not see it (e.g. adb devices
). If this happens to you, try rolling the driver back to the version provided by Google (noted above in Setup).
- Update config file, as appropriate.
- Follow steps under Prepare Each Tablet under Use Case 3: Install Apps
- Once all your tablets are prepped, run the script with no parameters, e.g.
./n7p.py -f
- Confirm files copied to your tablet using a file manager app or
adb shell