mirror of https://github.com/portainer/portainer
				
				
				
			
		
			
				
	
	
		
			132 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
| package slices
 | |
| 
 | |
| import (
 | |
| 	"strconv"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| type filterTestCase[T any] struct {
 | |
| 	name      string
 | |
| 	input     []T
 | |
| 	expected  []T
 | |
| 	predicate func(T) bool
 | |
| }
 | |
| 
 | |
| func TestFilter(t *testing.T) {
 | |
| 
 | |
| 	intTestCases := []filterTestCase[int]{
 | |
| 		{
 | |
| 			name:     "Filter even numbers",
 | |
| 			input:    []int{1, 2, 3, 4, 5, 6, 7, 8, 9},
 | |
| 			expected: []int{2, 4, 6, 8},
 | |
| 
 | |
| 			predicate: func(n int) bool {
 | |
| 				return n%2 == 0
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name:     "Filter odd numbers",
 | |
| 			input:    []int{1, 2, 3, 4, 5, 6, 7, 8, 9},
 | |
| 			expected: []int{1, 3, 5, 7, 9},
 | |
| 
 | |
| 			predicate: func(n int) bool {
 | |
| 				return n%2 != 0
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	runTestCases(t, intTestCases)
 | |
| 
 | |
| 	stringTestCases := []filterTestCase[string]{
 | |
| 		{
 | |
| 			name:     "Filter strings starting with 'A'",
 | |
| 			input:    []string{"Apple", "Banana", "Avocado", "Grapes", "Apricot"},
 | |
| 			expected: []string{"Apple", "Avocado", "Apricot"},
 | |
| 			predicate: func(s string) bool {
 | |
| 				return s[0] == 'A'
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name:     "Filter strings longer than 5 characters",
 | |
| 			input:    []string{"Apple", "Banana", "Avocado", "Grapes", "Apricot"},
 | |
| 			expected: []string{"Banana", "Avocado", "Grapes", "Apricot"},
 | |
| 			predicate: func(s string) bool {
 | |
| 				return len(s) > 5
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	runTestCases(t, stringTestCases)
 | |
| 
 | |
| }
 | |
| 
 | |
| func runTestCases[T any](t *testing.T, testCases []filterTestCase[T]) {
 | |
| 	for _, testCase := range testCases {
 | |
| 		t.Run(testCase.name, func(t *testing.T) {
 | |
| 			is := assert.New(t)
 | |
| 			result := Filter(testCase.input, testCase.predicate)
 | |
| 
 | |
| 			is.Equal(len(testCase.expected), len(result))
 | |
| 			is.ElementsMatch(testCase.expected, result)
 | |
| 		})
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestMap(t *testing.T) {
 | |
| 	intTestCases := []struct {
 | |
| 		name     string
 | |
| 		input    []int
 | |
| 		expected []string
 | |
| 		mapper   func(int) string
 | |
| 	}{
 | |
| 		{
 | |
| 			name:     "Map integers to strings",
 | |
| 			input:    []int{1, 2, 3, 4, 5},
 | |
| 			expected: []string{"1", "2", "3", "4", "5"},
 | |
| 			mapper: func(n int) string {
 | |
| 				return strconv.Itoa(n)
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	runMapTestCases(t, intTestCases)
 | |
| 
 | |
| 	stringTestCases := []struct {
 | |
| 		name     string
 | |
| 		input    []string
 | |
| 		expected []int
 | |
| 		mapper   func(string) int
 | |
| 	}{
 | |
| 		{
 | |
| 			name:     "Map strings to integers",
 | |
| 			input:    []string{"1", "2", "3", "4", "5"},
 | |
| 			expected: []int{1, 2, 3, 4, 5},
 | |
| 			mapper: func(s string) int {
 | |
| 				n, _ := strconv.Atoi(s)
 | |
| 				return n
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	runMapTestCases(t, stringTestCases)
 | |
| }
 | |
| 
 | |
| func runMapTestCases[T, U any](t *testing.T, testCases []struct {
 | |
| 	name     string
 | |
| 	input    []T
 | |
| 	expected []U
 | |
| 	mapper   func(T) U
 | |
| }) {
 | |
| 	for _, testCase := range testCases {
 | |
| 		t.Run(testCase.name, func(t *testing.T) {
 | |
| 			is := assert.New(t)
 | |
| 			result := Map(testCase.input, testCase.mapper)
 | |
| 
 | |
| 			is.Equal(len(testCase.expected), len(result))
 | |
| 			is.ElementsMatch(testCase.expected, result)
 | |
| 		})
 | |
| 	}
 | |
| }
 |