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

How to sync a move of a subtask using Exalate

(I'm Francis - product manager for Exalate - an issue tracker synchronization solution) 

 

Challenge

More and more companies are using issue trackers to organize day to day operations. Nowadays everything is connected with everything, and the probability that you will be working with another team that is using a completely different solution grows daily.

 

To avoid tedious manual copying data between the different environments, different issue tracker synchronization solutions exist.

Of course - integrations can become more complex as it requires that the target Jira mirrors in some way the information of the source Jira. 

Lately, we've been challenged with another synchronization case to synchronize sub-tasks which moved from one parent to another.

 

Assume you have the following structure (Issue Lx is synchronized to Issue Rx)

2019-08-13_23-06-30.png

 

Whenever someone moves subtask LA1 to parent LB, what should happen with the twin of LA1 (RA1)?  From a business point of view, you would expect that subtask RA1 moves to parent RB.

 

 

Solution (with Exalate)

An intro to Exalate

Exalate has the concept of outgoing and incoming script rules.  The outgoing script rules specify what information is sent from the source to the target, and the incoming script rules define how incoming information is processed on the local issues.

 

These rules are specified as groovy scripts to allow for maximum flexibility.  Thanks to the built-in scripting capability, almost any synchronization use case can be developed.

 

Additionally - on Jira Server - Exalate is running as an embedded app and is therefore fully capable to access any of the services provided by the Jira process. 

 

Exalating subtasks

 

Whenever a subtask is synchronized, it is important to sync the relation with the parent of the subtask

This can be done by adding the parent id of the subtask to the message that will be sent to the other side:

replica.parentId = issue.parentId

On the receiving end, it is important to ensure that the subtask parent is mapped to the right parent. 

Following code-snippet allows doing so

 

2019-08-13_23-28-59.png

  • line 1, test if a parentId is provided in the incoming message
  • line 3, use the getLocalIssueFromRemoteId to look up the local twin of the parent
  • line 5, if the localParent is found, set the parentId of the to be created subtask to the id of the found parent.
  • The code snippet can be found here

Moving a subtask

The code snippet is also valid in case the subtask is moved from one parent to another on the source.

 

The message (replica) will contain the new parentId, and if the parent is found, twin subtask will be moved to the new parent.

 

Conclusion

Building real-life synchronization cases require the flexibility of a solution like Exalate.  It must be able to support standard operations like moving subtasks from one parent to another and be robust enough to implement any challenging synchronization case.

 

Do you want to know more or a real challenge - don't hesitate to reach out here

 

 

Francis

0 comments

Comment

Log in or Sign up to comment
TAGS
Community showcase
Published in Marketplace Apps & Integrations

Staying organized with Jira: best practices for a better project management

Project managers know this problem: A “mountain of work” lays in front of you, and you don’t know how and where to tackle them. Different to-dos lie ahead, but just one task after the other can be ha...

246 views 2 1
Read article

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