func (p *CrittercismPlugin) DailyMostFrequentCrashes(job *job.Job, f *gotelemetry.Flow) { data, found := f.TableData() if !found { job.ReportError(gotelemetry.NewError(400, "Cannot extract table data from flow"+f.Tag)) } crashes, err := p.api.FetchCrashStatus() if err != nil { job.ReportError(err) return } crashes = crashes.Aggregate() cells := [][]gotelemetry.TableCell{} var count = 8 for _, crash := range crashes { name := "" if crash.Reason != "" { name = crash.Reason } else if crash.DisplayReason != nil { name = *crash.DisplayReason } else if crash.Name != nil { name = *crash.Name } else { name = "N/A (" + crash.Reason + ")" } if len(name) > tableDataLength { name = name[:tableDataLength-1] } cells = append( cells, []gotelemetry.TableCell{ gotelemetry.TableCell{Value: name}, gotelemetry.TableCell{Value: crash.SessionCount}, }, ) count -= 1 if count == 0 { break } } for count > 0 { cells = append( cells, []gotelemetry.TableCell{ gotelemetry.TableCell{Value: ""}, gotelemetry.TableCell{Value: ""}, }, ) count -= 1 } data.Cells = cells job.PostFlowUpdate(f) job.Logf("Updated flow %s", f.Tag) }