mirror of https://github.com/rocboss/paopao-ce
Merge pull request #195 from rocboss/jc/alimy
use github.com/alimy/cfg as features configure help librarypull/198/head
commit
a0e13e2167
@ -1,41 +0,0 @@
|
||||
package cfg
|
||||
|
||||
var (
|
||||
_features = newEmptyFeatures()
|
||||
|
||||
// Use alias of Features.Use func
|
||||
Use = _features.Use
|
||||
|
||||
// UseDeafult alias of Features.UseDefault func
|
||||
UseDefault = _features.UseDefault
|
||||
|
||||
// As alias of Features.Cfg func
|
||||
As = _features.Cfg
|
||||
|
||||
// If alias of Features.CfgIf func
|
||||
If = _features.CfgIf
|
||||
|
||||
// In alias of Features.CfgIn func
|
||||
In = _features.CfgIn
|
||||
|
||||
// Be alias of Feaures.CfgBe func
|
||||
Be = _features.CfgBe
|
||||
|
||||
// Not alias of Features.CfgNot func
|
||||
Not = _features.CfgNot
|
||||
)
|
||||
|
||||
// Initialize initialize features in cfg pkg
|
||||
func Initialize(suites map[string][]string, kv map[string]string) {
|
||||
_features = NewFeatures(suites, kv)
|
||||
{
|
||||
// must re-assign variable below
|
||||
Use = _features.Use
|
||||
UseDefault = _features.UseDefault
|
||||
As = _features.Cfg
|
||||
If = _features.CfgIf
|
||||
In = _features.CfgIn
|
||||
Be = _features.CfgBe
|
||||
Not = _features.CfgNot
|
||||
}
|
||||
}
|
@ -1,78 +0,0 @@
|
||||
package cfg
|
||||
|
||||
import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestCfg(t *testing.T) {
|
||||
suites := map[string][]string{
|
||||
"default": {"Sms", "Alipay", "Zinc", "MySQL", "Redis", "AliOSS", "LogZinc"},
|
||||
"develop": {"Zinc", "MySQL", "AliOSS", "LogFile"},
|
||||
"slim": {"Zinc", "MySQL", "Redis", "AliOSS", "LogFile"},
|
||||
}
|
||||
kv := map[string]string{
|
||||
"sms": "SmsJuhe",
|
||||
}
|
||||
|
||||
Initialize(suites, kv)
|
||||
UseDefault()
|
||||
|
||||
if !If("Sms") {
|
||||
t.Error(`want If("Sms") == true but not`)
|
||||
}
|
||||
|
||||
if v, exist := As("Sms"); exist && v != "SmsJuhe" {
|
||||
t.Errorf(`want As("Sms") == "SmsJuhe", true but got: "%s", "%t"`, v, exist)
|
||||
}
|
||||
|
||||
matched := false
|
||||
Be("Alipay", func() {
|
||||
matched = true
|
||||
})
|
||||
if !matched {
|
||||
t.Error(`want Be("Alipay", ...) matched but not`)
|
||||
}
|
||||
|
||||
matched = false
|
||||
Not("LogFile", func() {
|
||||
matched = true
|
||||
})
|
||||
if !matched {
|
||||
t.Error(`want Not("LogFile", ...) matched but not`)
|
||||
}
|
||||
|
||||
var m1, m2, m3, m4 bool
|
||||
In(Actions{
|
||||
"Sms": func() {
|
||||
m1 = true
|
||||
},
|
||||
"Alipay": func() {
|
||||
m2 = true
|
||||
},
|
||||
"Meili": func() {
|
||||
m4 = true
|
||||
},
|
||||
}, func() {
|
||||
m3 = true
|
||||
})
|
||||
if !m1 || !m2 || m3 || m4 {
|
||||
t.Errorf(`In("Sms", "Alipay", "Meili", ...) not correct -> m1: %t m2:%t m3:%t m4:%t`, m1, m2, m3, m4)
|
||||
}
|
||||
|
||||
m1 = false
|
||||
m2 = false
|
||||
m3 = false
|
||||
In(Actions{
|
||||
"LogFile": func() {
|
||||
m1 = true
|
||||
},
|
||||
"Meili": func() {
|
||||
m2 = true
|
||||
},
|
||||
}, func() {
|
||||
m3 = true
|
||||
})
|
||||
if m1 || m2 || !m3 {
|
||||
t.Errorf(`In("Zinc", "MySQL", ...) not correct -> m1: %t m2:%t m3:%t`, m1, m2, m3)
|
||||
}
|
||||
}
|
@ -1,149 +0,0 @@
|
||||
package cfg
|
||||
|
||||
import (
|
||||
"strings"
|
||||
|
||||
"github.com/rocboss/paopao-ce/pkg/types"
|
||||
)
|
||||
|
||||
// Features fetures info struct
|
||||
type Features struct {
|
||||
kv map[string]string
|
||||
suites map[string][]string
|
||||
features map[string]string
|
||||
}
|
||||
|
||||
// Actions feature-func map alias type
|
||||
type Actions map[string]types.Fn
|
||||
|
||||
// NewFeatures create new Features instance
|
||||
func NewFeatures(suites map[string][]string, kv map[string]string) *Features {
|
||||
f := newEmptyFeatures()
|
||||
for k, v := range suites {
|
||||
if len(k) > 0 {
|
||||
for i := 0; i < len(v); i++ {
|
||||
// ignore empty string
|
||||
if len(v[i]) == 0 {
|
||||
lastIdx := len(v) - 1
|
||||
v[i] = v[lastIdx]
|
||||
v = v[:lastIdx]
|
||||
i--
|
||||
}
|
||||
}
|
||||
if len(v) > 0 {
|
||||
f.suites[k] = v
|
||||
}
|
||||
}
|
||||
}
|
||||
for k, v := range kv {
|
||||
if len(k) > 0 && len(v) > 0 {
|
||||
f.kv[k] = v
|
||||
}
|
||||
}
|
||||
f.UseDefault()
|
||||
return f
|
||||
}
|
||||
|
||||
func newEmptyFeatures() *Features {
|
||||
return &Features{
|
||||
suites: make(map[string][]string),
|
||||
kv: make(map[string]string),
|
||||
features: make(map[string]string),
|
||||
}
|
||||
}
|
||||
|
||||
// UseDefault use default suite for features
|
||||
func (f *Features) UseDefault() {
|
||||
f.Use([]string{"default"}, true)
|
||||
}
|
||||
|
||||
// Use use custom suite for features
|
||||
func (f *Features) Use(suite []string, noDefault bool) {
|
||||
if noDefault && len(f.features) != 0 {
|
||||
f.features = make(map[string]string)
|
||||
}
|
||||
features := f.flatFeatures(suite)
|
||||
for _, feature := range features {
|
||||
if len(feature) == 0 {
|
||||
continue
|
||||
}
|
||||
f.features[feature] = f.kv[feature]
|
||||
}
|
||||
}
|
||||
|
||||
func (f *Features) flatFeatures(suite []string) []string {
|
||||
features := make([]string, 0, len(suite)+10)
|
||||
for s := suite[:]; len(s) > 0; s = s[:len(s)-1] {
|
||||
item := strings.TrimSpace(strings.ToLower(s[0]))
|
||||
if len(item) > 0 {
|
||||
if items, exist := f.suites[item]; exist {
|
||||
s = append(s, items...)
|
||||
}
|
||||
features = append(features, item)
|
||||
}
|
||||
s[0] = s[len(s)-1]
|
||||
}
|
||||
return features
|
||||
}
|
||||
|
||||
// Cfg get value by key if exist
|
||||
func (f *Features) Cfg(key string) (string, bool) {
|
||||
key = strings.ToLower(key)
|
||||
value, exist := f.features[key]
|
||||
return value, exist
|
||||
}
|
||||
|
||||
// CfgIf check expression is true. if expression just have a string like
|
||||
// `Sms` is mean `Sms` whether define in suite feature settings. expression like
|
||||
// `Sms = SmsJuhe` is mean whether `Sms` define in suite feature settings and value
|
||||
// is `SmsJuhe`
|
||||
func (f *Features) CfgIf(expression string) bool {
|
||||
kv := strings.Split(expression, "=")
|
||||
key := strings.Trim(strings.ToLower(kv[0]), " ")
|
||||
v, ok := f.features[key]
|
||||
if len(kv) == 2 && ok && strings.Trim(kv[1], " ") == v {
|
||||
return true
|
||||
} else if len(kv) == 1 && ok {
|
||||
return true
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
||||
// CfgIn range actions to check item's expression is true then do the handle, defFn will handle
|
||||
// if all items are not matched,
|
||||
func (f *Features) CfgIn(actions Actions, defAct ...types.Fn) {
|
||||
itemMatched := false
|
||||
for expression, handle := range actions {
|
||||
if f.CfgIf(expression) && handle != nil {
|
||||
handle()
|
||||
itemMatched = true
|
||||
}
|
||||
}
|
||||
if !itemMatched && len(defAct) > 0 {
|
||||
for _, handle := range defAct {
|
||||
if handle != nil {
|
||||
handle()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// CfgBe check expression is true then do the handle. if expression just have a string like
|
||||
// `Sms` is mean `Sms` whether defined in suite feature settings. expression like
|
||||
// `Sms = SmsJuhe` is mean whether `Sms` define in suite feature settings and value
|
||||
// is `SmsJuhe`
|
||||
func (f *Features) CfgBe(expression string, handle types.Fn) {
|
||||
if f.CfgIf(expression) && handle != nil {
|
||||
handle()
|
||||
}
|
||||
}
|
||||
|
||||
// CfgNot check expression is not true then do the handle. if expression just have a string like
|
||||
// `Sms` is mean `Sms` whether defined in suite feature settings. expression like
|
||||
// `Sms = SmsJuhe` is mean whether `Sms` define in suite feature settings and value
|
||||
// is `SmsJuhe`
|
||||
func (f *Features) CfgNot(expression string, handle func()) {
|
||||
if !f.CfgIf(expression) {
|
||||
handle()
|
||||
}
|
||||
}
|
@ -1,114 +0,0 @@
|
||||
package cfg
|
||||
|
||||
import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestUseDefault(t *testing.T) {
|
||||
suites := map[string][]string{
|
||||
"default": {"Sms", "Alipay", "Zinc", "MySQL", "Redis", "AliOSS", "LogZinc"},
|
||||
"develop": {"Zinc", "MySQL", "AliOSS", "LogFile"},
|
||||
"slim": {"Zinc", "MySQL", "Redis", "AliOSS", "LogFile"},
|
||||
}
|
||||
kv := map[string]string{
|
||||
"sms": "SmsJuhe",
|
||||
}
|
||||
f := NewFeatures(suites, kv)
|
||||
for _, data := range []struct {
|
||||
key string
|
||||
expect string
|
||||
exist bool
|
||||
}{
|
||||
{"Sms", "SmsJuhe", true},
|
||||
{"Alipay", "", true},
|
||||
{"Zinc", "", true},
|
||||
{"Redis", "", true},
|
||||
{"Database", "", false},
|
||||
} {
|
||||
if v, ok := f.Cfg(data.key); ok != data.exist || v != data.expect {
|
||||
t.Errorf("key: %s expect: %s exist: %t got v: %s ok: %t", data.key, data.expect, data.exist, v, ok)
|
||||
}
|
||||
}
|
||||
for exp, res := range map[string]bool{
|
||||
"Sms": true,
|
||||
"Sms = SmsJuhe": true,
|
||||
"SmsJuhe": false,
|
||||
"default": true,
|
||||
} {
|
||||
if ok := f.CfgIf(exp); res != ok {
|
||||
t.Errorf("CfgIf(%s) want %t got %t", exp, res, ok)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func TestUse(t *testing.T) {
|
||||
suites := map[string][]string{
|
||||
"default": {"Sms", "Alipay", "Zinc", "MySQL", "Redis", "AliOSS", "LogZinc"},
|
||||
"develop": {"Zinc", "MySQL", "AliOSS", "LogFile"},
|
||||
"slim": {"Zinc", "MySQL", "Redis", "AliOSS", "LogFile"},
|
||||
}
|
||||
kv := map[string]string{
|
||||
"sms": "SmsJuhe",
|
||||
}
|
||||
f := NewFeatures(suites, kv)
|
||||
|
||||
f.Use([]string{"develop"}, true)
|
||||
for _, data := range []struct {
|
||||
key string
|
||||
expect string
|
||||
exist bool
|
||||
}{
|
||||
{"Sms", "", false},
|
||||
{"Alipay", "", false},
|
||||
{"Zinc", "", true},
|
||||
{"Redis", "", false},
|
||||
{"Database", "", false},
|
||||
} {
|
||||
if v, ok := f.Cfg(data.key); ok != data.exist || v != data.expect {
|
||||
t.Errorf("key: %s expect: %s exist: %t got v: %s ok: %t", data.key, data.expect, data.exist, v, ok)
|
||||
}
|
||||
}
|
||||
for exp, res := range map[string]bool{
|
||||
"Sms": false,
|
||||
"Sms = SmsJuhe": false,
|
||||
"SmsJuhe": false,
|
||||
"default": false,
|
||||
"develop": true,
|
||||
} {
|
||||
if ok := f.CfgIf(exp); res != ok {
|
||||
t.Errorf("CfgIf(%s) want %t got %t", exp, res, ok)
|
||||
}
|
||||
}
|
||||
|
||||
f.UseDefault()
|
||||
f.Use([]string{"slim", "", "demo"}, false)
|
||||
for _, data := range []struct {
|
||||
key string
|
||||
expect string
|
||||
exist bool
|
||||
}{
|
||||
{"Sms", "SmsJuhe", true},
|
||||
{"Alipay", "", true},
|
||||
{"Zinc", "", true},
|
||||
{"Redis", "", true},
|
||||
{"Database", "", false},
|
||||
{"demo", "", true},
|
||||
} {
|
||||
if v, ok := f.Cfg(data.key); ok != data.exist || v != data.expect {
|
||||
t.Errorf("key: %s expect: %s exist: %t got v: %s ok: %t", data.key, data.expect, data.exist, v, ok)
|
||||
}
|
||||
}
|
||||
for exp, res := range map[string]bool{
|
||||
"Sms": true,
|
||||
"Sms = SmsJuhe": true,
|
||||
"SmsJuhe": false,
|
||||
"default": true,
|
||||
"develop": false,
|
||||
"slim": true,
|
||||
"demo": true,
|
||||
} {
|
||||
if ok := f.CfgIf(exp); res != ok {
|
||||
t.Errorf("CfgIf(%s) want %t got %t", exp, res, ok)
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in new issue