forked from rarias/bscpkgs
		
	Experimental garlic tool
This commit is contained in:
		
							parent
							
								
									d5d42b3c09
								
							
						
					
					
						commit
						6b40e6f9e9
					
				
							
								
								
									
										35
									
								
								garlic/sh/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								garlic/sh/default.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,35 @@ | |||||||
|  | { | ||||||
|  |   stdenv | ||||||
|  | , garlicTools | ||||||
|  | , sshHost | ||||||
|  | , rsync | ||||||
|  | , openssh | ||||||
|  | , nix | ||||||
|  | }: | ||||||
|  | 
 | ||||||
|  | with garlicTools; | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   garlicOut = "/mnt/garlic/out"; | ||||||
|  |   garlicTemp = "/tmp/garlic"; | ||||||
|  | in | ||||||
|  |   stdenv.mkDerivation { | ||||||
|  |     name = "garlic-tool"; | ||||||
|  |     preferLocalBuild = true; | ||||||
|  | 
 | ||||||
|  |     buildInputs = [ rsync openssh nix ]; | ||||||
|  |     phases = [ "unpackPhase" "installPhase" ]; | ||||||
|  | 
 | ||||||
|  |     src = ./.; | ||||||
|  | 
 | ||||||
|  |     inherit garlicOut garlicTemp sshHost; | ||||||
|  | 
 | ||||||
|  |     installPhase = '' | ||||||
|  |       substituteAllInPlace garlic | ||||||
|  |       substituteInPlace garlic \ | ||||||
|  |         --replace @PATH@ $PATH | ||||||
|  |       mkdir -p $out/bin | ||||||
|  |       cp garlic $out/bin | ||||||
|  |       chmod +x $out/bin/garlic | ||||||
|  |     ''; | ||||||
|  |   } | ||||||
							
								
								
									
										197
									
								
								garlic/sh/garlic
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										197
									
								
								garlic/sh/garlic
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,197 @@ | |||||||
|  | #!/bin/bash | ||||||
|  | 
 | ||||||
|  | garlicOut=@garlicOut@ | ||||||
|  | garlicTemp=@garlicTemp@ | ||||||
|  | sshHost=@sshHost@ | ||||||
|  | PATH=@PATH@ | ||||||
|  | 
 | ||||||
|  | usage() { echo "Usage: garlic [-RFwq] [-e experiment] [-t trebuchet]" 1>&2; exit 1; } | ||||||
|  | 
 | ||||||
|  | trebuchetFromExperiment() { | ||||||
|  |   nix-store -q --referrers $1 | grep trebuchet | ||||||
|  | } | ||||||
|  | experimentFromTrebuchet() { | ||||||
|  |   nix-store -qR $1 | grep experiment | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | drvFromOutput() { | ||||||
|  |   nix-store -q --deriver $1 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | checkTrebuchet() { | ||||||
|  |   if [ ! -e "$trebuchet" ]; then | ||||||
|  |     >&2 echo "$trebuchet: not found" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   if [ ! -f "$trebuchet" ]; then | ||||||
|  |     >&2 echo "$trebuchet: not a file" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   # FIXME: We need a better way to determine a trebuchet | ||||||
|  |   if [ -z "$(grep "This trebuchet launches" $trebuchet)" ]; then | ||||||
|  |     >&2 echo "$trebuchet: not a trebuchet" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   return 0 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | checkExperiment() { | ||||||
|  |   if [ ! -e "$experiment" ]; then | ||||||
|  |     >&2 echo "$experiment: not found" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   if [ ! -f "$experiment" ]; then | ||||||
|  |     >&2 echo "$experiment: not a file" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   # FIXME: We need a better way to determine a experiment | ||||||
|  |   if [ -z "$(grep "This is an experiment" $experiment)" ]; then | ||||||
|  |     >&2 echo "$experiment: not an experiment" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   return 0 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | do_fetch() { | ||||||
|  |   expName=$(basename $experiment) | ||||||
|  |   user=$(ssh -G "$sshHost" | awk '/^user /{print $2}') | ||||||
|  |   exp=$garlicOut/$user/$expName | ||||||
|  | 
 | ||||||
|  |   if [ ! -e "$exp" ]; then | ||||||
|  |     echo "missing experiment: $exp" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   cwd=$(pwd) | ||||||
|  | 
 | ||||||
|  |   repeat=1 | ||||||
|  |   while [ 1 ]; do | ||||||
|  |     repeat=0 | ||||||
|  |     cd $exp | ||||||
|  |     test $verbose && >&2 echo "$exp: checking units" | ||||||
|  | 
 | ||||||
|  |     for unit in *-unit; do | ||||||
|  |       cd $exp/$unit | ||||||
|  |       if [ ! -e status ]; then | ||||||
|  |          | ||||||
|  |         test $verbose && >&2 echo "$unit: no status" | ||||||
|  |         repeat=1 | ||||||
|  |       else | ||||||
|  |         st=$(cat status) | ||||||
|  |         test $verbose && >&2 echo "$unit: $st" | ||||||
|  |         if [ "$st" != "completed" ]; then | ||||||
|  |           repeat=1 | ||||||
|  |         fi | ||||||
|  |       fi | ||||||
|  |     done | ||||||
|  | 
 | ||||||
|  |     if [ $repeat -eq 0 ]; then | ||||||
|  |       break | ||||||
|  |     fi | ||||||
|  | 
 | ||||||
|  |     if [ $waitResults -eq 1 ]; then | ||||||
|  |       #echo "waiting 3 seconds to try again" | ||||||
|  |       sleep 3 | ||||||
|  |     else | ||||||
|  |       break | ||||||
|  |     fi | ||||||
|  |   done | ||||||
|  | 
 | ||||||
|  |   if [ $repeat -eq 1 ]; then | ||||||
|  |     >&2 echo "$exp: execution incomplete" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   cd "$cwd" | ||||||
|  | 
 | ||||||
|  |   test $verbose && >&2 echo "$exp: execution complete, fetching results" | ||||||
|  | 
 | ||||||
|  |   mkdir -p $garlicTemp | ||||||
|  | 
 | ||||||
|  |   rsync -rt --copy-links \ | ||||||
|  |     --include='*/*/garlic_config.json' \ | ||||||
|  |     --include='*/*/std*.log' \ | ||||||
|  |     --include='*/*/*/std*.log' \ | ||||||
|  |     --exclude='*/*/*/*' \ | ||||||
|  |     $exp $garlicTemp | ||||||
|  | 
 | ||||||
|  |   nix-build -E "(with import ./default.nix; \ | ||||||
|  |     garlic.pp.store { \ | ||||||
|  |       experimentStage = import \"$experimentDrv\"; | ||||||
|  |       trebuchetStage = import \"$trebuchetDrv\"; | ||||||
|  |     })" | ||||||
|  | 
 | ||||||
|  |   rm -rf $garlicTemp/$expName | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | do_run() { | ||||||
|  | 
 | ||||||
|  |   $trebuchet | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | waitResults=1 | ||||||
|  | verbose=1 | ||||||
|  | operation= | ||||||
|  | target= | ||||||
|  | enableRun= | ||||||
|  | enableFetch= | ||||||
|  | 
 | ||||||
|  | while getopts "qwRFe:t:" o; do | ||||||
|  |   case "${o}" in | ||||||
|  |     e) experiment=${OPTARG} ;; | ||||||
|  |     t) trebuchet=${OPTARG} ;; | ||||||
|  |     R) enableRun=1 ;; | ||||||
|  |     F) enableFetch=1 ;; | ||||||
|  |     w) waitResults=0 ;; | ||||||
|  |     q) verbose= ;; | ||||||
|  |     *) usage ;; | ||||||
|  |   esac | ||||||
|  | done | ||||||
|  | shift $((OPTIND-1)) | ||||||
|  | #target="$1" | ||||||
|  | 
 | ||||||
|  | if [ -z "$trebuchet" -a -z "$experiment" ]; then | ||||||
|  |   >&2 echo "missing trebuchet or experiment" | ||||||
|  |   usage | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | if [ -z "$enableRun" -a -z "$enableFetch" ]; then | ||||||
|  |   >&2 echo "missing operation" | ||||||
|  |   usage | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | #if [ -z "$target" ]; then | ||||||
|  | #  >&2 echo "missing target" | ||||||
|  | #  usage | ||||||
|  | #fi | ||||||
|  | 
 | ||||||
|  | #trebuchet=$(nix-build -A "exp.$target") | ||||||
|  | #checkTrebuchet $trebuchet | ||||||
|  | #experiment=$(experimentFromTrebuchet $trebuchet) | ||||||
|  | #checkExperiment $experiment | ||||||
|  | 
 | ||||||
|  | if [ ! -z "$trebuchet" ]; then | ||||||
|  |   checkTrebuchet $trebuchet | ||||||
|  |   trebuchet=$(readlink -f $trebuchet) | ||||||
|  |   experiment=$(experimentFromTrebuchet $trebuchet) | ||||||
|  |   checkExperiment $experiment | ||||||
|  | else | ||||||
|  |   checkExperiment $experiment | ||||||
|  |   experiment=$(readlink -f $experiment) | ||||||
|  |   trebuchet=$(trebuchetFromExperiment $experiment) | ||||||
|  |   checkTrebuchet $trebuchet | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | trebuchetDrv=$(drvFromOutput $trebuchet) | ||||||
|  | experimentDrv=$(drvFromOutput $experiment) | ||||||
|  | 
 | ||||||
|  | if [ $enableRun ]; then do_run; fi | ||||||
|  | if [ $enableFetch ]; then do_fetch; fi | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user