[librsvg: 6/7] Pass through temp directory, clean up images Now this uses a docker-run command to run the docker co
- From: Marge Bot <marge-bot src gnome org>
- To: commits-list gnome org
- Cc: 
- Subject: [librsvg: 6/7] Pass through temp directory, clean up images Now this uses a docker-run command to run the docker co
- Date: Wed, 25 Aug 2021 03:27:32 +0000 (UTC)
commit dab1044f011156c6f7340857c465781a700126dc
Author: Madds H <madds hollandart io>
Date:   Tue Aug 24 15:13:07 2021 -0500
    Pass through temp directory, clean up images
    Now this uses a docker-run command to run the docker container
    Any rendered files can now be accessed in the temp directory on the host
    
    Part-of: <https://gitlab.gnome.org/GNOME/librsvg/-/merge_requests/579>
 tools/docker/README.md           |  22 ++--
 tools/docker/build-librsvg.sh    |   4 -
 tools/docker/debian/Dockerfile   |   5 -
 tools/docker/docker-test.sh      | 270 +++++++++++++++++++++------------------
 tools/docker/fedora/Dockerfile   |   5 -
 tools/docker/opensuse/Dockerfile |   5 -
 6 files changed, 163 insertions(+), 148 deletions(-)
---
diff --git a/tools/docker/README.md b/tools/docker/README.md
index bce12ac6..d750981a 100644
--- a/tools/docker/README.md
+++ b/tools/docker/README.md
@@ -10,23 +10,29 @@ Docker requires root for nearly all of its commands so the script will ask for r
 ```
 This tool lets you run Librsvg's test suite under a couple different docker containers for testing, it 
requires sudo privleges, which it will ask for in the terminal (this is by the docker commands, which require 
root)
 
-Use -d [DIRECTORY] pointing at your librsvg directory
-Use -s [SYSTEM] to determine what docker container to use (Fedora, OpenSUSE, or Debian)
-use -h to return this help
-use -i to have it pause periodically to check output
-use -r to rebuild the docker image forcefully
-use -p to repackage the librsvg image (use in conjunction with -r otherwise the cache will stop changes from 
taking
-use -t to specify a temporary directory (default: /tmp/librsvg)
+Use -d [DIRECTORY] pointing at your librsvg Directory
+Use -s [SYSTEM] to determine what docker container to use (Fedora, OpenSUSE, Debian)
+Use -h to return this Help
+Use -i to have it Interactively pause periodically to check output (the cleanup scripts is always 
interactive unless -y is passed)
+Use -p to recoPy the librsvg library folder to the tmp directory, removing everything that is there, useful 
for cleaning the cargo cache
+Use -r to Rebuild the build dependencies docker image forcefully
+Use -t to specify a Temporary directory (default: /tmp/librsvg)
+Use -y to answer Yes to any prompts (This currently only includes the cleanup scripts)
+Use -c to Cleanup ALL related docker images (this will not run the test suite)
 ```
 
 ### Example:
 ```
 If the librsvg folder is in your home directory:
-./docker-test.sh -d ~/librsvg -s opensuse -i 
+~/librsvg/tools/docker/docker-test.sh -d ~/librsvg -s opensuse -i 
 
 This will run it pointing at /home/Username/librsvg (-d) with opensuse tumbleweed docker image (-s), and 
interactive (-i), meaning it pauses and has the user input a keystroke before continuing, useful for 
debugging or catching typos. 
 
 The first run will take some time as Docker downloads and installs the system, updates the packages, and 
installs the build requirements, but it's set up so that it won't re-download the system image each time, 
which takes more disk space but saves on bandwidth.
+
+What I use, from the librsvg directory:
+
+tools/docker/docker-test.sh -s opensuse
 ```
 
 
diff --git a/tools/docker/docker-test.sh b/tools/docker/docker-test.sh
index c4fc6dc5..32e5c2dd 100755
--- a/tools/docker/docker-test.sh
+++ b/tools/docker/docker-test.sh
@@ -5,7 +5,13 @@ SYS="no"
 REBUILD=false
 DIR=no
 TMPDIR=/tmp/librsvg
+
+YES=false
+
 CLEANUP=false
+RMDISTRO=false
+RMSYSTEMIMG=false
+RMTMP=false
 
 function usage {
         echo "This tool lets you run Librsvg's test suite under a couple different"
@@ -13,52 +19,56 @@ function usage {
         echo "Use -d [DIRECTORY] pointing at your librsvg Directory"
         echo "Use -s [SYSTEM] to determine what docker container to use (Fedora, OpenSUSE, Debian)"
         echo "Use -h to return this Help"
-        echo "Use -i to have it Interactively pause periodically to check output"
-        echo "Use -r to Rebuild the docker image forcefully"
-        echo "Use -p to rePackage the librsvg tar (use in conjunction with -r otherwise the cache will stop 
changes from taking"
+        echo "Use -i to have it Interactively pause periodically to check output (the cleanup scripts is 
always interactive unless -y is passed)"
+        echo "Use -p to recoPy the librsvg library folder to the tmp directory, removing everything that is 
there, useful for cleaning the cargo cache"        
+               echo "Use -r to Rebuild the build dependencies docker image forcefully"
                echo "Use -t to specify a Temporary directory (default: /tmp/librsvg)"
+               echo "Use -y to answer Yes to any prompts (This currently only includes the cleanup scripts)"
                echo "Use -c to Cleanup ALL related docker images (this will not run the test suite)"
 }
 
-function copy_build_script {
-       #echo $PWD
-       echo "Copying build-librsvg.sh to $SYS folder"
-       cp $PWD/build-librsvg.sh $SYS/
-}
-
 #Package librsvg for inclusion in the Docker image
 function prepare_librsvg {
-       echo "Packaging Librsvg"
+       echo "Preparing Librsvg"
 
-       if [[ ! -f "$SYS/librsvg.tar.gz" ]]
-       then
-               if [[ $REPACKAGE == false ]] 
+       if [[ $REPACKAGE == false ]] 
                then
                        if [[ $INT == true ]]
                        then
                                read -p "Making a copy, then running make clean and packaging Librsvg, press 
any key to continue" -n1 -s
+                               echo " "
                        fi
 
                        mkdir $TMPDIR
                        echo "Copying librsvg to $TMPDIR"
                        rsync -av --exclude '.git' --exclude 'target' $LIBDIR/ $TMPDIR/
+
                        #Uncomment this line if your distro doesn't have rsync, it'll make a lot of text when 
copying the git folder, but works
                        #cp -r $LIBDIR/. $TMPDIR 
                        cd $TMPDIR
 
+                       if [[ $INT == true ]]
+                       then
+                               read -p "Running autogen to prepare for building in $TMPDIR, then running 
make clean, press any key to continue" -n1 -s
+                               echo " "
+                       fi
+
                        #Run autogen, this prepares librsvg for building, and allows make clean to be ran
                        ./autogen.sh
                        #run make clean which makes the resulting tar much smaller.
                        make clean
-                       cd $DIR
-                       tar -cvzf $SYS/librsvg.tar.gz -C $TMPDIR . --xform='s!^\./!!'
+       else
+               echo "Recopying Librsvg"
+               if [[ ! -d "$TMPDIR" ]] 
+               then
+                       echo "$TMPDIR does not exist, creating"
+                       mkdir $TMPDIR
+               else
+                       echo "Erasing $TMPDIR and recreating"
+                       clean_tmp_dir
+                       mkdir $TMPDIR
                fi
-       fi
 
-       if [[ $REPACKAGE == true ]]
-       then
-               echo "Repackaging Librsvg"
-               mkdir $TMPDIR
                echo "Copying librsvg to $TMPDIR"
                rsync -av --exclude '.git' --exclude 'target' $LIBDIR/ $TMPDIR/
 
@@ -66,154 +76,173 @@ function prepare_librsvg {
                #cp -r $LIBDIR/. $TMPDIR
                cd $TMPDIR
 
+               if [[ $INT == true ]]
+               then
+                       read -p "Running autogen to prepare for building in $TMPDIR, then running make clean, 
press any key to continue" -n1 -s
+                       echo " "
+               fi
+
                #Run autogen, this prepares librsvg for building, and allows make clean to be ran
                ./autogen.sh
-               #run make clean which makes the resulting tar much smaller.
+               #run make clean to clean up the folder
                make clean
-               cd $DIR
-               tar -cvzf $SYS/librsvg.tar.gz -C $TMPDIR . --xform='s!^\./!!'
-       fi
-}
 
-#build the base image, this contains the dependencies for librsvg to be built, and is used to build the 
system image
-function build_base_image {
-       sudo docker build -t librsvg/librsvg-base-$SYS -f librsvg-base/$SYS/Dockerfile librsvg-base/$SYS/.    
  
+       fi      
 }
 
-#build the system image, this is the image which librsvg goes into and is built with
-function build_system_image {
-       sudo docker build -t librsvg/librsvg-$SYS -f $SYS/Dockerfile $SYS/.
+function confirm {
+       if [[ $YES == false ]] 
+       then
+               echo "Would you like to remove the librsvg docker image with the build dependencies (it will 
take a while to rebuild if removed)"
+               select yn in "Yes" "No"; do
+               case $yn in
+                   Yes ) RMSYSTEMIMG=true;;
+                   No ) RMSYSTEMIMG=false;;
+                       esac
+               done
+               echo " "
+       fi
 }
 
-#removes the system image and rebuilds it, this doesn't touch the system images
-function rebuild_docker {
-       echo "removing old image"
-       sudo docker rmi --force librsvg/librsvg-$SYS
-       sudo docker build -t librsvg/librsvg-$SYS --no-cache -f $SYS/Dockerfile $SYS/.
+function confirm_rm_dir {
+       if [[ $YES == false ]] 
+       then
+               echo "Would you like to remove the librsvg files from the tmp directory: $TMPDIR"
+               select yn in "Yes" "No"; do
+               case $yn in
+                   Yes ) RMTMP=true;;
+                   No ) RMTMP=false;;
+                       esac
+               done
+               echo " "
+       fi
 }
 
-#Build the docker image, using $SYS and $LIBDIR to determine where and what library
-function build_docker {
-       if [[ $REBUILD == false ]]
+function confirm_rm_distro {
+       if [[ $YES == false ]] 
        then
-               if [[ $INT == true ]]
+               echo "Would you like to remove the base docker system images ie. opensuse (do this if you 
don't plan to build librsvg with this tool in the future, otherwise keep them, it takes a while to build)"
+               select yn in "Yes" "No"; do
+               case $yn in
+                   Yes ) RMDISTROIMG=true;;
+                   No ) RMDISTROIMG=false;;
+                       esac
+               done
+               echo " "
+       fi
+
+
+}
+
+#build the base image, this contains the dependencies for librsvg to be built, and is used to build the 
system image
+function build_base_image {
+
+       if [[ $REBUILD == true ]]
                then
-                       read -p "Building Docker with cache and settings $SYS, $LIBDIR Press any key to 
continue" -n1 -s
-               fi
-               echo "Building Docker System $SYS with cache"
-               build_system_image
-       else
                if [[ $INT == true ]]
-               then
-                       read -p "Rebuilding Docker with settings $SYS, $LIBDIR Press any key to continue" -n1 
-s
+                       then
+                               read -p "Rebuilding the Librsvg build dependencies docker container, this 
will take a moment" -n1 -s
+                               echo " "
                fi
 
-               rebuild_docker
+               clean_base_image
+               sudo docker build -t librsvg/librsvg-$SYS-base -f tools/docker/librsvg-base/$SYS/Dockerfile 
tools/docker/librsvg-base/$SYS/.    
+
        fi
-}
 
-#removes the designated system image
-function remove_system_image {
-       echo "removing system image librsvg-base-$SYS"
-       sudo docker rmi --force librsvg/librsvg-base-$SYS
+       if [[ $INT == true ]]
+       then
+               read -p "Building the Librsvg build dependencies docker container, this will take a moment, 
press any key to continue" -n1 -s
+               echo " "
+       fi
+
+       sudo docker build -t librsvg/librsvg-$SYS-base -f tools/docker/librsvg-base/$SYS/Dockerfile 
tools/docker/librsvg-base/$SYS/.    
 }
 
-#removes the librsvg image
-function remove_librsvg_image {
-       echo "removing librsvg image librsvg-$SYS"
-       sudo docker rmi --force librsvg/librsvg-$SYS
+#removes the designated base system image
+function clean_base_image {
+       echo "removing system image librsvg-base-$SYS"
+       sudo docker rmi --force librsvg/librsvg-$SYS-base
 }
 
-function remove_distro_image {
+#removes distro images
+function clean_distro_image {
        echo "removing base system images"
        sudo docker rmi --force debian
        sudo docker rmi --force opensuse/tumbleweed
        sudo docker rmi --force fedora
 }
 
+function clean_tmp_dir {
+       if [[ "$TMPDIR" == "/" ]] 
+       then
+               echo "Tried to delete root, exiting"
+               exit 1
+       fi
+
+       if [[ ! -d "$TMPDIR" ]] 
+       then
+               echo "$TMPDIR does not exist, exiting"
+               exit 0
+       fi
+       echo "This requires sudo because the build is done with the docker image, so build files cannot be 
removed without it"
+       echo " "
+       if [[ $INT == true ]]
+       then
+               read -p "Pausing, press any key to continue, you may be asked for admin password in the next 
step" -n1 -s
+               echo " "
+       fi
+       sudo rm -rf $TMPDIR
+}
+
 function cleanup {
        if [[ $CLEANUP == true ]]
        then
                confirm
-               SYS=opensuse
-               remove_librsvg_image
-               remove_system_image
-               rm $SYS/librsvg.tar.gz
-               rm $SYS/build-librsvg.sh
-               SYS=fedora
-               remove_librsvg_image
-               remove_system_image
-               rm $SYS/librsvg.tar.gz
-               rm $SYS/build-librsvg.sh
-               SYS=debian
-               remove_librsvg_image
-               remove_system_image
-               rm $SYS/librsvg.tar.gz
-               rm $SYS/build-rsvg.sh
 
-               confirm_rm_distro
-               remove_distro_image
-
-               confirm_rm_dir
-               if [[ "$TMPDIR" == "/" ]] 
+               if [ $RMSYSTEMIMG == "true" ]
                then
-                       echo "Tried to delete root, exiting"
-                       exit 1
+                       SYS=opensuse
+                       clean_base_image
+
+                       SYS=fedora
+                       clean_base_image
+
+                       SYS=debian
+                       clean_base_image
+
                fi
 
-               if [[ ! -d "$TMPDIR" ]] 
+               confirm_rm_distro
+               if [ $RMDISTROIMG == "true" ]
                then
-                       echo "$TMPDIR does not exist, exiting"
-                       exit 0
+                       clean_distro_image
                fi
-               rm -rf $TMPDIR
+               
+               confirm_rm_dir
+               if [ $RMTMP == "true" ]
+               then
+                       clean_tmp_dir
+               fi
+
+
 
                exit 0
        fi
        
 }
 
-function confirm {
-       echo "Are you sure? This will remove all Docker images and the packaged librsvg.tar.gz"
-       select yn in "Yes" "No"; do
-       case $yn in
-           Yes ) break;;
-           No ) exit 1;;
-               esac
-       done
-}
-
-function confirm_rm_dir {
-       echo "Would you like to also remove the librsvg files from the tmp directory: $TMPDIR"
-       select yn in "Yes" "No"; do
-       case $yn in
-           Yes ) break;;
-           No ) exit 1;;
-               esac
-       done
-}
-
-function confirm_rm_distro {
-       echo "Would you like to remove the base system images ie. opensuse (do this if you don't plan to 
build librsvg with this tool in the future, otherwise keep them, it takes a while to build)"
-       select yn in "Yes" "No"; do
-       case $yn in
-           Yes ) break;;
-           No ) exit 1;;
-               esac
-       done
-}
-
-#runs the built docker image, this runs build_librsvg.sh automatically attached to the console
+#runs the built docker image, this runs cargo check automatically attached to the console
 function run_docker {
-       sudo docker run -it librsvg/librsvg-$SYS
+       sudo docker run --name librsvg-$SYS-test -v /tmp/librsvg/:/tmp/librsvg/ -w /tmp/librsvg/ -t --rm 
librsvg/librsvg-$SYS-base cargo test 
 }
 
 function check_dir {
        echo "Checking if $LIBDIR exists"
        if [[ ! -d "$LIBDIR" ]]
        then
-               echo "$LIBDIR does not exist, exiting"
-               exit 2
+               echo "Library directory: '$LIBDIR' does not exist or isn't set, defaulting to current working 
directory"
+               LIBDIR=$PWD
        fi
        
        if [[ $LIBDIR == */ ]]
@@ -275,6 +304,7 @@ while getopts "d:s:irpt:ch" flag; do
                t) TMPDIR=${OPTARG};;
                c) CLEANUP=true;;
                h) usage; exit 0;;
+               y) YES=true;;
                ?) usage; echo "Error: $flag"; exit 1;;
        esac
 done
@@ -284,10 +314,8 @@ function main {
        cleanup
        check_dir
        check_system
-       copy_build_script
-       prepare_librsvg
        build_base_image
-       build_docker
+       prepare_librsvg
        run_docker
 
        if [[ $INT == true ]]
[
Date Prev][
Date Next]   [
Thread Prev][
Thread Next]   
[
Thread Index]
[
Date Index]
[
Author Index]