clair/vendor/github.com/magiconair/properties/load_test.go
2016-09-28 15:24:38 +02:00

205 lines
5.3 KiB
Go

// Copyright 2016 Frank Schroeder. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package properties
import (
"fmt"
"io/ioutil"
"net/http"
"net/http/httptest"
"os"
"strings"
. "github.com/magiconair/properties/_third_party/gopkg.in/check.v1"
)
type LoadSuite struct {
tempFiles []string
}
var _ = Suite(&LoadSuite{})
func (s *LoadSuite) TestLoadFailsWithNotExistingFile(c *C) {
_, err := LoadFile("doesnotexist.properties", ISO_8859_1)
c.Assert(err, NotNil)
c.Assert(err, ErrorMatches, "open.*no such file or directory")
}
func (s *LoadSuite) TestLoadFilesFailsOnNotExistingFile(c *C) {
_, err := LoadFiles([]string{"doesnotexist.properties"}, ISO_8859_1, false)
c.Assert(err, NotNil)
c.Assert(err, ErrorMatches, "open.*no such file or directory")
}
func (s *LoadSuite) TestLoadFilesDoesNotFailOnNotExistingFileAndIgnoreMissing(c *C) {
p, err := LoadFiles([]string{"doesnotexist.properties"}, ISO_8859_1, true)
c.Assert(err, IsNil)
c.Assert(p.Len(), Equals, 0)
}
func (s *LoadSuite) TestLoadString(c *C) {
x := "key=äüö"
p1 := MustLoadString(x)
p2 := must(Load([]byte(x), UTF8))
c.Assert(p1, DeepEquals, p2)
}
func (s *LoadSuite) TestLoadFile(c *C) {
filename := s.makeFile(c, "key=value")
p := MustLoadFile(filename, ISO_8859_1)
c.Assert(p.Len(), Equals, 1)
assertKeyValues(c, "", p, "key", "value")
}
func (s *LoadSuite) TestLoadFiles(c *C) {
filename := s.makeFile(c, "key=value")
filename2 := s.makeFile(c, "key2=value2")
p := MustLoadFiles([]string{filename, filename2}, ISO_8859_1, false)
assertKeyValues(c, "", p, "key", "value", "key2", "value2")
}
func (s *LoadSuite) TestLoadExpandedFile(c *C) {
filename := s.makeFilePrefix(c, os.Getenv("USER"), "key=value")
filename = strings.Replace(filename, os.Getenv("USER"), "${USER}", -1)
p := MustLoadFile(filename, ISO_8859_1)
assertKeyValues(c, "", p, "key", "value")
}
func (s *LoadSuite) TestLoadFilesAndIgnoreMissing(c *C) {
filename := s.makeFile(c, "key=value")
filename2 := s.makeFile(c, "key2=value2")
p := MustLoadFiles([]string{filename, filename + "foo", filename2, filename2 + "foo"}, ISO_8859_1, true)
assertKeyValues(c, "", p, "key", "value", "key2", "value2")
}
func (s *LoadSuite) TestLoadURL(c *C) {
srv := testServer()
defer srv.Close()
p := MustLoadURL(srv.URL + "/a")
assertKeyValues(c, "", p, "key", "value")
}
func (s *LoadSuite) TestLoadURLs(c *C) {
srv := testServer()
defer srv.Close()
p := MustLoadURLs([]string{srv.URL + "/a", srv.URL + "/b"}, false)
assertKeyValues(c, "", p, "key", "value", "key2", "value2")
}
func (s *LoadSuite) TestLoadURLsAndFailMissing(c *C) {
srv := testServer()
defer srv.Close()
p, err := LoadURLs([]string{srv.URL + "/a", srv.URL + "/c"}, false)
c.Assert(p, IsNil)
c.Assert(err, ErrorMatches, ".*returned 404.*")
}
func (s *LoadSuite) TestLoadURLsAndIgnoreMissing(c *C) {
srv := testServer()
defer srv.Close()
p := MustLoadURLs([]string{srv.URL + "/a", srv.URL + "/b", srv.URL + "/c"}, true)
assertKeyValues(c, "", p, "key", "value", "key2", "value2")
}
func (s *LoadSuite) TestLoadURLEncoding(c *C) {
srv := testServer()
defer srv.Close()
uris := []string{"/none", "/utf8", "/plain", "/latin1", "/iso88591"}
for i, uri := range uris {
p := MustLoadURL(srv.URL + uri)
c.Assert(p.GetString("key", ""), Equals, "äöü", Commentf("%d", i))
}
}
func (s *LoadSuite) TestLoadURLFailInvalidEncoding(c *C) {
srv := testServer()
defer srv.Close()
p, err := LoadURL(srv.URL + "/json")
c.Assert(p, IsNil)
c.Assert(err, ErrorMatches, ".*invalid content type.*")
}
func (s *LoadSuite) SetUpSuite(c *C) {
s.tempFiles = make([]string, 0)
}
func (s *LoadSuite) TearDownSuite(c *C) {
for _, path := range s.tempFiles {
err := os.Remove(path)
if err != nil {
fmt.Printf("os.Remove: %v", err)
}
}
}
func (s *LoadSuite) makeFile(c *C, data string) string {
return s.makeFilePrefix(c, "properties", data)
}
func (s *LoadSuite) makeFilePrefix(c *C, prefix, data string) string {
f, err := ioutil.TempFile("", prefix)
if err != nil {
fmt.Printf("ioutil.TempFile: %v", err)
c.FailNow()
}
// remember the temp file so that we can remove it later
s.tempFiles = append(s.tempFiles, f.Name())
n, err := fmt.Fprint(f, data)
if err != nil {
fmt.Printf("fmt.Fprintln: %v", err)
c.FailNow()
}
if n != len(data) {
fmt.Printf("Data size mismatch. expected=%d wrote=%d\n", len(data), n)
c.FailNow()
}
err = f.Close()
if err != nil {
fmt.Printf("f.Close: %v", err)
c.FailNow()
}
return f.Name()
}
func testServer() *httptest.Server {
return httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
send := func(data []byte, contentType string) {
w.Header().Set("Content-Type", contentType)
w.Write(data)
}
utf8 := []byte("key=äöü")
iso88591 := []byte{0x6b, 0x65, 0x79, 0x3d, 0xe4, 0xf6, 0xfc} // key=äöü
switch r.RequestURI {
case "/a":
send([]byte("key=value"), "")
case "/b":
send([]byte("key2=value2"), "")
case "/none":
send(utf8, "")
case "/utf8":
send(utf8, "text/plain; charset=utf-8")
case "/json":
send(utf8, "application/json; charset=utf-8")
case "/plain":
send(iso88591, "text/plain")
case "/latin1":
send(iso88591, "text/plain; charset=latin1")
case "/iso88591":
send(iso88591, "text/plain; charset=iso-8859-1")
default:
w.WriteHeader(404)
}
}))
}