mirror of
https://github.com/interviewstreet/go-jira.git
synced 2024-12-10 10:10:10 +02:00
Merge pull request #38 from bidesh/master
Fix MetaIssueTypes to MetaIssueType and GetProjectWithKey from createmeta
This commit is contained in:
commit
5563f27ecd
23
metaissue.go
23
metaissue.go
@ -21,16 +21,16 @@ type MetaProject struct {
|
|||||||
Key string `json:"key,omitempty"`
|
Key string `json:"key,omitempty"`
|
||||||
Name string `json:"name,omitempty"`
|
Name string `json:"name,omitempty"`
|
||||||
// omitted avatarUrls
|
// omitted avatarUrls
|
||||||
IssueTypes []*MetaIssueTypes `json:"issuetypes,omitempty"`
|
IssueTypes []*MetaIssueType `json:"issuetypes,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// metaIssueTypes represents the different issue types a project has.
|
// MetaIssueType represents the different issue types a project has.
|
||||||
//
|
//
|
||||||
// Note: Fields is interface because this is an object which can
|
// Note: Fields is interface because this is an object which can
|
||||||
// have arbitraty keys related to customfields. It is not possible to
|
// have arbitraty keys related to customfields. It is not possible to
|
||||||
// expect these for a general way. This will be returning a map.
|
// expect these for a general way. This will be returning a map.
|
||||||
// Further processing must be done depending on what is required.
|
// Further processing must be done depending on what is required.
|
||||||
type MetaIssueTypes struct {
|
type MetaIssueType struct {
|
||||||
Self string `json:"expand,omitempty"`
|
Self string `json:"expand,omitempty"`
|
||||||
Id string `json:"id,omitempty"`
|
Id string `json:"id,omitempty"`
|
||||||
Description string `json:"description,omitempty"`
|
Description string `json:"description,omitempty"`
|
||||||
@ -72,9 +72,20 @@ func (m *CreateMetaInfo) GetProjectWithName(name string) *MetaProject {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetProjectWithName returns a project with "name" from the meta information recieved. If not found, this returns nil.
|
||||||
|
// The comparision of the name is case insensitive.
|
||||||
|
func (m *CreateMetaInfo) GetProjectWithKey(key string) *MetaProject {
|
||||||
|
for _, m := range m.Projects {
|
||||||
|
if strings.ToLower(m.Key) == strings.ToLower(key) {
|
||||||
|
return m
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// GetIssueWithName returns an IssueType with name from a given MetaProject. If not found, this returns nil.
|
// GetIssueWithName returns an IssueType with name from a given MetaProject. If not found, this returns nil.
|
||||||
// The comparision of the name is case insensitive
|
// The comparision of the name is case insensitive
|
||||||
func (p *MetaProject) GetIssueTypeWithName(name string) *MetaIssueTypes {
|
func (p *MetaProject) GetIssueTypeWithName(name string) *MetaIssueType {
|
||||||
for _, m := range p.IssueTypes {
|
for _, m := range p.IssueTypes {
|
||||||
if strings.ToLower(m.Name) == strings.ToLower(name) {
|
if strings.ToLower(m.Name) == strings.ToLower(name) {
|
||||||
return m
|
return m
|
||||||
@ -100,7 +111,7 @@ func (p *MetaProject) GetIssueTypeWithName(name string) *MetaIssueTypes {
|
|||||||
// }
|
// }
|
||||||
// the returned map would have "Epic Link" as the key and "customfield_10806" as value.
|
// the returned map would have "Epic Link" as the key and "customfield_10806" as value.
|
||||||
// This choice has been made so that the it is easier to generate the create api request later.
|
// This choice has been made so that the it is easier to generate the create api request later.
|
||||||
func (t *MetaIssueTypes) GetMandatoryFields() (map[string]string, error) {
|
func (t *MetaIssueType) GetMandatoryFields() (map[string]string, error) {
|
||||||
ret := make(map[string]string)
|
ret := make(map[string]string)
|
||||||
for key, _ := range t.Fields {
|
for key, _ := range t.Fields {
|
||||||
required, err := t.Fields.Bool(key + "/required")
|
required, err := t.Fields.Bool(key + "/required")
|
||||||
@ -120,7 +131,7 @@ func (t *MetaIssueTypes) GetMandatoryFields() (map[string]string, error) {
|
|||||||
|
|
||||||
// GetAllFields returns a map of all the fields for an IssueType. This includes all required and not required.
|
// GetAllFields returns a map of all the fields for an IssueType. This includes all required and not required.
|
||||||
// The key of the returned map is what you see in the form and the value is how it is representated in the jira schema.
|
// The key of the returned map is what you see in the form and the value is how it is representated in the jira schema.
|
||||||
func (t *MetaIssueTypes) GetAllFields() (map[string]string, error) {
|
func (t *MetaIssueType) GetAllFields() (map[string]string, error) {
|
||||||
ret := make(map[string]string)
|
ret := make(map[string]string)
|
||||||
for key, _ := range t.Fields {
|
for key, _ := range t.Fields {
|
||||||
|
|
||||||
|
@ -378,7 +378,7 @@ func TestIssueService_GetCreateMeta_Success(t *testing.T) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMetaIssueTypes_GetMandatoryFields(t *testing.T) {
|
func TestMetaIssueType_GetMandatoryFields(t *testing.T) {
|
||||||
data := make(map[string]interface{})
|
data := make(map[string]interface{})
|
||||||
|
|
||||||
data["summary"] = map[string]interface{}{
|
data["summary"] = map[string]interface{}{
|
||||||
@ -396,7 +396,7 @@ func TestMetaIssueTypes_GetMandatoryFields(t *testing.T) {
|
|||||||
"name": "Epic Link",
|
"name": "Epic Link",
|
||||||
}
|
}
|
||||||
|
|
||||||
m := new(MetaIssueTypes)
|
m := new(MetaIssueType)
|
||||||
m.Fields = data
|
m.Fields = data
|
||||||
|
|
||||||
mandatory, err := m.GetMandatoryFields()
|
mandatory, err := m.GetMandatoryFields()
|
||||||
@ -409,14 +409,14 @@ func TestMetaIssueTypes_GetMandatoryFields(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMetaIssueTypes_GetMandatoryFields_NonExistentRequiredKey_Fail(t *testing.T) {
|
func TestMetaIssueType_GetMandatoryFields_NonExistentRequiredKey_Fail(t *testing.T) {
|
||||||
data := make(map[string]interface{})
|
data := make(map[string]interface{})
|
||||||
|
|
||||||
data["summary"] = map[string]interface{}{
|
data["summary"] = map[string]interface{}{
|
||||||
"name": "Summary",
|
"name": "Summary",
|
||||||
}
|
}
|
||||||
|
|
||||||
m := new(MetaIssueTypes)
|
m := new(MetaIssueType)
|
||||||
m.Fields = data
|
m.Fields = data
|
||||||
|
|
||||||
_, err := m.GetMandatoryFields()
|
_, err := m.GetMandatoryFields()
|
||||||
@ -425,14 +425,14 @@ func TestMetaIssueTypes_GetMandatoryFields_NonExistentRequiredKey_Fail(t *testin
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMetaIssueTypes_GetMandatoryFields_NonExistentNameKey_Fail(t *testing.T) {
|
func TestMetaIssueType_GetMandatoryFields_NonExistentNameKey_Fail(t *testing.T) {
|
||||||
data := make(map[string]interface{})
|
data := make(map[string]interface{})
|
||||||
|
|
||||||
data["summary"] = map[string]interface{}{
|
data["summary"] = map[string]interface{}{
|
||||||
"required": true,
|
"required": true,
|
||||||
}
|
}
|
||||||
|
|
||||||
m := new(MetaIssueTypes)
|
m := new(MetaIssueType)
|
||||||
m.Fields = data
|
m.Fields = data
|
||||||
|
|
||||||
_, err := m.GetMandatoryFields()
|
_, err := m.GetMandatoryFields()
|
||||||
@ -441,7 +441,7 @@ func TestMetaIssueTypes_GetMandatoryFields_NonExistentNameKey_Fail(t *testing.T)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMetaIssueTypes_GetAllFields(t *testing.T) {
|
func TestMetaIssueType_GetAllFields(t *testing.T) {
|
||||||
data := make(map[string]interface{})
|
data := make(map[string]interface{})
|
||||||
|
|
||||||
data["summary"] = map[string]interface{}{
|
data["summary"] = map[string]interface{}{
|
||||||
@ -459,7 +459,7 @@ func TestMetaIssueTypes_GetAllFields(t *testing.T) {
|
|||||||
"name": "Epic Link",
|
"name": "Epic Link",
|
||||||
}
|
}
|
||||||
|
|
||||||
m := new(MetaIssueTypes)
|
m := new(MetaIssueType)
|
||||||
m.Fields = data
|
m.Fields = data
|
||||||
|
|
||||||
mandatory, err := m.GetAllFields()
|
mandatory, err := m.GetAllFields()
|
||||||
@ -473,14 +473,14 @@ func TestMetaIssueTypes_GetAllFields(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMetaIssueTypes_GetAllFields_NonExistingNameKey_Fail(t *testing.T) {
|
func TestMetaIssueType_GetAllFields_NonExistingNameKey_Fail(t *testing.T) {
|
||||||
data := make(map[string]interface{})
|
data := make(map[string]interface{})
|
||||||
|
|
||||||
data["summary"] = map[string]interface{}{
|
data["summary"] = map[string]interface{}{
|
||||||
"required": true,
|
"required": true,
|
||||||
}
|
}
|
||||||
|
|
||||||
m := new(MetaIssueTypes)
|
m := new(MetaIssueType)
|
||||||
m.Fields = data
|
m.Fields = data
|
||||||
|
|
||||||
_, err := m.GetAllFields()
|
_, err := m.GetAllFields()
|
||||||
@ -489,7 +489,7 @@ func TestMetaIssueTypes_GetAllFields_NonExistingNameKey_Fail(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestCreateMetaInfo_GetProjectName_Success(t *testing.T) {
|
func TestCreateMetaInfo_GetProjectWithName_Success(t *testing.T) {
|
||||||
metainfo := new(CreateMetaInfo)
|
metainfo := new(CreateMetaInfo)
|
||||||
metainfo.Projects = append(metainfo.Projects, &MetaProject{
|
metainfo.Projects = append(metainfo.Projects, &MetaProject{
|
||||||
Name: "SPN",
|
Name: "SPN",
|
||||||
@ -503,7 +503,7 @@ func TestCreateMetaInfo_GetProjectName_Success(t *testing.T) {
|
|||||||
|
|
||||||
func TestMetaProject_GetIssueTypeWithName_CaseMismatch_Success(t *testing.T) {
|
func TestMetaProject_GetIssueTypeWithName_CaseMismatch_Success(t *testing.T) {
|
||||||
m := new(MetaProject)
|
m := new(MetaProject)
|
||||||
m.IssueTypes = append(m.IssueTypes, &MetaIssueTypes{
|
m.IssueTypes = append(m.IssueTypes, &MetaIssueType{
|
||||||
Name: "Bug",
|
Name: "Bug",
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -513,3 +513,27 @@ func TestMetaProject_GetIssueTypeWithName_CaseMismatch_Success(t *testing.T) {
|
|||||||
t.Errorf("Expected non nil value, recieved nil")
|
t.Errorf("Expected non nil value, recieved nil")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestCreateMetaInfo_GetProjectWithKey_Success(t *testing.T) {
|
||||||
|
metainfo := new(CreateMetaInfo)
|
||||||
|
metainfo.Projects = append(metainfo.Projects, &MetaProject{
|
||||||
|
Key: "SPNKEY",
|
||||||
|
})
|
||||||
|
|
||||||
|
project := metainfo.GetProjectWithKey("SPNKEY")
|
||||||
|
if project == nil {
|
||||||
|
t.Errorf("Expected non nil value, recieved nil")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestCreateMetaInfo_GetProjectWithKey_NilForNonExistent(t *testing.T) {
|
||||||
|
metainfo := new(CreateMetaInfo)
|
||||||
|
metainfo.Projects = append(metainfo.Projects, &MetaProject{
|
||||||
|
Key: "SPNKEY",
|
||||||
|
})
|
||||||
|
|
||||||
|
project := metainfo.GetProjectWithKey("SPN")
|
||||||
|
if project != nil {
|
||||||
|
t.Errorf("Expected nil, recieved value")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user