2016-06-21 02:50:40 +02:00
|
|
|
// 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.*")
|
|
|
|
}
|
|
|
|
|
2016-07-12 01:03:02 +02:00
|
|
|
func (s *LoadSuite) TestLoadAll(c *C) {
|
|
|
|
filename := s.makeFile(c, "key=value")
|
|
|
|
filename2 := s.makeFile(c, "key2=value3")
|
|
|
|
filename3 := s.makeFile(c, "key=value4")
|
|
|
|
srv := testServer()
|
|
|
|
defer srv.Close()
|
|
|
|
p := MustLoadAll([]string{filename, filename2, srv.URL + "/a", srv.URL + "/b", filename3}, UTF8, false)
|
|
|
|
assertKeyValues(c, "", p, "key", "value4", "key2", "value2")
|
|
|
|
}
|
|
|
|
|
2016-06-21 02:50:40 +02:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
}
|