summaryrefslogblamecommitdiffstats
path: root/test/remove-trailing-ws.test
blob: 5f5117bcdcca4c389e3d85f20cd97bf5625b4133 (plain) (tree)
1
2
3
4
5
6
7
8
9








                                              
 



                         

      


                          
 

        
 

        
 

        
 








                         
 

        
 




                                
 

        
 

        
 

        
 





                 
 

         
 










                     
 

        
 

        
 

                
 

                
 











                    
 




                           
 

        
 






















                                                                              
                    
                    
                       
                     
                         
                    
                       
                    
                       
                           
                              
                    
                        
                         
                             

















                                                                            
                    
                    
                       
                     
                         
                    
                       
                    
                       
                           
                              
                    
                         
                         
                              








                                                         
# Unit test for the remove-trailing-ws script.

# Prepare the working directory
$ mkdir files.orig files

$ cat > files.orig/add
< Line 1
< Line 2
< Line 3
<
< Line 5
< Line 6
$ cat > files.orig/change
< change
< from
< this
$ cat > files.orig/complex
< Line 1
< Line 2
<
< Line 3
< Line 4
<
< Line 5
< Line 6
<
< Line 7
< Line 8
<
< Line 9
< Line 10
$ cat > files.orig/delete
< delete
< an old
< file
$ cat > files.orig/remove
< Line 1
< Line 2
<
< Line 3
< Line 4
<
< Line 5
< Line 6
$ cat > files.orig/remove-at-end
< Line 1
< Line 2
<
< Line 3
< Line 4
<
< Line 5
< Line 6
<
< Line 7
< Line 8
<
< Line 9
< Line 10

$ cat > files/add
< Line 1
< Line 2
<
< Line 3
< Line 4 
<
< Line 5
< Line 6
$ cat > files/change
< change
< to 
< that 
$ cat > files/complex
< Line 1
< Line 2
< Line 3
< Line 4
<
< Line 5
< Line 6
<
< Line 7
< Line 8
<
< Line 9	
< Line A
<
< Line B
< Line C 	
<
< Line D
< Line E
< Line F
< Line 10
$ cat > files/create
< create 
< a new 
< file 
$ cat > files/remove
< Line 1
< Line 2
< Line 3
<
< Line 5
< Line 6
$ cat > files/remove-at-end
< Line 1
< Line 2
<
< Line 3
< Line 4
<
< Line 5
< Line 6

$ cp -r files files.backup

# Generate the two patches
$ diff -ruN files.orig files > unified.diff
# For the context diff we need the files listed in a certain order to
# cover some corner cases
$ diff -c files.orig/add files/add > context.diff
$ diff -C 10 files.orig/remove-at-end files/remove-at-end >> context.diff
$ diff -cN files.orig/create files/create | sed -e '/^diff /d' >> context.diff
$ diff -cN files.orig/delete files/delete >> context.diff
$ diff -c files.orig/remove files/remove | sed -e '/^diff /d' >> context.diff
$ diff -c files.orig/change files/change | sed -e '/^diff /d'  >> context.diff
$ diff -c files.orig/complex files/complex >> context.diff

$ %{QUILT_DIR}/scripts/remove-trailing-ws < unified.diff > unified-wsok.diff
> Removing trailing whitespace from line 5 of files/add
> Removing trailing whitespace from lines 2,3 of files/change
> Removing trailing whitespace from lines 12,16 of files/complex
> Removing trailing whitespace from lines 1,2,3 of files/create
$ wc -l files/add
>~ (\s+)?8 files/add
$ wc -l files/change
>~ (\s+)?3 files/change
$ wc -l files/complex
>~ (\s+)?21 files/complex
$ wc -l files/create
>~ (\s+)?3 files/create
$ wc -l files/remove
>~ (\s+)?6 files/remove
$ wc -l files/remove-at-end
>~ (\s+)?8 files/remove-at-end
$ wc -l unified.diff
>~ (\s+)?85 unified.diff
$ wc -l unified-wsok.diff
>~ (\s+)?85 unified-wsok.diff
$ diff -u unified.diff unified-wsok.diff | grep '^++[^+]'
> ++Line 4
> ++to
> ++that
> ++Line 9
> ++Line C
> ++create
> ++a new
> ++file

$ rm -rf files
$ mv files.backup files
$ %{QUILT_DIR}/scripts/remove-trailing-ws < context.diff > context-wsok.diff
> Removing trailing whitespace from line 5 of files/add
> Removing trailing whitespace from lines 2,3 of files/change
> Removing trailing whitespace from lines 12,16 of files/complex
> Removing trailing whitespace from lines 1,2,3 of files/create
$ wc -l files/add
>~ (\s+)?8 files/add
$ wc -l files/change
>~ (\s+)?3 files/change
$ wc -l files/complex
>~ (\s+)?21 files/complex
$ wc -l files/create
>~ (\s+)?3 files/create
$ wc -l files/remove
>~ (\s+)?6 files/remove
$ wc -l files/remove-at-end
>~ (\s+)?8 files/remove-at-end
$ wc -l context.diff
>~ (\s+)?104 context.diff
$ wc -l context-wsok.diff
>~ (\s+)?104 context-wsok.diff
$ diff -u context.diff context-wsok.diff | grep '^+[+!] '
> ++ Line 4
> ++ create
> ++ a new
> ++ file
> +! to
> +! that
> +! Line 9
> +! Line C