Merge pull request #4757 from a631807682/fix/issue4698
fix(core/config/xml): prompt error when config format is incorrect
This commit is contained in:
		
						commit
						9f12707dee
					
				| @ -61,6 +61,7 @@ | ||||
| - Fix 4736: set a fixed value "/" to the "Path" of "_xsrf" cookie. [4736](https://github.com/beego/beego/issues/4735) [4739](https://github.com/beego/beego/issues/4739) | ||||
| - Fix 4734: do not reset id in Delete function. [4738](https://github.com/beego/beego/pull/4738) [4742](https://github.com/beego/beego/pull/4742) | ||||
| - Fix 4699: Remove Remove goyaml2 dependency. [4755](https://github.com/beego/beego/pull/4755) | ||||
| - Fix 4698: Prompt error when config format is incorrect. [4757](https://github.com/beego/beego/pull/4757) | ||||
| 
 | ||||
| ## Fix Sonar | ||||
| 
 | ||||
|  | ||||
| @ -70,7 +70,17 @@ func (xc *Config) ParseData(data []byte) (config.Configer, error) { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	x.data = config.ExpandValueEnvForMap(d["config"].(map[string]interface{})) | ||||
| 	v := d["config"] | ||||
| 	if v == nil { | ||||
| 		return nil, fmt.Errorf("xml parse should include in <config></config> tags") | ||||
| 	} | ||||
| 
 | ||||
| 	confVal, ok := v.(map[string]interface{}) | ||||
| 	if !ok { | ||||
| 		return nil, fmt.Errorf("xml parse <config></config> tags should include sub tags") | ||||
| 	} | ||||
| 
 | ||||
| 	x.data = config.ExpandValueEnvForMap(confVal) | ||||
| 
 | ||||
| 	return x, nil | ||||
| } | ||||
|  | ||||
| @ -26,7 +26,7 @@ import ( | ||||
| 
 | ||||
| func TestXML(t *testing.T) { | ||||
| 	var ( | ||||
| 		// xml parse should incluce in <config></config> tags | ||||
| 		// xml parse should include in <config></config> tags | ||||
| 		xmlcontext = `<?xml version="1.0" encoding="UTF-8"?> | ||||
| <config> | ||||
| <appname>beeapi</appname> | ||||
| @ -150,6 +150,25 @@ func TestXML(t *testing.T) { | ||||
| 	assert.Equal(t, "MySection", sec.Name) | ||||
| } | ||||
| 
 | ||||
| func TestXMLMissConfig(t *testing.T) { | ||||
| 	xmlcontext1 := ` | ||||
| 	<?xml version="1.0" encoding="UTF-8"?> | ||||
| 	<appname>beeapi</appname> | ||||
| 	` | ||||
| 
 | ||||
| 	c := &Config{} | ||||
| 	_, err := c.ParseData([]byte(xmlcontext1)) | ||||
| 	assert.Equal(t, "xml parse should include in <config></config> tags", err.Error()) | ||||
| 
 | ||||
| 	xmlcontext2 := ` | ||||
| 	<?xml version="1.0" encoding="UTF-8"?> | ||||
| 	<config></config> | ||||
| 	` | ||||
| 
 | ||||
| 	_, err = c.ParseData([]byte(xmlcontext2)) | ||||
| 	assert.Equal(t, "xml parse <config></config> tags should include sub tags", err.Error()) | ||||
| } | ||||
| 
 | ||||
| type Section struct { | ||||
| 	Name string `xml:"name"` | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user