Skip to content

Commit 6860c10

Browse files
committed
Add a script to install a bundle into Docker for Mac
After building docker from the git repo, you can run ``` ./contrib/mac-install-bundle.sh install ``` and this will tell Docker for Mac to look for a bundle at the current path to run instead of the built in version of Docker. This will persist until you do a factory reset or run ``` ./contrib/mac-install-bundle.sh undo ``` A factory reset is advised to reset as a development Docker may break your install. The path must be a path that is shared with Docker for Mac so that the VM can find it - nothing is installed into the image. This is in `contrib/` as it is a best effort attempt to make it easier for Docker for Mac users to test master or pull requests. If it breaks anything a factory reset is your friend. Signed-off-by: Justin Cormack <[email protected]>
1 parent c0699cd commit 6860c10

1 file changed

Lines changed: 45 additions & 0 deletions

File tree

contrib/mac-install-bundle.sh

Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
#!/bin/sh
2+
3+
set -e
4+
5+
errexit() {
6+
echo "$1"
7+
exit 1
8+
}
9+
10+
[ "$(uname -s)" == "Darwin" ] || errexit "This script can only be used on a Mac"
11+
12+
[ $# -eq 1 ] || errexit "Usage: $0 install|undo"
13+
14+
BUNDLE="bundles/$(cat VERSION)"
15+
BUNDLE_PATH="$PWD/$BUNDLE"
16+
CLIENT_PATH="$BUNDLE_PATH/cross/darwin/amd64/docker"
17+
DATABASE="$HOME/Library/Containers/com.docker.docker/Data/database"
18+
DATABASE_KEY="$DATABASE/com.docker.driver.amd64-linux/bundle"
19+
20+
[ -d "$DATABASE" ] || errexit "Docker for Mac must be installed for this script"
21+
22+
case "$1" in
23+
"install")
24+
[ -d "$BUNDLE" ] || errexit "cannot find bundle $BUNDLE"
25+
[ -e "$CLIENT_PATH" ] || errexit "you need to run make cross first"
26+
[ -e "$BUNDLE/binary-daemon/dockerd" ] || errexit "you need to build binaries first"
27+
[ -f "$BUNDLE/binary-client/docker" ] || errexit "you need to build binaries first"
28+
git -C "$DATABASE" reset --hard >/dev/null
29+
echo "$BUNDLE_PATH" > "$DATABASE_KEY"
30+
git -C "$DATABASE" add "$DATABASE_KEY"
31+
git -C "$DATABASE" commit -m "update bundle to $BUNDLE_PATH"
32+
rm -f /usr/local/bin/docker
33+
cp "$CLIENT_PATH" /usr/local/bin
34+
echo "Bundle installed. Restart Docker to use. To uninstall, reset Docker to factory defaults."
35+
;;
36+
"undo")
37+
git -C "$DATABASE" reset --hard >/dev/null
38+
[ -f "$DATABASE_KEY" ] || errexit "bundle not set"
39+
git -C "$DATABASE" rm "$DATABASE_KEY"
40+
git -C "$DATABASE" commit -m "remove bundle"
41+
rm -f /usr/local/bin/docker
42+
ln -s "$HOME/Library/Group Containers/group.com.docker/bin/docker" /usr/local/bin
43+
echo "Bundle removed. Using dev versions may cause issues, a reset to factory defaults is recommended."
44+
;;
45+
esac

0 commit comments

Comments
 (0)