mirror of
https://github.com/interviewstreet/go-jira.git
synced 2025-06-12 23:37:31 +02:00
Add 'affects versions' to issue fields
This commit is contained in:
parent
18969b05a0
commit
b1589c4b06
76
issue.go
76
issue.go
@ -101,42 +101,43 @@ type IssueFields struct {
|
|||||||
// * "workratio": -1,
|
// * "workratio": -1,
|
||||||
// * "lastViewed": null,
|
// * "lastViewed": null,
|
||||||
// * "environment": null,
|
// * "environment": null,
|
||||||
Expand string `json:"expand,omitempty" structs:"expand,omitempty"`
|
Expand string `json:"expand,omitempty" structs:"expand,omitempty"`
|
||||||
Type IssueType `json:"issuetype,omitempty" structs:"issuetype,omitempty"`
|
Type IssueType `json:"issuetype,omitempty" structs:"issuetype,omitempty"`
|
||||||
Project Project `json:"project,omitempty" structs:"project,omitempty"`
|
Project Project `json:"project,omitempty" structs:"project,omitempty"`
|
||||||
Resolution *Resolution `json:"resolution,omitempty" structs:"resolution,omitempty"`
|
Resolution *Resolution `json:"resolution,omitempty" structs:"resolution,omitempty"`
|
||||||
Priority *Priority `json:"priority,omitempty" structs:"priority,omitempty"`
|
Priority *Priority `json:"priority,omitempty" structs:"priority,omitempty"`
|
||||||
Resolutiondate Time `json:"resolutiondate,omitempty" structs:"resolutiondate,omitempty"`
|
Resolutiondate Time `json:"resolutiondate,omitempty" structs:"resolutiondate,omitempty"`
|
||||||
Created Time `json:"created,omitempty" structs:"created,omitempty"`
|
Created Time `json:"created,omitempty" structs:"created,omitempty"`
|
||||||
Duedate Date `json:"duedate,omitempty" structs:"duedate,omitempty"`
|
Duedate Date `json:"duedate,omitempty" structs:"duedate,omitempty"`
|
||||||
Watches *Watches `json:"watches,omitempty" structs:"watches,omitempty"`
|
Watches *Watches `json:"watches,omitempty" structs:"watches,omitempty"`
|
||||||
Assignee *User `json:"assignee,omitempty" structs:"assignee,omitempty"`
|
Assignee *User `json:"assignee,omitempty" structs:"assignee,omitempty"`
|
||||||
Updated Time `json:"updated,omitempty" structs:"updated,omitempty"`
|
Updated Time `json:"updated,omitempty" structs:"updated,omitempty"`
|
||||||
Description string `json:"description,omitempty" structs:"description,omitempty"`
|
Description string `json:"description,omitempty" structs:"description,omitempty"`
|
||||||
Summary string `json:"summary,omitempty" structs:"summary,omitempty"`
|
Summary string `json:"summary,omitempty" structs:"summary,omitempty"`
|
||||||
Creator *User `json:"Creator,omitempty" structs:"Creator,omitempty"`
|
Creator *User `json:"Creator,omitempty" structs:"Creator,omitempty"`
|
||||||
Reporter *User `json:"reporter,omitempty" structs:"reporter,omitempty"`
|
Reporter *User `json:"reporter,omitempty" structs:"reporter,omitempty"`
|
||||||
Components []*Component `json:"components,omitempty" structs:"components,omitempty"`
|
Components []*Component `json:"components,omitempty" structs:"components,omitempty"`
|
||||||
Status *Status `json:"status,omitempty" structs:"status,omitempty"`
|
Status *Status `json:"status,omitempty" structs:"status,omitempty"`
|
||||||
Progress *Progress `json:"progress,omitempty" structs:"progress,omitempty"`
|
Progress *Progress `json:"progress,omitempty" structs:"progress,omitempty"`
|
||||||
AggregateProgress *Progress `json:"aggregateprogress,omitempty" structs:"aggregateprogress,omitempty"`
|
AggregateProgress *Progress `json:"aggregateprogress,omitempty" structs:"aggregateprogress,omitempty"`
|
||||||
TimeTracking *TimeTracking `json:"timetracking,omitempty" structs:"timetracking,omitempty"`
|
TimeTracking *TimeTracking `json:"timetracking,omitempty" structs:"timetracking,omitempty"`
|
||||||
TimeSpent int `json:"timespent,omitempty" structs:"timespent,omitempty"`
|
TimeSpent int `json:"timespent,omitempty" structs:"timespent,omitempty"`
|
||||||
TimeEstimate int `json:"timeestimate,omitempty" structs:"timeestimate,omitempty"`
|
TimeEstimate int `json:"timeestimate,omitempty" structs:"timeestimate,omitempty"`
|
||||||
TimeOriginalEstimate int `json:"timeoriginalestimate,omitempty" structs:"timeoriginalestimate,omitempty"`
|
TimeOriginalEstimate int `json:"timeoriginalestimate,omitempty" structs:"timeoriginalestimate,omitempty"`
|
||||||
Worklog *Worklog `json:"worklog,omitempty" structs:"worklog,omitempty"`
|
Worklog *Worklog `json:"worklog,omitempty" structs:"worklog,omitempty"`
|
||||||
IssueLinks []*IssueLink `json:"issuelinks,omitempty" structs:"issuelinks,omitempty"`
|
IssueLinks []*IssueLink `json:"issuelinks,omitempty" structs:"issuelinks,omitempty"`
|
||||||
Comments *Comments `json:"comment,omitempty" structs:"comment,omitempty"`
|
Comments *Comments `json:"comment,omitempty" structs:"comment,omitempty"`
|
||||||
FixVersions []*FixVersion `json:"fixVersions,omitempty" structs:"fixVersions,omitempty"`
|
FixVersions []*FixVersion `json:"fixVersions,omitempty" structs:"fixVersions,omitempty"`
|
||||||
Labels []string `json:"labels,omitempty" structs:"labels,omitempty"`
|
AffectsVersions []*AffectsVersion `json:"versions,omitempty" structs:"versions,omitempty"`
|
||||||
Subtasks []*Subtasks `json:"subtasks,omitempty" structs:"subtasks,omitempty"`
|
Labels []string `json:"labels,omitempty" structs:"labels,omitempty"`
|
||||||
Attachments []*Attachment `json:"attachment,omitempty" structs:"attachment,omitempty"`
|
Subtasks []*Subtasks `json:"subtasks,omitempty" structs:"subtasks,omitempty"`
|
||||||
Epic *Epic `json:"epic,omitempty" structs:"epic,omitempty"`
|
Attachments []*Attachment `json:"attachment,omitempty" structs:"attachment,omitempty"`
|
||||||
Sprint *Sprint `json:"sprint,omitempty" structs:"sprint,omitempty"`
|
Epic *Epic `json:"epic,omitempty" structs:"epic,omitempty"`
|
||||||
Parent *Parent `json:"parent,omitempty" structs:"parent,omitempty"`
|
Sprint *Sprint `json:"sprint,omitempty" structs:"sprint,omitempty"`
|
||||||
AggregateTimeOriginalEstimate int `json:"aggregatetimeoriginalestimate,omitempty" structs:"aggregatetimeoriginalestimate,omitempty"`
|
Parent *Parent `json:"parent,omitempty" structs:"parent,omitempty"`
|
||||||
AggregateTimeSpent int `json:"aggregatetimespent,omitempty" structs:"aggregatetimespent,omitempty"`
|
AggregateTimeOriginalEstimate int `json:"aggregatetimeoriginalestimate,omitempty" structs:"aggregatetimeoriginalestimate,omitempty"`
|
||||||
AggregateTimeEstimate int `json:"aggregatetimeestimate,omitempty" structs:"aggregatetimeestimate,omitempty"`
|
AggregateTimeSpent int `json:"aggregatetimespent,omitempty" structs:"aggregatetimespent,omitempty"`
|
||||||
|
AggregateTimeEstimate int `json:"aggregatetimeestimate,omitempty" structs:"aggregatetimeestimate,omitempty"`
|
||||||
Unknowns tcontainer.MarshalMap
|
Unknowns tcontainer.MarshalMap
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -476,6 +477,9 @@ type FixVersion struct {
|
|||||||
StartDate string `json:"startDate,omitempty" structs:"startDate,omitempty"`
|
StartDate string `json:"startDate,omitempty" structs:"startDate,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// AffectsVersion represents a software release which is affected by an issue.
|
||||||
|
type AffectsVersion Version
|
||||||
|
|
||||||
// CommentVisibility represents he visibility of a comment.
|
// CommentVisibility represents he visibility of a comment.
|
||||||
// E.g. Type could be "role" and Value "Administrators"
|
// E.g. Type could be "role" and Value "Administrators"
|
||||||
type CommentVisibility struct {
|
type CommentVisibility struct {
|
||||||
|
@ -937,6 +937,14 @@ func TestIssueFields_MarshalJSON_Success(t *testing.T) {
|
|||||||
ID: "10000",
|
ID: "10000",
|
||||||
Key: "EX",
|
Key: "EX",
|
||||||
},
|
},
|
||||||
|
AffectsVersions: []*AffectsVersion{
|
||||||
|
&AffectsVersion{
|
||||||
|
ID: "10705",
|
||||||
|
Name: "2.1.0-rc3",
|
||||||
|
Self: "http://www.example.com/jira/rest/api/2/version/10705",
|
||||||
|
ReleaseDate: "2018-09-30",
|
||||||
|
},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
bytes, err := json.Marshal(i)
|
bytes, err := json.Marshal(i)
|
||||||
@ -1428,3 +1436,35 @@ func TestIssueService_Get_Fields_Changelog(t *testing.T) {
|
|||||||
t.Errorf("Expected CreatedTime func return %v time, %v got", tm, ct)
|
t.Errorf("Expected CreatedTime func return %v time, %v got", tm, ct)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
func TestIssueService_Get_Fields_AffectsVersions(t *testing.T) {
|
||||||
|
setup()
|
||||||
|
defer teardown()
|
||||||
|
testMux.HandleFunc("/rest/api/2/issue/10002", func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
testMethod(t, r, "GET")
|
||||||
|
testRequestURL(t, r, "/rest/api/2/issue/10002")
|
||||||
|
|
||||||
|
fmt.Fprint(w, `{"fields":{"versions":[{"self":"http://www.example.com/jira/rest/api/2/version/10705","id":"10705","description":"test description","name":"2.1.0-rc3","archived":false,"released":false,"releaseDate":"2018-09-30"}]}}`)
|
||||||
|
})
|
||||||
|
|
||||||
|
issue, _, err := testClient.Issue.Get("10002", nil)
|
||||||
|
if issue == nil {
|
||||||
|
t.Error("Expected issue. Issue is nil")
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(issue.Fields.AffectsVersions, []*AffectsVersion{
|
||||||
|
{
|
||||||
|
ID: "10705",
|
||||||
|
Name: "2.1.0-rc3",
|
||||||
|
Self: "http://www.example.com/jira/rest/api/2/version/10705",
|
||||||
|
ReleaseDate: "2018-09-30",
|
||||||
|
Released: false,
|
||||||
|
Archived: false,
|
||||||
|
Description: "test description",
|
||||||
|
},
|
||||||
|
}) {
|
||||||
|
t.Error("Expected AffectsVersions for the returned issue")
|
||||||
|
}
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Error given: %s", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user