mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-25 01:14:59 +03:00 
			
		
		
		
	Add wait_freeing helper function to ZTS
				
					
				
			Sometimes the ZTS checks freed space just after `zfs destroy snapshot` and gets an unexpected value because of space being freed asynchronously. For cases like this add a `wait_freeing` function which blocks until the pools `freeing` property drops to zero. Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: George Melikov <mail@gmelikov.ru> Closes #5740
This commit is contained in:
		
							parent
							
								
									d32d25c5c2
								
							
						
					
					
						commit
						d834b9ce5b
					
				| @ -3078,3 +3078,17 @@ function sync_pool #pool | ||||
| 		log_must $SLEEP 2 | ||||
| 	done | ||||
| } | ||||
| 
 | ||||
| # | ||||
| # Wait for zpool 'freeing' property drops to zero. | ||||
| # | ||||
| # $1 pool name | ||||
| # | ||||
| function wait_freeing #pool | ||||
| { | ||||
| 	typeset pool=${1:-$TESTPOOL} | ||||
| 	while true; do | ||||
| 		[[ "0" == "$($ZPOOL list -Ho freeing $pool)" ]] && break | ||||
| 		log_must $SLEEP 1 | ||||
| 	done | ||||
| } | ||||
|  | ||||
| @ -93,6 +93,8 @@ function set_n_check_prop | ||||
| 
 | ||||
| 		[[ -n $prop ]] && cur_value=$(get_prop $prop $dataset) | ||||
| 		 | ||||
| 		wait_freeing | ||||
| 
 | ||||
| 		if [[ "$expect_value" != "" && "$cur_value" != "$old_value" ]]; | ||||
| 		then | ||||
| 			log_fail "The '$dataset' '$prop' value '$cur_value' \ | ||||
|  | ||||
| @ -88,6 +88,8 @@ while [[ $i -lt $COUNT ]]; do | ||||
| 	(( i = i + 1 )) | ||||
| done | ||||
| 
 | ||||
| wait_freeing $TESTPOOL | ||||
| 
 | ||||
| new_size=`get_prop available $TESTPOOL` | ||||
| 
 | ||||
| typeset -i tolerance=0 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 George Melikov
						George Melikov