| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | package archiver | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"context" | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							| 
									
										
										
										
											2022-08-19 23:08:13 +02:00
										 |  |  | 	"os" | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 	"path/filepath" | 
					
						
							|  |  |  | 	"runtime" | 
					
						
							|  |  |  | 	"testing" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/restic/chunker" | 
					
						
							|  |  |  | 	"github.com/restic/restic/internal/fs" | 
					
						
							|  |  |  | 	"github.com/restic/restic/internal/restic" | 
					
						
							|  |  |  | 	"github.com/restic/restic/internal/test" | 
					
						
							| 
									
										
										
										
											2022-05-27 19:08:50 +02:00
										 |  |  | 	"golang.org/x/sync/errgroup" | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-09 13:42:33 +01:00
										 |  |  | func createTestFiles(t testing.TB, num int) (files []string) { | 
					
						
							|  |  |  | 	tempdir := test.TempDir(t) | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-18 19:31:42 +02:00
										 |  |  | 	for i := 0; i < num; i++ { | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 		filename := fmt.Sprintf("testfile-%d", i) | 
					
						
							| 
									
										
										
										
											2022-12-02 19:36:43 +01:00
										 |  |  | 		err := os.WriteFile(filepath.Join(tempdir, filename), []byte(filename), 0600) | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			t.Fatal(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		files = append(files, filepath.Join(tempdir, filename)) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-09 13:42:33 +01:00
										 |  |  | 	return files | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-27 11:26:52 +02:00
										 |  |  | func startFileSaver(ctx context.Context, t testing.TB) (*fileSaver, context.Context, *errgroup.Group) { | 
					
						
							| 
									
										
										
										
											2022-05-27 19:08:50 +02:00
										 |  |  | 	wg, ctx := errgroup.WithContext(ctx) | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-27 11:26:52 +02:00
										 |  |  | 	saveBlob := func(ctx context.Context, tpe restic.BlobType, buf *buffer, _ string, cb func(saveBlobResponse)) { | 
					
						
							|  |  |  | 		cb(saveBlobResponse{ | 
					
						
							| 
									
										
										
										
											2022-11-05 13:42:17 +01:00
										 |  |  | 			id:         restic.Hash(buf.Data), | 
					
						
							|  |  |  | 			length:     len(buf.Data), | 
					
						
							|  |  |  | 			sizeInRepo: len(buf.Data), | 
					
						
							|  |  |  | 			known:      false, | 
					
						
							|  |  |  | 		}) | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	workers := uint(runtime.NumCPU()) | 
					
						
							|  |  |  | 	pol, err := chunker.RandomPolynomial() | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		t.Fatal(err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-27 11:26:52 +02:00
										 |  |  | 	s := newFileSaver(ctx, wg, saveBlob, pol, workers, workers) | 
					
						
							| 
									
										
										
										
											2024-01-31 20:48:03 +01:00
										 |  |  | 	s.NodeFromFileInfo = func(snPath, filename string, fi os.FileInfo, ignoreXattrListError bool) (*restic.Node, error) { | 
					
						
							| 
									
										
										
										
											2024-08-26 23:03:25 +02:00
										 |  |  | 		return fs.NodeFromFileInfo(filename, fi, ignoreXattrListError) | 
					
						
							| 
									
										
										
										
											2022-08-19 23:08:13 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-27 19:08:50 +02:00
										 |  |  | 	return s, ctx, wg | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestFileSaver(t *testing.T) { | 
					
						
							|  |  |  | 	ctx, cancel := context.WithCancel(context.Background()) | 
					
						
							|  |  |  | 	defer cancel() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-09 13:42:33 +01:00
										 |  |  | 	files := createTestFiles(t, 15) | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	startFn := func() {} | 
					
						
							| 
									
										
										
										
											2022-10-22 12:05:49 +02:00
										 |  |  | 	completeReadingFn := func() {} | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 	completeFn := func(*restic.Node, ItemStats) {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	testFs := fs.Local{} | 
					
						
							| 
									
										
										
										
											2022-05-27 19:08:50 +02:00
										 |  |  | 	s, ctx, wg := startFileSaver(ctx, t) | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-27 11:26:52 +02:00
										 |  |  | 	var results []futureNode | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	for _, filename := range files { | 
					
						
							| 
									
										
										
										
											2024-07-21 16:30:49 +02:00
										 |  |  | 		f, err := testFs.OpenFile(filename, os.O_RDONLY, 0) | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			t.Fatal(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		fi, err := f.Stat() | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			t.Fatal(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-22 12:05:49 +02:00
										 |  |  | 		ff := s.Save(ctx, filename, filename, f, fi, startFn, completeReadingFn, completeFn) | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 		results = append(results, ff) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for _, file := range results { | 
					
						
							| 
									
										
										
										
											2022-05-29 11:57:10 +02:00
										 |  |  | 		fnr := file.take(ctx) | 
					
						
							|  |  |  | 		if fnr.err != nil { | 
					
						
							|  |  |  | 			t.Errorf("unable to save file: %v", fnr.err) | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-27 19:08:50 +02:00
										 |  |  | 	s.TriggerShutdown() | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-27 19:08:50 +02:00
										 |  |  | 	err := wg.Wait() | 
					
						
							| 
									
										
										
										
											2018-05-12 21:40:31 +02:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		t.Fatal(err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |