Calculando o percentual de conclusão do épico (ScriptRunner)

Daiane Conte
Rising Star
Rising Star
Rising Stars are recognized for providing high-quality answers to other users. Rising Stars receive a certificate of achievement and are on the path to becoming Community Leaders.
April 15, 2021

Olá Pessoal,

 

Gostaria de compartilhar uma necessidade que tivemos aqui na empresa para exibir o percentual de evolução do épico.

Um agilista precisava montar um board UpStream e apresentar no card a evolução do épico. Criamos esse calculo a partir do APP ScriptRunner na opção Custom Script Fields, esse campo calculado pode ser utilizado em relatórios nativos do Jira, boards e dashboards.

Segue abaixo o código que utilizamos nesse campo calculado:

import com.atlassian.jira.component.ComponentAccessor
import com.atlassian.jira.bc.issue.search.SearchService
import com.atlassian.jira.jql.parser.JqlQueryParser
import com.atlassian.jira.web.bean.PagerFilter
import java.text.DecimalFormat
import java.text.NumberFormat

def jqlQueryParser = ComponentAccessor.getComponent(JqlQueryParser)
def searchService = ComponentAccessor.getComponent(SearchService)
def issueManager = ComponentAccessor.getIssueManager()
def user = ComponentAccessor.getJiraAuthenticationContext().getLoggedInUser()

NumberFormat nf = NumberFormat.getNumberInstance(Locale.US);
DecimalFormat df = (DecimalFormat)nf
df.applyPattern("###,##0.00")

// edit this query to suit
def query = jqlQueryParser.parseQuery("issueFunction in linkedIssuesOf(\"issuekey=" + issue.key + "\",\"Is Epic Of\")")
def search = searchService.search(user, query, PagerFilter.getUnlimitedFilter())

log.debug("Total issues: ${search.total}")

def Progresso = 0
def StatusFinalizado = 0
def Total = 0
def textoCategoria = ""

search.results.each { documentIssue ->
log.debug(documentIssue.key)

// if you need a mutable issue you can do:
def issueJira = issueManager.getIssueObject(documentIssue.id)

//ajuste para não entrar os itens removed
if (!issueJira.issueType.isSubTask() && issueJira.issueType.name != "Epic" && issueJira.getStatus().name != "Removed")
{

/// textoCategoria = textoCategoria + " - " + issueJira.issueType.name

if(issueJira.getStatus().getStatusCategory().name == "Complete" &&issueJira.getStatus().getStatusCategory().name != "Removed" ) {
(StatusFinalizado++)
textoCategoria = textoCategoria + " - " + issueJira.issueType.name
}

(Total++ )
}
}

if (Total > 0){
//Total de Features em Andamento ou finalizado
Progresso = (((int)StatusFinalizado) / (int)Total) * 100;
}


return df.format(Progresso) + "%"

 

 

 

2 comments

Comment

Log in or Sign up to comment
Débora Campos
I'm New Here
I'm New Here
Those new to the Atlassian Community have posted less than three times. Give them a warm welcome!
April 15, 2021

Oi Daiane, td bem?

Muito legal a ideia.

Você tem imagem de exemplo do resultado final? Como ele representa nos relatórios nativos do jira?

Like # people like this
Italo _Modus Create_
Contributor
April 16, 2021

Oi @Daiane Conte ,

Ótimo exemplo! 

 

Tenho uma observação, esse script vai acontecer toda vez que a issue for carregada. Já que esse script utiliza JQL é necessário ter o cuidado de verificar se o Index esta disponível para ser usado.

 

Recomendo adicionar uma condição para verificar se o index esta disponível para ser utilizado, seguindo a documentação abaixo:

https://docs.adaptavist.com/sr4js/6.23.0/features/script-fields/script-field-tips#id-.ScriptFieldTipsv6.20.0-CheckIndexAvailability

 

Isso vai evitar lentidão durante o full reindex.

Like Pedro Silva likes this
TAGS
AUG Leaders

Atlassian Community Events