Move StrSlice to types.
This is a very docker concept that nobody elses need. We only maintain it to keep the API backwards compatible. Signed-off-by: David Calavera <david.calavera@gmail.com>
This commit is contained in:
		
							parent
							
								
									94d7adb3c4
								
							
						
					
					
						commit
						59feba7c2a
					
				
					 2 changed files with 0 additions and 206 deletions
				
			
		|  | @ -1,71 +0,0 @@ | ||||||
| package stringutils |  | ||||||
| 
 |  | ||||||
| import ( |  | ||||||
| 	"encoding/json" |  | ||||||
| 	"strings" |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| // StrSlice represents a string or an array of strings. |  | ||||||
| // We need to override the json decoder to accept both options. |  | ||||||
| type StrSlice struct { |  | ||||||
| 	parts []string |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // MarshalJSON Marshals (or serializes) the StrSlice into the json format. |  | ||||||
| // This method is needed to implement json.Marshaller. |  | ||||||
| func (e *StrSlice) MarshalJSON() ([]byte, error) { |  | ||||||
| 	if e == nil { |  | ||||||
| 		return []byte{}, nil |  | ||||||
| 	} |  | ||||||
| 	return json.Marshal(e.Slice()) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // UnmarshalJSON decodes the byte slice whether it's a string or an array of strings. |  | ||||||
| // This method is needed to implement json.Unmarshaler. |  | ||||||
| func (e *StrSlice) UnmarshalJSON(b []byte) error { |  | ||||||
| 	if len(b) == 0 { |  | ||||||
| 		return nil |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	p := make([]string, 0, 1) |  | ||||||
| 	if err := json.Unmarshal(b, &p); err != nil { |  | ||||||
| 		var s string |  | ||||||
| 		if err := json.Unmarshal(b, &s); err != nil { |  | ||||||
| 			return err |  | ||||||
| 		} |  | ||||||
| 		p = append(p, s) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	e.parts = p |  | ||||||
| 	return nil |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // Len returns the number of parts of the StrSlice. |  | ||||||
| func (e *StrSlice) Len() int { |  | ||||||
| 	if e == nil { |  | ||||||
| 		return 0 |  | ||||||
| 	} |  | ||||||
| 	return len(e.parts) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // Slice gets the parts of the StrSlice as a Slice of string. |  | ||||||
| func (e *StrSlice) Slice() []string { |  | ||||||
| 	if e == nil { |  | ||||||
| 		return nil |  | ||||||
| 	} |  | ||||||
| 	return e.parts |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // ToString gets space separated string of all the parts. |  | ||||||
| func (e *StrSlice) ToString() string { |  | ||||||
| 	s := e.Slice() |  | ||||||
| 	if s == nil { |  | ||||||
| 		return "" |  | ||||||
| 	} |  | ||||||
| 	return strings.Join(s, " ") |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // NewStrSlice creates an StrSlice based on the specified parts (as strings). |  | ||||||
| func NewStrSlice(parts ...string) *StrSlice { |  | ||||||
| 	return &StrSlice{parts} |  | ||||||
| } |  | ||||||
|  | @ -1,135 +0,0 @@ | ||||||
| package stringutils |  | ||||||
| 
 |  | ||||||
| import ( |  | ||||||
| 	"encoding/json" |  | ||||||
| 	"reflect" |  | ||||||
| 	"testing" |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| func TestStrSliceMarshalJSON(t *testing.T) { |  | ||||||
| 	strss := map[*StrSlice]string{ |  | ||||||
| 		nil:         "", |  | ||||||
| 		&StrSlice{}: "null", |  | ||||||
| 		&StrSlice{[]string{"/bin/sh", "-c", "echo"}}: `["/bin/sh","-c","echo"]`, |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	for strs, expected := range strss { |  | ||||||
| 		data, err := strs.MarshalJSON() |  | ||||||
| 		if err != nil { |  | ||||||
| 			t.Fatal(err) |  | ||||||
| 		} |  | ||||||
| 		if string(data) != expected { |  | ||||||
| 			t.Fatalf("Expected %v, got %v", expected, string(data)) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func TestStrSliceUnmarshalJSON(t *testing.T) { |  | ||||||
| 	parts := map[string][]string{ |  | ||||||
| 		"":   {"default", "values"}, |  | ||||||
| 		"[]": {}, |  | ||||||
| 		`["/bin/sh","-c","echo"]`: {"/bin/sh", "-c", "echo"}, |  | ||||||
| 	} |  | ||||||
| 	for json, expectedParts := range parts { |  | ||||||
| 		strs := &StrSlice{ |  | ||||||
| 			[]string{"default", "values"}, |  | ||||||
| 		} |  | ||||||
| 		if err := strs.UnmarshalJSON([]byte(json)); err != nil { |  | ||||||
| 			t.Fatal(err) |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		actualParts := strs.Slice() |  | ||||||
| 		if len(actualParts) != len(expectedParts) { |  | ||||||
| 			t.Fatalf("Expected %v parts, got %v (%v)", len(expectedParts), len(actualParts), expectedParts) |  | ||||||
| 		} |  | ||||||
| 		for index, part := range actualParts { |  | ||||||
| 			if part != expectedParts[index] { |  | ||||||
| 				t.Fatalf("Expected %v, got %v", expectedParts, actualParts) |  | ||||||
| 				break |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func TestStrSliceUnmarshalString(t *testing.T) { |  | ||||||
| 	var e *StrSlice |  | ||||||
| 	echo, err := json.Marshal("echo") |  | ||||||
| 	if err != nil { |  | ||||||
| 		t.Fatal(err) |  | ||||||
| 	} |  | ||||||
| 	if err := json.Unmarshal(echo, &e); err != nil { |  | ||||||
| 		t.Fatal(err) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	slice := e.Slice() |  | ||||||
| 	if len(slice) != 1 { |  | ||||||
| 		t.Fatalf("expected 1 element after unmarshal: %q", slice) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if slice[0] != "echo" { |  | ||||||
| 		t.Fatalf("expected `echo`, got: %q", slice[0]) |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func TestStrSliceUnmarshalSlice(t *testing.T) { |  | ||||||
| 	var e *StrSlice |  | ||||||
| 	echo, err := json.Marshal([]string{"echo"}) |  | ||||||
| 	if err != nil { |  | ||||||
| 		t.Fatal(err) |  | ||||||
| 	} |  | ||||||
| 	if err := json.Unmarshal(echo, &e); err != nil { |  | ||||||
| 		t.Fatal(err) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	slice := e.Slice() |  | ||||||
| 	if len(slice) != 1 { |  | ||||||
| 		t.Fatalf("expected 1 element after unmarshal: %q", slice) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if slice[0] != "echo" { |  | ||||||
| 		t.Fatalf("expected `echo`, got: %q", slice[0]) |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func TestStrSliceToString(t *testing.T) { |  | ||||||
| 	slices := map[*StrSlice]string{ |  | ||||||
| 		NewStrSlice(""):           "", |  | ||||||
| 		NewStrSlice("one"):        "one", |  | ||||||
| 		NewStrSlice("one", "two"): "one two", |  | ||||||
| 	} |  | ||||||
| 	for s, expected := range slices { |  | ||||||
| 		toString := s.ToString() |  | ||||||
| 		if toString != expected { |  | ||||||
| 			t.Fatalf("Expected %v, got %v", expected, toString) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func TestStrSliceLen(t *testing.T) { |  | ||||||
| 	var emptyStrSlice *StrSlice |  | ||||||
| 	slices := map[*StrSlice]int{ |  | ||||||
| 		NewStrSlice(""):           1, |  | ||||||
| 		NewStrSlice("one"):        1, |  | ||||||
| 		NewStrSlice("one", "two"): 2, |  | ||||||
| 		emptyStrSlice:             0, |  | ||||||
| 	} |  | ||||||
| 	for s, expected := range slices { |  | ||||||
| 		if s.Len() != expected { |  | ||||||
| 			t.Fatalf("Expected %d, got %d", s.Len(), expected) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func TestStrSliceSlice(t *testing.T) { |  | ||||||
| 	var emptyStrSlice *StrSlice |  | ||||||
| 	slices := map[*StrSlice][]string{ |  | ||||||
| 		NewStrSlice("one"):        {"one"}, |  | ||||||
| 		NewStrSlice("one", "two"): {"one", "two"}, |  | ||||||
| 		emptyStrSlice:             nil, |  | ||||||
| 	} |  | ||||||
| 	for s, expected := range slices { |  | ||||||
| 		if !reflect.DeepEqual(s.Slice(), expected) { |  | ||||||
| 			t.Fatalf("Expected %v, got %v", s.Slice(), expected) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue