You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							31 lines
						
					
					
						
							1.0 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							31 lines
						
					
					
						
							1.0 KiB
						
					
					
				
								package storage
							 | 
						|
								
							 | 
						|
								import (
							 | 
						|
									"io/ioutil"
							 | 
						|
									"math/rand"
							 | 
						|
									"testing"
							 | 
						|
								
							 | 
						|
									"github.com/chrislusf/seaweedfs/weed/glog"
							 | 
						|
									. "github.com/chrislusf/seaweedfs/weed/storage/types"
							 | 
						|
								)
							 | 
						|
								
							 | 
						|
								func TestFastLoadingNeedleMapMetrics(t *testing.T) {
							 | 
						|
								
							 | 
						|
									idxFile, _ := ioutil.TempFile("", "tmp.idx")
							 | 
						|
									nm := NewCompactNeedleMap(idxFile)
							 | 
						|
								
							 | 
						|
									for i := 0; i < 10000; i++ {
							 | 
						|
										nm.Put(Uint64ToNeedleId(uint64(i+1)), Uint32ToOffset(uint32(0)), Size(1))
							 | 
						|
										if rand.Float32() < 0.2 {
							 | 
						|
											nm.Delete(Uint64ToNeedleId(uint64(rand.Int63n(int64(i))+1)), Uint32ToOffset(uint32(0)))
							 | 
						|
										}
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									mm, _ := newNeedleMapMetricFromIndexFile(idxFile)
							 | 
						|
								
							 | 
						|
									glog.V(0).Infof("FileCount expected %d actual %d", nm.FileCount(), mm.FileCount())
							 | 
						|
									glog.V(0).Infof("DeletedSize expected %d actual %d", nm.DeletedSize(), mm.DeletedSize())
							 | 
						|
									glog.V(0).Infof("ContentSize expected %d actual %d", nm.ContentSize(), mm.ContentSize())
							 | 
						|
									glog.V(0).Infof("DeletedCount expected %d actual %d", nm.DeletedCount(), mm.DeletedCount())
							 | 
						|
									glog.V(0).Infof("MaxFileKey expected %d actual %d", nm.MaxFileKey(), mm.MaxFileKey())
							 | 
						|
								}
							 |