// Copyright 2019 Google Inc. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package java import ( "reflect" "testing" ) func Test_shardTests(t *testing.T) { type args struct { paths []string shards int } tests := []struct { name string args args want [][]string }{ { name: "empty", args: args{ paths: nil, shards: 1, }, want: [][]string(nil), }, { name: "too many shards", args: args{ paths: []string{"a", "b"}, shards: 3, }, want: [][]string{{"a"}, {"b"}}, }, { name: "single shard", args: args{ paths: []string{"a", "b"}, shards: 1, }, want: [][]string{{"a", "b"}}, }, { name: "shard per input", args: args{ paths: []string{"a", "b", "c"}, shards: 3, }, want: [][]string{{"a"}, {"b"}, {"c"}}, }, { name: "balanced shards", args: args{ paths: []string{"a", "b", "c", "d"}, shards: 2, }, want: [][]string{{"a", "b"}, {"c", "d"}}, }, { name: "unbalanced shards", args: args{ paths: []string{"a", "b", "c"}, shards: 2, }, want: [][]string{{"a", "b"}, {"c"}}, }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { if got := shardTests(tt.args.paths, tt.args.shards); !reflect.DeepEqual(got, tt.want) { t.Errorf("shardTests() = %v, want %v", got, tt.want) } }) } }