diff options
| author | Gabriel A. Giovanini <mail@gabrielgio.me> | 2024-05-25 23:41:01 +0200 | 
|---|---|---|
| committer | Gabriel A. Giovanini <mail@gabrielgio.me> | 2024-05-25 23:41:40 +0200 | 
| commit | c06945c189c1d8ef3cedeb51e416ba0fec36368f (patch) | |
| tree | e9655b29715d5bae1d3fc5f669a74f2d7bde3c4e /pkg/u | |
| parent | ce911df583e384d86018e42f9548cdf33d1c1549 (diff) | |
| download | cerrado-c06945c189c1d8ef3cedeb51e416ba0fec36368f.tar.gz cerrado-c06945c189c1d8ef3cedeb51e416ba0fec36368f.tar.bz2 cerrado-c06945c189c1d8ef3cedeb51e416ba0fec36368f.zip | |
feat: Add utils
Diffstat (limited to 'pkg/u')
| -rw-r--r-- | pkg/u/util.go | 17 | ||||
| -rw-r--r-- | pkg/u/util_test.go | 96 | 
2 files changed, 113 insertions, 0 deletions
| diff --git a/pkg/u/util.go b/pkg/u/util.go new file mode 100644 index 0000000..34eafd1 --- /dev/null +++ b/pkg/u/util.go @@ -0,0 +1,17 @@ +package u + +func First[T any](v []T) (T, bool) { +	if len(v) == 0 { +		var zero T +		return zero, false +	} +	return v[0], true +} + +func ChunkBy[T any](items []T, chunkSize int) [][]T { +	var chunks = make([][]T, 0, (len(items)/chunkSize)+1) +	for chunkSize < len(items) { +		items, chunks = items[chunkSize:], append(chunks, items[0:chunkSize:chunkSize]) +	} +	return append(chunks, items) +} diff --git a/pkg/u/util_test.go b/pkg/u/util_test.go new file mode 100644 index 0000000..a6d84c7 --- /dev/null +++ b/pkg/u/util_test.go @@ -0,0 +1,96 @@ +// go:build unit + +package u + +import ( +	"testing" + +	"github.com/google/go-cmp/cmp" +) + +func TestFirst(t *testing.T) { +	testCases := []struct { +		name  string +		slice []int +		first int +		exist bool +	}{ +		{ +			name:  "multiple items slice", +			slice: []int{1, 2, 3}, +			first: 1, +			exist: true, +		}, +		{ +			name:  "single item slice", +			slice: []int{1}, +			first: 1, +			exist: true, +		}, +		{ +			name:  "empty slice", +			slice: []int{}, +			first: 0, +			exist: false, +		}, +	} +	for _, tc := range testCases { +		t.Run(tc.name, func(t *testing.T) { + +			first, empty := First(tc.slice) + +			if first != tc.first { +				t.Errorf("Error first, want %d got %d", tc.first, first) +			} + +			if empty != tc.exist { +				t.Errorf("Error empty, want %t got %t", tc.exist, empty) +			} + +		}) +	} +} + +func TestSubList(t *testing.T) { +	testCases := []struct { +		name  string +		slice []int +		size  int +		want  [][]int +	}{ +		{ +			name:  "sigle size sub list", +			slice: []int{1, 2, 3}, +			size:  1, +			want:  [][]int{{1}, {2}, {3}}, +		}, +		{ +			name:  "multiple size sub list", +			slice: []int{1, 2, 3, 4}, +			size:  2, +			want:  [][]int{{1, 2}, {3, 4}}, +		}, +		{ +			name:  "uneven multiple size sub list", +			slice: []int{1, 2, 3, 4, 5}, +			size:  2, +			want:  [][]int{{1, 2}, {3, 4}, {5}}, +		}, +		{ +			name:  "empty sub list", +			slice: []int{}, +			size:  2, +			want:  [][]int{{}}, +		}, +	} +	for _, tc := range testCases { +		t.Run(tc.name, func(t *testing.T) { + +			subList := ChunkBy(tc.slice, tc.size) + +			if diff := cmp.Diff(tc.want, subList); diff != "" { +				t.Errorf("Wrong result given - wanted + got\n %s", diff) +			} +		}) +	} +} | 
