forked from rarias/bscpkgs
		
	garlicd: send logs to the builder
This commit is contained in:
		
							parent
							
								
									732b0c0e9c
								
							
						
					
					
						commit
						12ff1fd506
					
				| @ -2,10 +2,15 @@ | |||||||
| 
 | 
 | ||||||
| set -e | set -e | ||||||
| 
 | 
 | ||||||
| msg() { | emsg() { | ||||||
|   >&2 echo "garlicd: $@" |   >&2 echo "garlicd: $@" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | msg() { | ||||||
|  |   emsg "$@" | ||||||
|  |   if [ ! -z "$st" ]; then echo "garlicd: $@" >>"$st"; fi | ||||||
|  | } | ||||||
|  | 
 | ||||||
| if [ ! -z "$1" ]; then | if [ ! -z "$1" ]; then | ||||||
|   >&2 echo "usage: garlicd" |   >&2 echo "usage: garlicd" | ||||||
|   exit 1 |   exit 1 | ||||||
| @ -18,8 +23,8 @@ garlic_sandbox=$(nix show-config |\ | |||||||
|   grep -o '/garlic=[^ ]*' || true) |   grep -o '/garlic=[^ ]*' || true) | ||||||
| 
 | 
 | ||||||
| if [ -z "$garlic_sandbox" ]; then | if [ -z "$garlic_sandbox" ]; then | ||||||
|   msg "Missing extra-sandbox-paths /garlic mountpoint" |   emsg "Missing extra-sandbox-paths /garlic mountpoint" | ||||||
|   msg "Check the ~/.config/nix/nix.conf file" |   emsg "Check the ~/.config/nix/nix.conf file" | ||||||
|   exit 1 |   exit 1 | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| @ -28,6 +33,7 @@ mountdir=$(readlink -f "$mountdir_rel") | |||||||
| run="$mountdir/run" | run="$mountdir/run" | ||||||
| completed="$mountdir/completed" | completed="$mountdir/completed" | ||||||
| wipe="$mountdir/wipe" | wipe="$mountdir/wipe" | ||||||
|  | st="$mountdir/st" | ||||||
| 
 | 
 | ||||||
| handle_bad_signal() { | handle_bad_signal() { | ||||||
|   msg "cleaning FIFO pipes" |   msg "cleaning FIFO pipes" | ||||||
| @ -46,21 +52,40 @@ for fifo in "$run" "$completed" "$wipe"; do | |||||||
| done | done | ||||||
| 
 | 
 | ||||||
| while true; do | while true; do | ||||||
|   msg "Waiting for experiments ..." |   emsg "--- Waiting for experiments ---" | ||||||
|   tre=$(head -1 "$run") |   tre=$(head -1 "$run") | ||||||
| 
 | 
 | ||||||
|  |   # Truncate state file | ||||||
|  |   printf "" > "$st" | ||||||
|  | 
 | ||||||
|   msg "Attempting to run: $tre" |   msg "Attempting to run: $tre" | ||||||
|   msg "Copying files to MN4..." |   msg "Copying files to MN4..." | ||||||
|   # It fails if the user doesn't have nix-store, but is already copied |   # It fails if the user doesn't have nix-store, but is already copied | ||||||
|   # with the post build hook |   # with the post build hook | ||||||
|   nix copy --to ssh://mn1 $tre || true |   nix copy --to ssh://mn1 $tre || true | ||||||
| 
 | 
 | ||||||
|  |   set +e | ||||||
|  | 
 | ||||||
|   msg "Launching the experiment..." |   msg "Launching the experiment..." | ||||||
|   garlic -R "$tre" |   garlic -R "$tre" 2>>"$st" | ||||||
|  |   if [ "$?" != 0 ]; then | ||||||
|  |     echo ERROR > "$completed" | ||||||
|  |     msg "Failed to run the experiment :-(" | ||||||
|  |     continue | ||||||
|  |   fi | ||||||
| 
 | 
 | ||||||
|   msg "Fetching results..." |   msg "Fetching results..." | ||||||
|   garlic -FKv "$tre" |   garlic -FKv "$tre" 2>>"$st" | ||||||
| 
 | 
 | ||||||
|  |   if [ "$?" != 0 ]; then | ||||||
|  |     echo ERROR > "$completed" | ||||||
|  |     msg "The experiment failed :-(" | ||||||
|  |     continue | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   set -e | ||||||
|  | 
 | ||||||
|  |   msg "Signalling nix build..." | ||||||
|   echo -n "$tre" >> "$completed" |   echo -n "$tre" >> "$completed" | ||||||
| 
 | 
 | ||||||
|   msg "Waiting for nix to finish the build..." |   msg "Waiting for nix to finish the build..." | ||||||
| @ -72,7 +97,7 @@ while true; do | |||||||
|   fi |   fi | ||||||
| 
 | 
 | ||||||
|   msg "Removing temporal files..." |   msg "Removing temporal files..." | ||||||
|   garlic -D "$tre" |   garlic -D "$tre" 2>>"$st" | ||||||
| 
 | 
 | ||||||
|   echo -n "$tre" >> "$completed" |   echo -n "$tre" >> "$completed" | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -26,8 +26,17 @@ in | |||||||
| 
 | 
 | ||||||
|         echo ${trebuchet} >> /garlic/run |         echo ${trebuchet} >> /garlic/run | ||||||
|         echo "resultTree: waiting for experiment results..." |         echo "resultTree: waiting for experiment results..." | ||||||
|  |         stdbuf -o 0 tail -f /garlic/st & | ||||||
|  |         stpid=$! | ||||||
|         res=$(cat /garlic/completed) |         res=$(cat /garlic/completed) | ||||||
| 
 | 
 | ||||||
|  |         kill -TERM $stpid | ||||||
|  | 
 | ||||||
|  |         if [ "$res" == "ERROR" ]; then | ||||||
|  |           echo "resultTree: the experiment failed" | ||||||
|  |           exit 1 | ||||||
|  |         fi | ||||||
|  | 
 | ||||||
|         if [ "$res" != "${trebuchet}" ]; then |         if [ "$res" != "${trebuchet}" ]; then | ||||||
|           echo "resultTree: unknown trebuchet received" |           echo "resultTree: unknown trebuchet received" | ||||||
|           exit 1 |           exit 1 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user