| // 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) 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") |
| } |
| |
| 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) |
| } |
| })) |
| } |