Compare commits
	
		
			1 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| c1f2a28ac1 | 
| @@ -62,7 +62,7 @@ For a long running (~1 hours 15 minutes) example: | ||||
|  | ||||
| The outpot (of the short running parameters) will look something like this: | ||||
| ``` | ||||
| ./sudoku-funpark -row1 769104802 -row2 154800060 -row3 832700154 -row4 600900328 -row5 045328670 -row6 328670945 -row7 597410280 -row8 006283090 -row9 200590006  | ||||
| ./sudoku-funpark -row1 769104802 -row2 154800060 -row3 832700154 -row4 600900328 -row5 045328670 -row6 328670945 -row7 597410280 -row8 006283090 -row9 200590006 | ||||
| Loading blocks... Done! (38.957376ms) | ||||
| Populating blocks... Done! (92.087174ms) | ||||
| Number of (potential) solutions: 26542080 | ||||
|   | ||||
							
								
								
									
										90
									
								
								export/Export_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								export/Export_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,90 @@ | ||||
| package export | ||||
|  | ||||
| import ( | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/controller" | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/outputter" | ||||
| ) | ||||
|  | ||||
| // This function will test the Export function. | ||||
| // Starts off by creating all the structs and intefaces needed. | ||||
| // Set all the needed values. | ||||
| // Execute the Export function. | ||||
| // Check if the output is a string. | ||||
| // Check if the output for "human" "flat" and "json" are valid. | ||||
| func TestExport(t *testing.T) { | ||||
|  | ||||
| 	// Create a new Export struct. | ||||
| 	export := Export{} | ||||
|  | ||||
| 	// Create a new outputter struct. | ||||
| 	outp := outputter.Outputter{} | ||||
|  | ||||
| 	// Set output type to "short". | ||||
| 	outp.OutputType = "short" | ||||
|  | ||||
| 	// Create a new Controller struct and set the outputter. | ||||
| 	controller := controller.Controller{Outputter: &outp} | ||||
|  | ||||
| 	// Set the Controller in the Export struct. | ||||
| 	export.Controller = &controller | ||||
|  | ||||
| 	// Populate the Solutions slice. | ||||
| 	controller.Solutions = append(controller.Solutions, []string{"123456789", "987654321", "123456789", "987654321", "123456789", "987654321", "123456789", "987654321", "123456789"}) | ||||
|  | ||||
| 	// Set output type to "human". | ||||
| 	controller.Output = "human" | ||||
|  | ||||
| 	// Execute the Export function. | ||||
| 	render := export.Export() | ||||
|  | ||||
| 	// Check if the output is a string and not empty. | ||||
| 	if render == "" { | ||||
| 		t.Error("Expected a non-empty string, string was empty") | ||||
| 	} | ||||
|  | ||||
| 	// Set the expected variable. | ||||
| 	expected := "\nSolution #1:\n╔═══════════╗\n║123│456│789╢\n║987│654│321╢\n║123│456│789╢\n╟───┼───┼───╢\n║987│654│321╢\n║123│456│789╢\n║987│654│321╢\n╟───┼───┼───╢\n║123│456│789╢\n║987│654│321╢\n║123│456│789╢\n╚═══════════╝\n" | ||||
|  | ||||
| 	// Check if the output is the same as the expected variable. | ||||
| 	if render != expected { | ||||
| 		t.Error("Expected a ", expected, ", got", render) | ||||
| 	} | ||||
|  | ||||
| 	// Set output type to "flat". | ||||
| 	controller.Output = "flat" | ||||
|  | ||||
| 	// Execute the Export function. | ||||
| 	render = export.Export() | ||||
|  | ||||
| 	// Check if the output for "flat" is non-empty. | ||||
| 	if render == "" { | ||||
| 		t.Error("Expected a non-empty string, string was empty") | ||||
| 	} | ||||
|  | ||||
| 	expected = "\nSolution #1:\n[123456789 987654321 123456789 987654321 123456789 987654321 123456789 987654321 123456789]\n" | ||||
|  | ||||
| 	if render != expected { | ||||
| 		t.Error("Expected a ", expected, ", got", render) | ||||
| 	} | ||||
|  | ||||
| 	// Set output type to "json". | ||||
| 	controller.Output = "json" | ||||
|  | ||||
| 	// Execute the Export function. | ||||
| 	render = export.Export() | ||||
|  | ||||
| 	// Check if the output for "json" is valid. | ||||
| 	if render == "" { | ||||
| 		t.Error("Expected a non-empty string, got empty string") | ||||
| 	} | ||||
|  | ||||
| 	// Set the expected variable. | ||||
| 	expected = "[{\"order\":0,\"row1\":\"123456789\",\"row2\":\"987654321\",\"row3\":\"123456789\",\"row4\":\"987654321\",\"row5\":\"123456789\",\"row6\":\"987654321\",\"row7\":\"123456789\",\"row8\":\"987654321\",\"row9\":\"123456789\"}]" | ||||
|  | ||||
| 	// Check if what is rendered is the same as the expected variable. | ||||
| 	if render != expected { | ||||
| 		t.Error("Expected a ", expected, ", got", render) | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										39
									
								
								export/renderFlat_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								export/renderFlat_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | ||||
| package export | ||||
|  | ||||
| import ( | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/controller" | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/outputter" | ||||
| ) | ||||
|  | ||||
| // This function will test the renderFlat function. | ||||
| // Then it will execute the renderFlat function. | ||||
| // Check if the output is a string. | ||||
| func TestRenderFlat(t *testing.T) { | ||||
|  | ||||
| 	// Create a new Export struct. | ||||
| 	export := Export{} | ||||
|  | ||||
| 	// Create a new Controller struct. | ||||
| 	// Set output type to "human". | ||||
| 	outp := outputter.Outputter{} | ||||
| 	outp.OutputType = "short" | ||||
| 	controller := controller.Controller{Outputter: &outp} | ||||
| 	export.Controller = &controller | ||||
| 	controller.Solutions = append(controller.Solutions, []string{"123456789", "987654321", "123456789", "987654321", "123456789", "987654321", "123456789", "987654321", "123456789"}) | ||||
|  | ||||
| 	// Execute the renderFlat function. | ||||
| 	render := export.renderFlat() | ||||
|  | ||||
| 	// Check if the output is a string and not empty. | ||||
| 	if render == "" { | ||||
| 		t.Error("Expected a non-empty string, got", render) | ||||
| 	} | ||||
|  | ||||
| 	// Check if the output is a string. | ||||
| 	if render != "\nSolution #1:\n[123456789 987654321 123456789 987654321 123456789 987654321 123456789 987654321 123456789]\n" { | ||||
| 		t.Error("Expected a string, got", render) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										45
									
								
								export/renderHumanReadable_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								export/renderHumanReadable_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| package export | ||||
|  | ||||
| import ( | ||||
| 	"strings" | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/controller" | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/outputter" | ||||
| ) | ||||
|  | ||||
| // This function will test the renderHumanReadable function. | ||||
| // Starts off by creating a new Export struct. | ||||
| // Creates a new Controller struct. | ||||
| // Adds a solution to the Controller struct. | ||||
| // Then it will execute the renderHumanReadable function. | ||||
| // Check if the output is a string. | ||||
| func TestRenderHumanReadable(t *testing.T) { | ||||
|  | ||||
| 	// Create a new Export struct. | ||||
| 	export := Export{} | ||||
|  | ||||
| 	// Create a new Controller struct. | ||||
| 	// Set output type to "human". | ||||
| 	outp := outputter.Outputter{} | ||||
| 	outp.OutputType = "short" | ||||
| 	controller := controller.Controller{Outputter: &outp} | ||||
| 	export.Controller = &controller | ||||
| 	controller.Solutions = append(controller.Solutions, []string{"123456789", "987654321", "123456789", "987654321", "123456789", "987654321", "123456789", "987654321", "123456789"}) | ||||
|  | ||||
| 	// Execute the renderHumanReadable function. | ||||
| 	render := export.renderHumanReadable() | ||||
|  | ||||
| 	expected := "\nSolution #1:\n╔═══════════╗\n║123│456│789╢\n║987│654│321╢\n║123│456│789╢\n╟───┼───┼───╢\n║987│654│321╢\n║123│456│789╢\n║987│654│321╢\n╟───┼───┼───╢\n║123│456│789╢\n║987│654│321╢\n║123│456│789╢\n╚═══════════╝\n" | ||||
|  | ||||
| 	// Check if the output is a string and not empty. | ||||
| 	if render == "" { | ||||
| 		t.Error("Expected a non-empty string, got", render) | ||||
| 	} | ||||
|  | ||||
| 	// Check if the output is a string. | ||||
| 	if strings.TrimSpace(render) != strings.TrimSpace(expected) { | ||||
| 		t.Error("Expected a string, got", render) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										54
									
								
								export/renderJSON_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								export/renderJSON_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | ||||
| package export | ||||
|  | ||||
| import ( | ||||
| 	"encoding/json" | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/controller" | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/outputter" | ||||
| ) | ||||
|  | ||||
| // This function will test the renderJSON function. | ||||
| // Starts off by creating a new Export struct. | ||||
| // Creates a new Controller struct. | ||||
| // Adds a solution to the Controller struct. | ||||
| // Then it will execute the renderJSON function. | ||||
| // Check if the output is a JSON string. | ||||
| func TestRenderJSON(t *testing.T) { | ||||
|  | ||||
| 	// Create a new Export struct. | ||||
| 	export := Export{} | ||||
| 	outp := outputter.Outputter{} | ||||
| 	outp.OutputType = "short" | ||||
| 	export.Controller = &controller.Controller{Outputter: &outp} | ||||
|  | ||||
| 	// Create a new Controller struct. | ||||
| 	controller := controller.Controller{} | ||||
| 	controller.Solutions = append(controller.Solutions, []string{"123456789", "987654321", "123456789", "987654321", "123456789", "987654321", "123456789", "987654321", "123456789"}) | ||||
|  | ||||
| 	// Add a solution to the Controller struct. | ||||
| 	export.Controller = &controller | ||||
|  | ||||
| 	// Execute the renderJSON function. | ||||
| 	render := export.renderJSON() | ||||
|  | ||||
| 	// Check if the output is a JSON string and not empty. | ||||
| 	if render == "" { | ||||
| 		t.Error("Expected a non-empty JSON string, got", render) | ||||
| 	} | ||||
|  | ||||
| 	// Check if the output is a JSON string.\ | ||||
| 	if render != "[{\"order\":0,\"row1\":\"123456789\",\"row2\":\"987654321\",\"row3\":\"123456789\",\"row4\":\"987654321\",\"row5\":\"123456789\",\"row6\":\"987654321\",\"row7\":\"123456789\",\"row8\":\"987654321\",\"row9\":\"123456789\"}]" { | ||||
| 		t.Error("Expected a JSON string, got", render) | ||||
| 	} | ||||
|  | ||||
| 	// Check if the outpt is a valid JSON string. | ||||
| 	// Check using the json.Unmarshal function. | ||||
| 	// If the output is not a valid JSON string, the Unmarshal function will throw an error. | ||||
| 	var result []map[string]interface{} | ||||
| 	err := json.Unmarshal([]byte(render), &result) | ||||
| 	if err != nil { | ||||
| 		t.Error("Expected a valid JSON string, got", render) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										39
									
								
								flags/validChar_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								flags/validChar_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | ||||
| package flags | ||||
|  | ||||
| import "testing" | ||||
|  | ||||
| func TestValidChar(t *testing.T) { | ||||
| 	tests := []struct { | ||||
| 		name  string | ||||
| 		char  rune | ||||
| 		valid bool | ||||
| 	}{ | ||||
| 		{ | ||||
| 			name:  "Valid char", | ||||
| 			char:  '1', | ||||
| 			valid: true, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name:  "Invalid char", | ||||
| 			char:  'a', | ||||
| 			valid: false, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name:  "Valid char but not relevant", | ||||
| 			char:  '0', | ||||
| 			valid: true, | ||||
| 		}, | ||||
| 	} | ||||
|  | ||||
| 	flags := Flags{} | ||||
|  | ||||
| 	// Run tests | ||||
| 	for _, tt := range tests { | ||||
| 		t.Run(tt.name, func(t *testing.T) { | ||||
| 			if got := flags.validChar(tt.char); got != tt.valid { | ||||
| 				t.Errorf("validChar() = %v, want %v", got, tt.valid) | ||||
| 			} | ||||
| 		}) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										40
									
								
								solver/LoadBlocks_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								solver/LoadBlocks_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | ||||
| package solver | ||||
|  | ||||
| import ( | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/controller" | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/outputter" | ||||
| ) | ||||
|  | ||||
| // This function will test the loadBlocks function. | ||||
| // Starts off by creating a new Solver struct. | ||||
| // Then it will execute the loadBlocks function. | ||||
| // Check if there are 9! blocks loaded. | ||||
| // Check if the first block is "123456789". | ||||
| // check if the last block is "987654321". | ||||
| func TestLoadBlocks(t *testing.T) { | ||||
|  | ||||
| 	// Do all the necesarry steps to initialize the solver. | ||||
| 	solver := Solver{} | ||||
| 	outp := outputter.Outputter{} | ||||
| 	outp.OutputType = "short" | ||||
| 	solver.Outp = &outp | ||||
| 	controller := controller.Controller{} | ||||
| 	solver.Controller = &controller | ||||
| 	solver.LoadBlocks() | ||||
|  | ||||
| 	// Check if there are 9! blocks loaded. | ||||
| 	if len(solver.Controller.Blocks) != 362880 { | ||||
| 		t.Error("Expected 362880, got", len(solver.Controller.Blocks)) | ||||
| 	} | ||||
| 	// Check if the first block is "123456789". | ||||
| 	if solver.Controller.Blocks[0] != "123456789" { | ||||
| 		t.Error("Expected 123456789, got", solver.Controller.Blocks[0]) | ||||
| 	} | ||||
| 	// Check if the last block is "987654321". | ||||
| 	if solver.Controller.Blocks[362879] != "987654321" { | ||||
| 		t.Error("Expected 987654321, got", solver.Controller.Blocks[362879]) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										90
									
								
								solver/PopulateBlocks_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								solver/PopulateBlocks_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,90 @@ | ||||
| package solver | ||||
|  | ||||
| import ( | ||||
| 	"slices" | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/controller" | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/outputter" | ||||
| ) | ||||
|  | ||||
| // This functions tests the PopulateBlocks function. | ||||
| // It does this by creating a small set of rows and then | ||||
| // calling the PopulateBlocks function. It then checks | ||||
| // if the number of blocks is as expected. | ||||
| func TestPopulateBlocks(t *testing.T) { | ||||
| 	// Do all the necesarry steps to initialize the solver. | ||||
| 	solver := Solver{} | ||||
| 	outp := outputter.Outputter{} | ||||
| 	outp.OutputType = "short" | ||||
| 	solver.Outp = &outp | ||||
| 	controller := controller.Controller{} | ||||
| 	solver.Controller = &controller | ||||
| 	solver.LoadBlocks() | ||||
|  | ||||
| 	// Create a set of rows | ||||
| 	// Using the following values: [769154832 154832769 832769154 671945328 945328671 328671945 597416283 416283597 283597416] | ||||
| 	solver.Controller.Row1 = "769154800" | ||||
| 	solver.Controller.Row2 = "154832700" | ||||
| 	solver.Controller.Row3 = "832769100" | ||||
| 	solver.Controller.Row4 = "671945300" | ||||
| 	solver.Controller.Row5 = "945328600" | ||||
| 	solver.Controller.Row6 = "328671900" | ||||
| 	solver.Controller.Row7 = "597416200" | ||||
| 	solver.Controller.Row8 = "416283500" | ||||
| 	solver.Controller.Row9 = "283597400" | ||||
|  | ||||
| 	// Call the PopulateBlocks function | ||||
| 	solver.PopulateBlocks() | ||||
|  | ||||
| 	// Check if the number of blocks is as expected | ||||
| 	if solver.Iter != 512 { | ||||
| 		t.Errorf("Expected 19683 blocks, got %d", solver.Iter) | ||||
| 	} | ||||
|  | ||||
| 	// Check if solver.row1s is as expected | ||||
| 	if slices.Compare(solver.row1s, []string{"769154823", "769154832"}) != 0 { | ||||
| 		t.Errorf("Expected [769154832, 769154823], got %s", solver.row1s) | ||||
| 	} | ||||
|  | ||||
| 	// check if solver.row2s is as expected | ||||
| 	if slices.Compare(solver.row2s, []string{"154832769", "154832796"}) != 0 { | ||||
| 		t.Errorf("Expected [154832769, 154832796], got %s", solver.row2s) | ||||
| 	} | ||||
|  | ||||
| 	// check if solver.row3s is as expected | ||||
| 	if slices.Compare(solver.row3s, []string{"832769145", "832769154"}) != 0 { | ||||
| 		t.Errorf("Expected [832769154, 832769145], got %s", solver.row3s) | ||||
| 	} | ||||
|  | ||||
| 	// check if solver.row4s is as expected | ||||
| 	if slices.Compare(solver.row4s, []string{"671945328", "671945382"}) != 0 { | ||||
| 		t.Errorf("Expected [671945328, 671945382], got %s", solver.row4s) | ||||
| 	} | ||||
|  | ||||
| 	// check if solver.row5s is as expected | ||||
| 	if slices.Compare(solver.row5s, []string{"945328617", "945328671"}) != 0 { | ||||
| 		t.Errorf("Expected [945328617, 945328671], got %s", solver.row5s) | ||||
| 	} | ||||
|  | ||||
| 	// check if solver.row6s is as expected | ||||
| 	if slices.Compare(solver.row6s, []string{"328671945", "328671954"}) != 0 { | ||||
| 		t.Errorf("Expected [328671945, 328671954], got %s", solver.row6s) | ||||
| 	} | ||||
|  | ||||
| 	// check if solver.row7s is as expected | ||||
| 	if slices.Compare(solver.row7s, []string{"597416238", "597416283"}) != 0 { | ||||
| 		t.Errorf("Expected [597416238, 597416283], got %s", solver.row7s) | ||||
| 	} | ||||
|  | ||||
| 	// check if solver.row8s is as expected | ||||
| 	if slices.Compare(solver.row8s, []string{"416283579", "416283597"}) != 0 { | ||||
| 		t.Errorf("Expected [416283579, 416283597], got %s", solver.row8s) | ||||
| 	} | ||||
|  | ||||
| 	// check if solver.row9s is as expected | ||||
| 	if slices.Compare(solver.row9s, []string{"283597416", "283597461"}) != 0 { | ||||
| 		t.Errorf("Expected [283597416, 283597461], got %s", solver.row9s) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										33
									
								
								solver/calcAVG_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								solver/calcAVG_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| package solver | ||||
|  | ||||
| import ( | ||||
| 	"testing" | ||||
| ) | ||||
|  | ||||
| // Test the calcAVG function. | ||||
| func TestCalcAVG(t *testing.T) { | ||||
|  | ||||
| 	// Create a new Solver struct. | ||||
| 	solver := Solver{} | ||||
| 	// Populate the solver.rates[] slice with some values and check if the average is calculated correctly. | ||||
| 	solver.rates = []uint64{1, 2, 3, 4, 5} | ||||
| 	if solver.calcAVG() != 3 { | ||||
| 		t.Error("Expected 3, got", solver.calcAVG()) | ||||
| 	} | ||||
| 	// Populate the solver.Rate[] slice with some values and check if the average is calculated correctly. | ||||
| 	solver.rates = []uint64{1, 2, 3, 4, 5, 6} | ||||
| 	if solver.calcAVG() != 3 { | ||||
| 		t.Error("Expected 3, got", solver.calcAVG()) | ||||
| 	} | ||||
| 	// Populate the solver.Rate[] slice with some values and check if the average is calculated correctly. | ||||
| 	solver.rates = []uint64{1, 2, 3, 4, 5, 6, 7} | ||||
| 	if solver.calcAVG() != 4 { | ||||
| 		t.Error("Expected 4, got", solver.calcAVG()) | ||||
| 	} | ||||
| 	// Populate the solver.Rate[] slice with some values and check if the average is calculated correctly. | ||||
| 	solver.rates = []uint64{1, 2, 3, 4, 5, 6, 7, 8} | ||||
| 	if solver.calcAVG() != 4 { | ||||
| 		t.Error("Expected 4, got", solver.calcAVG()) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										53
									
								
								solver/findBlocks_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								solver/findBlocks_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | ||||
| package solver | ||||
|  | ||||
| import ( | ||||
| 	"slices" | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/controller" | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/outputter" | ||||
| ) | ||||
|  | ||||
| // TestfindBlocks tests the findBlocks function. | ||||
| // It defines the solver struct | ||||
| // and calls the findBlocks function with a row and a slice of rows. | ||||
| // It then checks if the slice of rows is as expected. | ||||
| func TestFindBlocks(t *testing.T) { | ||||
|  | ||||
| 	// Create a new Solver struct. | ||||
| 	solver := Solver{} | ||||
|  | ||||
| 	// Create outputter struct. | ||||
| 	outp := outputter.Outputter{} | ||||
|  | ||||
| 	// Set the output type to human. | ||||
| 	outp.OutputType = "human" | ||||
|  | ||||
| 	// Set the outputter of the solver to the outputter. | ||||
| 	solver.Outp = &outp | ||||
|  | ||||
| 	// Create a controller struct. | ||||
| 	controller := controller.Controller{} | ||||
|  | ||||
| 	// Set the controller of the solver to the controller. | ||||
| 	solver.Controller = &controller | ||||
|  | ||||
| 	// Execute the loadBlocks function. | ||||
| 	solver.LoadBlocks() | ||||
|  | ||||
| 	// Provide controller.row1 with a value. | ||||
| 	// This is the row that will be used in the findBlocks function. | ||||
| 	controller.Row1 = "769104802" | ||||
|  | ||||
| 	// Call the findBlocks function with the row and the slice of rows. | ||||
| 	solver.findBlocks(&controller.Row1, &solver.row1s) | ||||
|  | ||||
| 	// A slice with the expected results. | ||||
| 	expected := []string{"769154832", "769134852"} | ||||
|  | ||||
| 	// Check if the slice of rows1 is same as expected variable. | ||||
| 	if slices.Equal(solver.row1s, expected) { | ||||
| 		t.Errorf("Expected %v, got %v", expected, solver.row1s) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										72
									
								
								solver/setWorkload_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								solver/setWorkload_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,72 @@ | ||||
| package solver | ||||
|  | ||||
| import ( | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/controller" | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/outputter" | ||||
| ) | ||||
|  | ||||
| // Function to test the setWorkload function. | ||||
| func TestSetWorkload(t *testing.T) { | ||||
| 	// Create a new Solver struct. | ||||
| 	solver := Solver{} | ||||
|  | ||||
| 	// Create outputter struct. | ||||
| 	outp := outputter.Outputter{} | ||||
|  | ||||
| 	// Set the output type to human. | ||||
| 	outp.OutputType = "short" | ||||
|  | ||||
| 	// Set the outputter of the solver to the outputter. | ||||
| 	solver.Outp = &outp | ||||
|  | ||||
| 	// Create a controller struct. | ||||
| 	controller := controller.Controller{} | ||||
|  | ||||
| 	// Set the controller of the solver to the controller. | ||||
| 	solver.Controller = &controller | ||||
|  | ||||
| 	// Execute the loadBlocks function. | ||||
| 	solver.LoadBlocks() | ||||
|  | ||||
| 	// Provide controller.row1 with a value. | ||||
| 	// This is the row that will be used in the findBlocks function. | ||||
| 	controller.Row1 = "769104802" | ||||
|  | ||||
| 	// Fill the other rows with values. | ||||
| 	solver.row2s = []string{"769104802"} | ||||
| 	solver.row3s = []string{"769104802"} | ||||
| 	solver.row4s = []string{"769104802"} | ||||
| 	solver.row5s = []string{"769104802"} | ||||
| 	solver.row6s = []string{"769104802"} | ||||
| 	solver.row7s = []string{"769104802"} | ||||
| 	solver.row8s = []string{"769104802"} | ||||
| 	solver.row9s = []string{"769104802"} | ||||
|  | ||||
| 	// Call the findBlocks function with the row and the slice of rows. | ||||
| 	solver.findBlocks(&controller.Row1, &solver.row1s) | ||||
|  | ||||
| 	// Divide the work between two agents. | ||||
| 	solver.Controller.Split = 2 | ||||
|  | ||||
| 	// Set the part of the workload that the first agent will do. | ||||
| 	solver.Controller.Part = 1 | ||||
|  | ||||
| 	// Call the splitWorkload function. | ||||
| 	agents := solver.splitWorkload() | ||||
|  | ||||
| 	// Run the setWorkload function. | ||||
| 	solver.setWorkload(agents) | ||||
|  | ||||
| 	// Check if the solver.row1s slice is as expected. | ||||
| 	if len(solver.row1s) != 1 { | ||||
| 		t.Errorf("Expected 1, got %v", len(solver.row1s)) | ||||
| 	} | ||||
|  | ||||
| 	// Check if the solver.Iter value is as expected. | ||||
| 	if solver.Iter != 1 { | ||||
| 		t.Errorf("Expected 9, got %v", solver.Iter) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										51
									
								
								solver/splitWorkload_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								solver/splitWorkload_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
| package solver | ||||
|  | ||||
| import ( | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/controller" | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/outputter" | ||||
| ) | ||||
|  | ||||
| // Test the splitWorkload function. | ||||
| func TestSplitWorkload(t *testing.T) { | ||||
| 	// Create a new Solver struct. | ||||
| 	solver := Solver{} | ||||
|  | ||||
| 	// Create outputter struct. | ||||
| 	outp := outputter.Outputter{} | ||||
|  | ||||
| 	// Set the output type to human. | ||||
| 	outp.OutputType = "human" | ||||
|  | ||||
| 	// Set the outputter of the solver to the outputter. | ||||
| 	solver.Outp = &outp | ||||
|  | ||||
| 	// Create a controller struct. | ||||
| 	controller := controller.Controller{} | ||||
|  | ||||
| 	// Set the controller of the solver to the controller. | ||||
| 	solver.Controller = &controller | ||||
|  | ||||
| 	// Execute the loadBlocks function. | ||||
| 	solver.LoadBlocks() | ||||
|  | ||||
| 	// Provide controller.row1 with a value. | ||||
| 	// This is the row that will be used in the findBlocks function. | ||||
| 	controller.Row1 = "769104802" | ||||
|  | ||||
| 	// Call the findBlocks function with the row and the slice of rows. | ||||
| 	solver.findBlocks(&controller.Row1, &solver.row1s) | ||||
|  | ||||
| 	// Divide the work between two agents. | ||||
| 	solver.Controller.Split = 2 | ||||
|  | ||||
| 	// Call the splitWorkload function. | ||||
| 	agents := solver.splitWorkload() | ||||
|  | ||||
| 	// Check if the agents slice is as expected. | ||||
| 	if agents[0] != 1 || agents[1] != 1 { | ||||
| 		t.Errorf("Expected [1, 1], got %v", agents) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										16
									
								
								solver/validateCombination_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								solver/validateCombination_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| package solver | ||||
|  | ||||
| import ( | ||||
| 	"testing" | ||||
| ) | ||||
|  | ||||
| // TestValidateCombination tests the validateCombination function. | ||||
| func TestValidateCombination(t *testing.T) { | ||||
| 	// Create a new solver | ||||
| 	solver := Solver{} | ||||
|  | ||||
| 	// Test the validateCombination function | ||||
| 	if !solver.validateCombination("769154832", "154832769", "832769154", "671945328", "945328671", "328671945", "597416283", "416283597", "283597416") { | ||||
| 		t.Error("validateCombination failed") | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										53
									
								
								solver/validator_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								solver/validator_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | ||||
| package solver | ||||
|  | ||||
| import ( | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/controller" | ||||
| 	"gitea.ligthert.net/golang/sudoku-funpark/outputter" | ||||
| ) | ||||
|  | ||||
| // This function will test the validator function. | ||||
| // It will create all the structs, and set required values | ||||
| // Load the blocks, populate the blocks, and then run the validator | ||||
| func TestValidator(t *testing.T) { | ||||
| 	// Do all the necesarry steps to initialize the solver. | ||||
| 	solver := Solver{} | ||||
| 	outp := outputter.Outputter{} | ||||
| 	outp.OutputType = "short" | ||||
| 	solver.Outp = &outp | ||||
| 	controller := controller.Controller{} | ||||
| 	solver.Controller = &controller | ||||
| 	solver.LoadBlocks() | ||||
|  | ||||
| 	// Fill the slices of solver.rows with the following values: | ||||
| 	// [769154832 154832769 832769154 671945328 945328671 328671945 597416283 416283597 283597416] | ||||
| 	solver.row1s = []string{"769154832"} | ||||
| 	solver.row2s = []string{"154832769"} | ||||
| 	solver.row3s = []string{"832769154"} | ||||
| 	solver.row4s = []string{"671945328"} | ||||
| 	solver.row5s = []string{"945328671"} | ||||
| 	solver.row6s = []string{"328671945"} | ||||
| 	solver.row7s = []string{"597416283"} | ||||
| 	solver.row8s = []string{"416283597"} | ||||
| 	solver.row9s = []string{"283597416"} | ||||
|  | ||||
| 	// Set the rows to validate | ||||
| 	rows1Index := 0 | ||||
| 	rows2Index := 0 | ||||
| 	rows3Index := 0 | ||||
| 	rows4Index := 0 | ||||
| 	rows5Index := 0 | ||||
| 	rows6Index := 0 | ||||
| 	rows7Index := 0 | ||||
| 	rows8Index := 0 | ||||
| 	rows9Index := 0 | ||||
|  | ||||
| 	// Run the validator | ||||
| 	solver.validator(rows1Index, rows2Index, rows3Index, rows4Index, rows5Index, rows6Index, rows7Index, rows8Index, rows9Index) | ||||
|  | ||||
| 	// Check the number of solutions | ||||
| 	if len(controller.Solutions) != 1 { | ||||
| 		t.Errorf("Expected 1 solution, got %d", len(controller.Solutions)) | ||||
| 	} | ||||
| } | ||||
		Reference in New Issue
	
	Block a user