Create
cancel
Showing results for 
Search instead for 
Did you mean: 
Sign up Log in
Deleted user
0 / 0 points
Next:
badges earned

Your Points Tracker
Challenges
Leaderboard
  • Global
  • Feed

Badge for your thoughts?

You're enrolled in our new beta rewards program. Join our group to get the inside scoop and share your feedback.

Join group
Recognition
Give the gift of kudos
You have 0 kudos available to give
Who do you want to recognize?
Why do you want to recognize them?
Kudos
Great job appreciating your peers!
Check back soon to give more kudos.

Past Kudos Given
No kudos given
You haven't given any kudos yet. Share the love above and you'll see it here.

It's not the same without you

Join the community to find out what other Atlassian users are discussing, debating and creating.

Atlassian Community Hero Image Collage

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

Dai Alarcão Community Leader Apr 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

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 Alex likes this

Oi @Dai Alarcão ,

Ó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.

Comment

Log in or Sign up to comment
TAGS

Community Events

Connect with like-minded Atlassian users at free events near you!

Find an event

Connect with like-minded Atlassian users at free events near you!

Unfortunately there are no Community Events near you at the moment.

Host an event

You're one step closer to meeting fellow Atlassian users at your local event. Learn more about Community Events

Events near you