1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
| // Copyright 2017 The Go Authors. All rights reserved.
| // Use of this source code is governed by a BSD-style
| // license that can be found in the LICENSE file.
|
| package exec
|
| import (
| "reflect"
| "testing"
| )
|
| func TestDedupEnv(t *testing.T) {
| tests := []struct {
| noCase bool
| in []string
| want []string
| }{
| {
| noCase: true,
| in: []string{"k1=v1", "k2=v2", "K1=v3"},
| want: []string{"K1=v3", "k2=v2"},
| },
| {
| noCase: false,
| in: []string{"k1=v1", "K1=V2", "k1=v3"},
| want: []string{"k1=v3", "K1=V2"},
| },
| {
| in: []string{"=a", "=b", "foo", "bar"},
| want: []string{"=b", "foo", "bar"},
| },
| }
| for _, tt := range tests {
| got := dedupEnvCase(tt.noCase, tt.in)
| if !reflect.DeepEqual(got, tt.want) {
| t.Errorf("Dedup(%v, %q) = %q; want %q", tt.noCase, tt.in, got, tt.want)
| }
| }
| }
|
|