mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-02 12:17:39 -06:00
6fe2703665
* Remove `make updatedeps` from Travis build. We'll follow up with more specific plans around dependency updating in subsequent PRs. * Update all `make` targets to set `GO15VENDOREXPERIMENT=1` and to filter out `/vendor/` from `./...` where appropriate. * Temporarily remove `vet` from the `make test` target until we can figure out how to get it to not vet `vendor/`. (Initial experimentation failed to yield the proper incantation.) Everything is pinned to current master, with the exception of: * Azure/azure-sdk-for-go which is pinned before the breaking change today * aws/aws-sdk-go which is pinned to the most recent tag The documentation still needs to be updated, which we can do in a follow up PR. The goal here is to unblock release.
575 lines
16 KiB
Go
575 lines
16 KiB
Go
// Copyright 2014 Unknwon
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License"): you may
|
|
// not use this file except in compliance with the License. You may obtain
|
|
// a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
// License for the specific language governing permissions and limitations
|
|
// under the License.
|
|
|
|
package ini
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"strings"
|
|
"testing"
|
|
"time"
|
|
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
)
|
|
|
|
func Test_Version(t *testing.T) {
|
|
Convey("Get version", t, func() {
|
|
So(Version(), ShouldEqual, _VERSION)
|
|
})
|
|
}
|
|
|
|
const _CONF_DATA = `
|
|
; Package name
|
|
NAME = ini
|
|
; Package version
|
|
VERSION = v1
|
|
; Package import path
|
|
IMPORT_PATH = gopkg.in/%(NAME)s.%(VERSION)s
|
|
|
|
# Information about package author
|
|
# Bio can be written in multiple lines.
|
|
[author]
|
|
NAME = Unknwon ; Succeeding comment
|
|
E-MAIL = fake@localhost
|
|
GITHUB = https://github.com/%(NAME)s
|
|
BIO = """Gopher.
|
|
Coding addict.
|
|
Good man.
|
|
""" # Succeeding comment
|
|
|
|
[package]
|
|
CLONE_URL = https://%(IMPORT_PATH)s
|
|
|
|
[package.sub]
|
|
UNUSED_KEY = should be deleted
|
|
|
|
[features]
|
|
-: Support read/write comments of keys and sections
|
|
-: Support auto-increment of key names
|
|
-: Support load multiple files to overwrite key values
|
|
|
|
[types]
|
|
STRING = str
|
|
BOOL = true
|
|
BOOL_FALSE = false
|
|
FLOAT64 = 1.25
|
|
INT = 10
|
|
TIME = 2015-01-01T20:17:05Z
|
|
DURATION = 2h45m
|
|
UINT = 3
|
|
|
|
[array]
|
|
STRINGS = en, zh, de
|
|
FLOAT64S = 1.1, 2.2, 3.3
|
|
INTS = 1, 2, 3
|
|
UINTS = 1, 2, 3
|
|
TIMES = 2015-01-01T20:17:05Z,2015-01-01T20:17:05Z,2015-01-01T20:17:05Z
|
|
|
|
[note]
|
|
empty_lines = next line is empty\
|
|
|
|
; Comment before the section
|
|
[comments] ; This is a comment for the section too
|
|
; Comment before key
|
|
key = "value"
|
|
key2 = "value2" ; This is a comment for key2
|
|
key3 = "one", "two", "three"
|
|
|
|
[advance]
|
|
value with quotes = "some value"
|
|
value quote2 again = 'some value'
|
|
true = 2+3=5
|
|
"1+1=2" = true
|
|
"""6+1=7""" = true
|
|
"""` + "`" + `5+5` + "`" + `""" = 10
|
|
` + "`" + `"6+6"` + "`" + ` = 12
|
|
` + "`" + `7-2=4` + "`" + ` = false
|
|
ADDRESS = ` + "`" + `404 road,
|
|
NotFound, State, 50000` + "`" + `
|
|
|
|
two_lines = how about \
|
|
continuation lines?
|
|
lots_of_lines = 1 \
|
|
2 \
|
|
3 \
|
|
4 \
|
|
`
|
|
|
|
func Test_Load(t *testing.T) {
|
|
Convey("Load from data sources", t, func() {
|
|
|
|
Convey("Load with empty data", func() {
|
|
So(Empty(), ShouldNotBeNil)
|
|
})
|
|
|
|
Convey("Load with multiple data sources", func() {
|
|
cfg, err := Load([]byte(_CONF_DATA), "testdata/conf.ini")
|
|
So(err, ShouldBeNil)
|
|
So(cfg, ShouldNotBeNil)
|
|
})
|
|
})
|
|
|
|
Convey("Bad load process", t, func() {
|
|
|
|
Convey("Load from invalid data sources", func() {
|
|
_, err := Load(_CONF_DATA)
|
|
So(err, ShouldNotBeNil)
|
|
|
|
f, err := Load("testdata/404.ini")
|
|
So(err, ShouldNotBeNil)
|
|
So(f, ShouldBeNil)
|
|
|
|
_, err = Load(1)
|
|
So(err, ShouldNotBeNil)
|
|
|
|
_, err = Load([]byte(""), 1)
|
|
So(err, ShouldNotBeNil)
|
|
})
|
|
|
|
Convey("Load with bad section name", func() {
|
|
_, err := Load([]byte("[]"))
|
|
So(err, ShouldNotBeNil)
|
|
|
|
_, err = Load([]byte("["))
|
|
So(err, ShouldNotBeNil)
|
|
})
|
|
|
|
Convey("Load with bad keys", func() {
|
|
_, err := Load([]byte(`"""name`))
|
|
So(err, ShouldNotBeNil)
|
|
|
|
_, err = Load([]byte(`"""name"""`))
|
|
So(err, ShouldNotBeNil)
|
|
|
|
_, err = Load([]byte(`""=1`))
|
|
So(err, ShouldNotBeNil)
|
|
|
|
_, err = Load([]byte(`=`))
|
|
So(err, ShouldNotBeNil)
|
|
|
|
_, err = Load([]byte(`name`))
|
|
So(err, ShouldNotBeNil)
|
|
})
|
|
|
|
Convey("Load with bad values", func() {
|
|
_, err := Load([]byte(`name="""Unknwon`))
|
|
So(err, ShouldNotBeNil)
|
|
})
|
|
})
|
|
}
|
|
|
|
func Test_Values(t *testing.T) {
|
|
Convey("Test getting and setting values", t, func() {
|
|
cfg, err := Load([]byte(_CONF_DATA), "testdata/conf.ini")
|
|
So(err, ShouldBeNil)
|
|
So(cfg, ShouldNotBeNil)
|
|
|
|
Convey("Get values in default section", func() {
|
|
sec := cfg.Section("")
|
|
So(sec, ShouldNotBeNil)
|
|
So(sec.Key("NAME").Value(), ShouldEqual, "ini")
|
|
So(sec.Key("NAME").String(), ShouldEqual, "ini")
|
|
So(sec.Key("NAME").Validate(func(in string) string {
|
|
return in
|
|
}), ShouldEqual, "ini")
|
|
So(sec.Key("NAME").Comment, ShouldEqual, "; Package name")
|
|
So(sec.Key("IMPORT_PATH").String(), ShouldEqual, "gopkg.in/ini.v1")
|
|
})
|
|
|
|
Convey("Get values in non-default section", func() {
|
|
sec := cfg.Section("author")
|
|
So(sec, ShouldNotBeNil)
|
|
So(sec.Key("NAME").String(), ShouldEqual, "Unknwon")
|
|
So(sec.Key("GITHUB").String(), ShouldEqual, "https://github.com/Unknwon")
|
|
|
|
sec = cfg.Section("package")
|
|
So(sec, ShouldNotBeNil)
|
|
So(sec.Key("CLONE_URL").String(), ShouldEqual, "https://gopkg.in/ini.v1")
|
|
})
|
|
|
|
Convey("Get auto-increment key names", func() {
|
|
keys := cfg.Section("features").Keys()
|
|
for i, k := range keys {
|
|
So(k.Name(), ShouldEqual, fmt.Sprintf("#%d", i+1))
|
|
}
|
|
})
|
|
|
|
Convey("Get overwrite value", func() {
|
|
So(cfg.Section("author").Key("E-MAIL").String(), ShouldEqual, "u@gogs.io")
|
|
})
|
|
|
|
Convey("Get sections", func() {
|
|
sections := cfg.Sections()
|
|
for i, name := range []string{DEFAULT_SECTION, "author", "package", "package.sub", "features", "types", "array", "note", "comments", "advance"} {
|
|
So(sections[i].Name(), ShouldEqual, name)
|
|
}
|
|
})
|
|
|
|
Convey("Get parent section value", func() {
|
|
So(cfg.Section("package.sub").Key("CLONE_URL").String(), ShouldEqual, "https://gopkg.in/ini.v1")
|
|
So(cfg.Section("package.fake.sub").Key("CLONE_URL").String(), ShouldEqual, "https://gopkg.in/ini.v1")
|
|
})
|
|
|
|
Convey("Get multiple line value", func() {
|
|
So(cfg.Section("author").Key("BIO").String(), ShouldEqual, "Gopher.\nCoding addict.\nGood man.\n")
|
|
})
|
|
|
|
Convey("Get values with type", func() {
|
|
sec := cfg.Section("types")
|
|
v1, err := sec.Key("BOOL").Bool()
|
|
So(err, ShouldBeNil)
|
|
So(v1, ShouldBeTrue)
|
|
|
|
v1, err = sec.Key("BOOL_FALSE").Bool()
|
|
So(err, ShouldBeNil)
|
|
So(v1, ShouldBeFalse)
|
|
|
|
v2, err := sec.Key("FLOAT64").Float64()
|
|
So(err, ShouldBeNil)
|
|
So(v2, ShouldEqual, 1.25)
|
|
|
|
v3, err := sec.Key("INT").Int()
|
|
So(err, ShouldBeNil)
|
|
So(v3, ShouldEqual, 10)
|
|
|
|
v4, err := sec.Key("INT").Int64()
|
|
So(err, ShouldBeNil)
|
|
So(v4, ShouldEqual, 10)
|
|
|
|
v5, err := sec.Key("UINT").Uint()
|
|
So(err, ShouldBeNil)
|
|
So(v5, ShouldEqual, 3)
|
|
|
|
v6, err := sec.Key("UINT").Uint64()
|
|
So(err, ShouldBeNil)
|
|
So(v6, ShouldEqual, 3)
|
|
|
|
t, err := time.Parse(time.RFC3339, "2015-01-01T20:17:05Z")
|
|
So(err, ShouldBeNil)
|
|
v7, err := sec.Key("TIME").Time()
|
|
So(err, ShouldBeNil)
|
|
So(v7.String(), ShouldEqual, t.String())
|
|
|
|
Convey("Must get values with type", func() {
|
|
So(sec.Key("STRING").MustString("404"), ShouldEqual, "str")
|
|
So(sec.Key("BOOL").MustBool(), ShouldBeTrue)
|
|
So(sec.Key("FLOAT64").MustFloat64(), ShouldEqual, 1.25)
|
|
So(sec.Key("INT").MustInt(), ShouldEqual, 10)
|
|
So(sec.Key("INT").MustInt64(), ShouldEqual, 10)
|
|
So(sec.Key("UINT").MustUint(), ShouldEqual, 3)
|
|
So(sec.Key("UINT").MustUint64(), ShouldEqual, 3)
|
|
So(sec.Key("TIME").MustTime().String(), ShouldEqual, t.String())
|
|
|
|
dur, err := time.ParseDuration("2h45m")
|
|
So(err, ShouldBeNil)
|
|
So(sec.Key("DURATION").MustDuration().Seconds(), ShouldEqual, dur.Seconds())
|
|
|
|
Convey("Must get values with default value", func() {
|
|
So(sec.Key("STRING_404").MustString("404"), ShouldEqual, "404")
|
|
So(sec.Key("BOOL_404").MustBool(true), ShouldBeTrue)
|
|
So(sec.Key("FLOAT64_404").MustFloat64(2.5), ShouldEqual, 2.5)
|
|
So(sec.Key("INT_404").MustInt(15), ShouldEqual, 15)
|
|
So(sec.Key("INT_404").MustInt64(15), ShouldEqual, 15)
|
|
So(sec.Key("UINT_404").MustUint(6), ShouldEqual, 6)
|
|
So(sec.Key("UINT_404").MustUint64(6), ShouldEqual, 6)
|
|
|
|
t, err := time.Parse(time.RFC3339, "2014-01-01T20:17:05Z")
|
|
So(err, ShouldBeNil)
|
|
So(sec.Key("TIME_404").MustTime(t).String(), ShouldEqual, t.String())
|
|
|
|
So(sec.Key("DURATION_404").MustDuration(dur).Seconds(), ShouldEqual, dur.Seconds())
|
|
})
|
|
})
|
|
})
|
|
|
|
Convey("Get value with candidates", func() {
|
|
sec := cfg.Section("types")
|
|
So(sec.Key("STRING").In("", []string{"str", "arr", "types"}), ShouldEqual, "str")
|
|
So(sec.Key("FLOAT64").InFloat64(0, []float64{1.25, 2.5, 3.75}), ShouldEqual, 1.25)
|
|
So(sec.Key("INT").InInt(0, []int{10, 20, 30}), ShouldEqual, 10)
|
|
So(sec.Key("INT").InInt64(0, []int64{10, 20, 30}), ShouldEqual, 10)
|
|
So(sec.Key("UINT").InUint(0, []uint{3, 6, 9}), ShouldEqual, 3)
|
|
So(sec.Key("UINT").InUint64(0, []uint64{3, 6, 9}), ShouldEqual, 3)
|
|
|
|
zt, err := time.Parse(time.RFC3339, "0001-01-01T01:00:00Z")
|
|
So(err, ShouldBeNil)
|
|
t, err := time.Parse(time.RFC3339, "2015-01-01T20:17:05Z")
|
|
So(err, ShouldBeNil)
|
|
So(sec.Key("TIME").InTime(zt, []time.Time{t, time.Now(), time.Now().Add(1 * time.Second)}).String(), ShouldEqual, t.String())
|
|
|
|
Convey("Get value with candidates and default value", func() {
|
|
So(sec.Key("STRING_404").In("str", []string{"str", "arr", "types"}), ShouldEqual, "str")
|
|
So(sec.Key("FLOAT64_404").InFloat64(1.25, []float64{1.25, 2.5, 3.75}), ShouldEqual, 1.25)
|
|
So(sec.Key("INT_404").InInt(10, []int{10, 20, 30}), ShouldEqual, 10)
|
|
So(sec.Key("INT64_404").InInt64(10, []int64{10, 20, 30}), ShouldEqual, 10)
|
|
So(sec.Key("UINT_404").InUint(3, []uint{3, 6, 9}), ShouldEqual, 3)
|
|
So(sec.Key("UINT_404").InUint64(3, []uint64{3, 6, 9}), ShouldEqual, 3)
|
|
So(sec.Key("TIME_404").InTime(t, []time.Time{time.Now(), time.Now(), time.Now().Add(1 * time.Second)}).String(), ShouldEqual, t.String())
|
|
})
|
|
})
|
|
|
|
Convey("Get values in range", func() {
|
|
sec := cfg.Section("types")
|
|
So(sec.Key("FLOAT64").RangeFloat64(0, 1, 2), ShouldEqual, 1.25)
|
|
So(sec.Key("INT").RangeInt(0, 10, 20), ShouldEqual, 10)
|
|
So(sec.Key("INT").RangeInt64(0, 10, 20), ShouldEqual, 10)
|
|
|
|
minT, err := time.Parse(time.RFC3339, "0001-01-01T01:00:00Z")
|
|
So(err, ShouldBeNil)
|
|
midT, err := time.Parse(time.RFC3339, "2013-01-01T01:00:00Z")
|
|
So(err, ShouldBeNil)
|
|
maxT, err := time.Parse(time.RFC3339, "9999-01-01T01:00:00Z")
|
|
So(err, ShouldBeNil)
|
|
t, err := time.Parse(time.RFC3339, "2015-01-01T20:17:05Z")
|
|
So(err, ShouldBeNil)
|
|
So(sec.Key("TIME").RangeTime(t, minT, maxT).String(), ShouldEqual, t.String())
|
|
|
|
Convey("Get value in range with default value", func() {
|
|
So(sec.Key("FLOAT64").RangeFloat64(5, 0, 1), ShouldEqual, 5)
|
|
So(sec.Key("INT").RangeInt(7, 0, 5), ShouldEqual, 7)
|
|
So(sec.Key("INT").RangeInt64(7, 0, 5), ShouldEqual, 7)
|
|
So(sec.Key("TIME").RangeTime(t, minT, midT).String(), ShouldEqual, t.String())
|
|
})
|
|
})
|
|
|
|
Convey("Get values into slice", func() {
|
|
sec := cfg.Section("array")
|
|
So(strings.Join(sec.Key("STRINGS").Strings(","), ","), ShouldEqual, "en,zh,de")
|
|
So(len(sec.Key("STRINGS_404").Strings(",")), ShouldEqual, 0)
|
|
|
|
vals1 := sec.Key("FLOAT64S").Float64s(",")
|
|
for i, v := range []float64{1.1, 2.2, 3.3} {
|
|
So(vals1[i], ShouldEqual, v)
|
|
}
|
|
|
|
vals2 := sec.Key("INTS").Ints(",")
|
|
for i, v := range []int{1, 2, 3} {
|
|
So(vals2[i], ShouldEqual, v)
|
|
}
|
|
|
|
vals3 := sec.Key("INTS").Int64s(",")
|
|
for i, v := range []int64{1, 2, 3} {
|
|
So(vals3[i], ShouldEqual, v)
|
|
}
|
|
|
|
vals4 := sec.Key("UINTS").Uints(",")
|
|
for i, v := range []uint{1, 2, 3} {
|
|
So(vals4[i], ShouldEqual, v)
|
|
}
|
|
|
|
vals5 := sec.Key("UINTS").Uint64s(",")
|
|
for i, v := range []uint64{1, 2, 3} {
|
|
So(vals5[i], ShouldEqual, v)
|
|
}
|
|
|
|
t, err := time.Parse(time.RFC3339, "2015-01-01T20:17:05Z")
|
|
So(err, ShouldBeNil)
|
|
vals6 := sec.Key("TIMES").Times(",")
|
|
for i, v := range []time.Time{t, t, t} {
|
|
So(vals6[i].String(), ShouldEqual, v.String())
|
|
}
|
|
})
|
|
|
|
Convey("Get key hash", func() {
|
|
cfg.Section("").KeysHash()
|
|
})
|
|
|
|
Convey("Set key value", func() {
|
|
k := cfg.Section("author").Key("NAME")
|
|
k.SetValue("无闻")
|
|
So(k.String(), ShouldEqual, "无闻")
|
|
})
|
|
|
|
Convey("Get key strings", func() {
|
|
So(strings.Join(cfg.Section("types").KeyStrings(), ","), ShouldEqual, "STRING,BOOL,BOOL_FALSE,FLOAT64,INT,TIME,DURATION,UINT")
|
|
})
|
|
|
|
Convey("Delete a key", func() {
|
|
cfg.Section("package.sub").DeleteKey("UNUSED_KEY")
|
|
_, err := cfg.Section("package.sub").GetKey("UNUSED_KEY")
|
|
So(err, ShouldNotBeNil)
|
|
})
|
|
|
|
Convey("Has Key (backwards compatible)", func() {
|
|
sec := cfg.Section("package.sub")
|
|
haskey1 := sec.Haskey("UNUSED_KEY")
|
|
haskey2 := sec.Haskey("CLONE_URL")
|
|
haskey3 := sec.Haskey("CLONE_URL_NO")
|
|
So(haskey1, ShouldBeTrue)
|
|
So(haskey2, ShouldBeTrue)
|
|
So(haskey3, ShouldBeFalse)
|
|
})
|
|
|
|
Convey("Has Key", func() {
|
|
sec := cfg.Section("package.sub")
|
|
haskey1 := sec.HasKey("UNUSED_KEY")
|
|
haskey2 := sec.HasKey("CLONE_URL")
|
|
haskey3 := sec.HasKey("CLONE_URL_NO")
|
|
So(haskey1, ShouldBeTrue)
|
|
So(haskey2, ShouldBeTrue)
|
|
So(haskey3, ShouldBeFalse)
|
|
})
|
|
|
|
Convey("Has Value", func() {
|
|
sec := cfg.Section("author")
|
|
hasvalue1 := sec.HasValue("Unknwon")
|
|
hasvalue2 := sec.HasValue("doc")
|
|
So(hasvalue1, ShouldBeTrue)
|
|
So(hasvalue2, ShouldBeFalse)
|
|
})
|
|
|
|
Convey("Get section strings", func() {
|
|
So(strings.Join(cfg.SectionStrings(), ","), ShouldEqual, "DEFAULT,author,package,package.sub,features,types,array,note,comments,advance")
|
|
})
|
|
|
|
Convey("Delete a section", func() {
|
|
cfg.DeleteSection("")
|
|
So(cfg.SectionStrings()[0], ShouldNotEqual, DEFAULT_SECTION)
|
|
})
|
|
|
|
Convey("Create new sections", func() {
|
|
cfg.NewSections("test", "test2")
|
|
_, err := cfg.GetSection("test")
|
|
So(err, ShouldBeNil)
|
|
_, err = cfg.GetSection("test2")
|
|
So(err, ShouldBeNil)
|
|
})
|
|
})
|
|
|
|
Convey("Test getting and setting bad values", t, func() {
|
|
cfg, err := Load([]byte(_CONF_DATA), "testdata/conf.ini")
|
|
So(err, ShouldBeNil)
|
|
So(cfg, ShouldNotBeNil)
|
|
|
|
Convey("Create new key with empty name", func() {
|
|
k, err := cfg.Section("").NewKey("", "")
|
|
So(err, ShouldNotBeNil)
|
|
So(k, ShouldBeNil)
|
|
})
|
|
|
|
Convey("Create new section with empty name", func() {
|
|
s, err := cfg.NewSection("")
|
|
So(err, ShouldNotBeNil)
|
|
So(s, ShouldBeNil)
|
|
})
|
|
|
|
Convey("Create new sections with empty name", func() {
|
|
So(cfg.NewSections(""), ShouldNotBeNil)
|
|
})
|
|
|
|
Convey("Get section that not exists", func() {
|
|
s, err := cfg.GetSection("404")
|
|
So(err, ShouldNotBeNil)
|
|
So(s, ShouldBeNil)
|
|
|
|
s = cfg.Section("404")
|
|
So(s, ShouldNotBeNil)
|
|
})
|
|
})
|
|
|
|
Convey("Test key hash clone", t, func() {
|
|
cfg, err := Load([]byte(strings.Replace("network=tcp,addr=127.0.0.1:6379,db=4,pool_size=100,idle_timeout=180", ",", "\n", -1)))
|
|
So(err, ShouldBeNil)
|
|
for _, v := range cfg.Section("").KeysHash() {
|
|
So(len(v), ShouldBeGreaterThan, 0)
|
|
}
|
|
})
|
|
|
|
Convey("Key has empty value", t, func() {
|
|
_conf := `key1=
|
|
key2= ; comment`
|
|
cfg, err := Load([]byte(_conf))
|
|
So(err, ShouldBeNil)
|
|
So(cfg.Section("").Key("key1").Value(), ShouldBeEmpty)
|
|
})
|
|
}
|
|
|
|
func Test_File_Append(t *testing.T) {
|
|
Convey("Append data sources", t, func() {
|
|
cfg, err := Load([]byte(""))
|
|
So(err, ShouldBeNil)
|
|
So(cfg, ShouldNotBeNil)
|
|
|
|
So(cfg.Append([]byte(""), []byte("")), ShouldBeNil)
|
|
|
|
Convey("Append bad data sources", func() {
|
|
So(cfg.Append(1), ShouldNotBeNil)
|
|
So(cfg.Append([]byte(""), 1), ShouldNotBeNil)
|
|
})
|
|
})
|
|
}
|
|
|
|
func Test_File_WriteTo(t *testing.T) {
|
|
Convey("Write to somewhere", t, func() {
|
|
var buf bytes.Buffer
|
|
cfg := Empty()
|
|
cfg.WriteTo(&buf)
|
|
})
|
|
}
|
|
|
|
func Test_File_SaveTo(t *testing.T) {
|
|
Convey("Save file", t, func() {
|
|
cfg, err := Load([]byte(_CONF_DATA), "testdata/conf.ini")
|
|
So(err, ShouldBeNil)
|
|
So(cfg, ShouldNotBeNil)
|
|
|
|
cfg.Section("").Key("NAME").Comment = "Package name"
|
|
cfg.Section("author").Comment = `Information about package author
|
|
# Bio can be written in multiple lines.`
|
|
cfg.Section("advanced").Key("val w/ pound").SetValue("my#password")
|
|
So(cfg.SaveTo("testdata/conf_out.ini"), ShouldBeNil)
|
|
|
|
cfg.Section("author").Key("NAME").Comment = "This is author name"
|
|
So(cfg.SaveToIndent("testdata/conf_out.ini", "\t"), ShouldBeNil)
|
|
})
|
|
}
|
|
|
|
func Benchmark_Key_Value(b *testing.B) {
|
|
c, _ := Load([]byte(_CONF_DATA))
|
|
for i := 0; i < b.N; i++ {
|
|
c.Section("").Key("NAME").Value()
|
|
}
|
|
}
|
|
|
|
func Benchmark_Key_String(b *testing.B) {
|
|
c, _ := Load([]byte(_CONF_DATA))
|
|
for i := 0; i < b.N; i++ {
|
|
c.Section("").Key("NAME").String()
|
|
}
|
|
}
|
|
|
|
func Benchmark_Key_Value_NonBlock(b *testing.B) {
|
|
c, _ := Load([]byte(_CONF_DATA))
|
|
c.BlockMode = false
|
|
for i := 0; i < b.N; i++ {
|
|
c.Section("").Key("NAME").Value()
|
|
}
|
|
}
|
|
|
|
func Benchmark_Key_String_NonBlock(b *testing.B) {
|
|
c, _ := Load([]byte(_CONF_DATA))
|
|
c.BlockMode = false
|
|
for i := 0; i < b.N; i++ {
|
|
c.Section("").Key("NAME").String()
|
|
}
|
|
}
|
|
|
|
func Benchmark_Key_SetValue(b *testing.B) {
|
|
c, _ := Load([]byte(_CONF_DATA))
|
|
for i := 0; i < b.N; i++ {
|
|
c.Section("").Key("NAME").SetValue("10")
|
|
}
|
|
}
|