parseReviewers parses given Reviews and ReviewRequests
(pr api.PullRequest)
| 347 | |
| 348 | // parseReviewers parses given Reviews and ReviewRequests |
| 349 | func parseReviewers(pr api.PullRequest) []*reviewerState { |
| 350 | reviewerStates := make(map[string]*reviewerState) |
| 351 | |
| 352 | for _, review := range pr.Reviews.Nodes { |
| 353 | if review.Author.Login != pr.Author.Login { |
| 354 | name := review.AuthorLogin() |
| 355 | if name == "" { |
| 356 | name = ghostName |
| 357 | } |
| 358 | reviewerStates[name] = &reviewerState{ |
| 359 | Name: name, |
| 360 | State: review.State, |
| 361 | } |
| 362 | } |
| 363 | } |
| 364 | |
| 365 | // Overwrite reviewer's state if a review request for the same reviewer exists. |
| 366 | for _, reviewRequest := range pr.ReviewRequests.Nodes { |
| 367 | name := reviewRequest.RequestedReviewer.DisplayName() |
| 368 | reviewerStates[name] = &reviewerState{ |
| 369 | Name: name, |
| 370 | State: requestedReviewState, |
| 371 | } |
| 372 | } |
| 373 | |
| 374 | // Convert map to slice for ease of sort |
| 375 | result := make([]*reviewerState, 0, len(reviewerStates)) |
| 376 | for _, reviewer := range reviewerStates { |
| 377 | if reviewer.State == pendingReviewState { |
| 378 | continue |
| 379 | } |
| 380 | result = append(result, reviewer) |
| 381 | } |
| 382 | |
| 383 | return result |
| 384 | } |
| 385 | |
| 386 | // sortReviewerStates puts completed reviews before review requests and sorts names alphabetically |
| 387 | func sortReviewerStates(reviewerStates []*reviewerState) { |
no test coverage detected