| 
									
										
										
										
											2023-05-01 11:19:09 +02:00
										 |  |  | package restore | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"testing" | 
					
						
							|  |  |  | 	"time" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/restic/restic/internal/test" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type mockTerm struct { | 
					
						
							|  |  |  | 	output []string | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (m *mockTerm) Print(line string) { | 
					
						
							|  |  |  | 	m.output = append(m.output, line) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (m *mockTerm) SetStatus(lines []string) { | 
					
						
							|  |  |  | 	m.output = append([]string{}, lines...) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-31 20:38:51 +02:00
										 |  |  | func createTextProgress() (*mockTerm, ProgressPrinter) { | 
					
						
							| 
									
										
										
										
											2023-05-01 11:19:09 +02:00
										 |  |  | 	term := &mockTerm{} | 
					
						
							| 
									
										
										
										
											2024-05-31 20:38:51 +02:00
										 |  |  | 	printer := NewTextProgress(term, 3) | 
					
						
							|  |  |  | 	return term, printer | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestPrintUpdate(t *testing.T) { | 
					
						
							|  |  |  | 	term, printer := createTextProgress() | 
					
						
							| 
									
										
										
										
											2024-05-31 14:12:06 +02:00
										 |  |  | 	printer.Update(State{3, 11, 0, 29, 47, 0}, 5*time.Second) | 
					
						
							| 
									
										
										
										
											2023-09-20 10:58:11 +02:00
										 |  |  | 	test.Equals(t, []string{"[0:05] 61.70%  3 files/dirs 29 B, total 11 files/dirs 47 B"}, term.output) | 
					
						
							| 
									
										
										
										
											2023-05-01 11:19:09 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-31 14:12:06 +02:00
										 |  |  | func TestPrintUpdateWithSkipped(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2024-05-31 20:38:51 +02:00
										 |  |  | 	term, printer := createTextProgress() | 
					
						
							| 
									
										
										
										
											2024-05-31 14:12:06 +02:00
										 |  |  | 	printer.Update(State{3, 11, 2, 29, 47, 59}, 5*time.Second) | 
					
						
							|  |  |  | 	test.Equals(t, []string{"[0:05] 61.70%  3 files/dirs 29 B, total 11 files/dirs 47 B, skipped 2 files/dirs 59 B"}, term.output) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-01 11:19:09 +02:00
										 |  |  | func TestPrintSummaryOnSuccess(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2024-05-31 20:38:51 +02:00
										 |  |  | 	term, printer := createTextProgress() | 
					
						
							| 
									
										
										
										
											2024-05-31 14:12:06 +02:00
										 |  |  | 	printer.Finish(State{11, 11, 0, 47, 47, 0}, 5*time.Second) | 
					
						
							| 
									
										
										
										
											2023-09-20 10:58:11 +02:00
										 |  |  | 	test.Equals(t, []string{"Summary: Restored 11 files/dirs (47 B) in 0:05"}, term.output) | 
					
						
							| 
									
										
										
										
											2023-05-01 11:19:09 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestPrintSummaryOnErrors(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2024-05-31 20:38:51 +02:00
										 |  |  | 	term, printer := createTextProgress() | 
					
						
							| 
									
										
										
										
											2024-05-31 14:12:06 +02:00
										 |  |  | 	printer.Finish(State{3, 11, 0, 29, 47, 0}, 5*time.Second) | 
					
						
							| 
									
										
										
										
											2023-09-20 10:58:11 +02:00
										 |  |  | 	test.Equals(t, []string{"Summary: Restored 3 / 11 files/dirs (29 B / 47 B) in 0:05"}, term.output) | 
					
						
							| 
									
										
										
										
											2023-05-01 11:19:09 +02:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2024-05-31 14:12:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | func TestPrintSummaryOnSuccessWithSkipped(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2024-05-31 20:38:51 +02:00
										 |  |  | 	term, printer := createTextProgress() | 
					
						
							| 
									
										
										
										
											2024-05-31 14:12:06 +02:00
										 |  |  | 	printer.Finish(State{11, 11, 2, 47, 47, 59}, 5*time.Second) | 
					
						
							|  |  |  | 	test.Equals(t, []string{"Summary: Restored 11 files/dirs (47 B) in 0:05, skipped 2 files/dirs 59 B"}, term.output) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-05-31 20:38:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | func TestPrintCompleteItem(t *testing.T) { | 
					
						
							|  |  |  | 	for _, data := range []struct { | 
					
						
							|  |  |  | 		action   ItemAction | 
					
						
							|  |  |  | 		size     uint64 | 
					
						
							|  |  |  | 		expected string | 
					
						
							|  |  |  | 	}{ | 
					
						
							|  |  |  | 		{ActionDirRestored, 0, "restored  test"}, | 
					
						
							|  |  |  | 		{ActionFileRestored, 123, "restored  test with size 123 B"}, | 
					
						
							|  |  |  | 		{ActionFileUpdated, 123, "updated   test with size 123 B"}, | 
					
						
							|  |  |  | 		{ActionFileUnchanged, 123, "unchanged test with size 123 B"}, | 
					
						
							| 
									
										
										
										
											2024-06-29 21:29:42 +02:00
										 |  |  | 		{ActionDeleted, 0, "deleted   test"}, | 
					
						
							| 
									
										
										
										
											2024-05-31 20:38:51 +02:00
										 |  |  | 	} { | 
					
						
							|  |  |  | 		term, printer := createTextProgress() | 
					
						
							|  |  |  | 		printer.CompleteItem(data.action, "test", data.size) | 
					
						
							|  |  |  | 		test.Equals(t, []string{data.expected}, term.output) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |