Ant task to create Work Items/Deployment Requests/etc?
5 answers
Hi Chris,
I am not aware of such a task. You can create work items using OSLC or using Java and the Plain Java Client Library. How to create work items is outlined here: https://jazz.net/wiki/bin/view/Main/ProgrammaticWorkItemCreation
Hello.
Are there any plans to do so?
I am surprised that they do not exist, as I'd have found them somewhat fundamental.
-Chris
Comments
Chris,
I am with you regarding the wish to have an easy way to create / modify work items from within an ANT build. There are two new additions which partly or completey get the job done.
1. Eclipse Lyo Perl module --> allows you to modify work items. Combined with ANT < exec > task, this will give you 1/2 the solution.
2. Add a custom task to ANT using the plain java api as described by Robin Yehle, to create / modify / link work items. It is not that hard and the complex part you only have to do once. When it is there you have the ANT task you dreamed of.
- Arne
hm.. this sounds like fun!.. never created an ANT task
what are the redistribution rules for plain java libs?
Hi Chris,
Since not all builds are meant to be deployed, except if you have an automated test bench, I would suggest to open the build result of the public build, review it and then use the link "Create a work item for this build" to create the work item if it is supposed to be deployed. The work item will be automatically linked to the build result providing all necessary information for the release engineer. Why creating work items for builds that does not need deployment?
Since not all builds are meant to be deployed, except if you have an automated test bench, I would suggest to open the build result of the public build, review it and then use the link "Create a work item for this build" to create the work item if it is supposed to be deployed. The work item will be automatically linked to the build result providing all necessary information for the release engineer. Why creating work items for builds that does not need deployment?
Ah. I can see coming from an Ant centric mode of thinking, how you'd think this.
But in this case, it's a bad assumption.
We're using Maven, a somewhat more advanced/elegant tool.
It has the concepts of build _phases_. Compile, Package, Install (to a local maven repository) and deploy (to a remote maven repository - not an actual deployment of code into an environment).
We only use the deploy phase when performing a formal release (against a tag).
So, I'd tie the maven ant-run plugin (to execute said non-existant ant tasks) to the deploy phase, so that it only runs when performing a formal release. We only do this when we want to actually deploy the code into a non-dev environment, potentially all the way up to production.
So, in this way, I'd be removing manual processes, automating them, only crating the work items, when necessary.
Additionally, and this is the bit that really surprises me, is that I'd like to open a Defect Work Item against the developer broke the build. That would be something that could be done for each build etc. I hope you get the idea.
-Chris
But in this case, it's a bad assumption.
We're using Maven, a somewhat more advanced/elegant tool.
It has the concepts of build _phases_. Compile, Package, Install (to a local maven repository) and deploy (to a remote maven repository - not an actual deployment of code into an environment).
We only use the deploy phase when performing a formal release (against a tag).
So, I'd tie the maven ant-run plugin (to execute said non-existant ant tasks) to the deploy phase, so that it only runs when performing a formal release. We only do this when we want to actually deploy the code into a non-dev environment, potentially all the way up to production.
So, in this way, I'd be removing manual processes, automating them, only crating the work items, when necessary.
Additionally, and this is the bit that really surprises me, is that I'd like to open a Defect Work Item against the developer broke the build. That would be something that could be done for each build etc. I hope you get the idea.
-Chris
Hi Chris,
Since not all builds are meant to be deployed, except if you have an automated test bench, I would suggest to open the build result of the public build, review it and then use the link "Create a work item for this build" to create the work item if it is supposed to be deployed. The work item will be automatically linked to the build result providing all necessary information for the release engineer. Why creating work items for builds that does not need deployment?
Hi,
as already mentioned, as far as I know that ant task does not exist as far as http://publib.boulder.ibm.com/infocenter/clmhelp/v3r0m1/topic/com.ibm.team.build.doc/topics/r_ant-tasks.html goes. The WorkItemPublisher publishes the work items related to the changes to the build result.
You can easily use the Plain Java Client Library also called Plain Java API in some places to create a work item as mentioned already in the first answer. See here: https://jazz.net/wiki/bin/view/Main/ProgrammaticWorkItemCreation
The Plain Java Client Library can be downloaded from the all download pages e.g. https://jazz.net/downloads/rational-team-concert/releases/3.0.1.1/RTC-Client-plainJavaLib-3.0.1.1.zip
New is the API documentation: https://jazz.net/downloads/rational-team-concert/releases/3.0.1.1/RTC-Client-plainJavaLib-API-javadoc-3.0.1.1.zip
This is the code you want to use. It is only very basic but can be extended easily to add more attributes. The Extending Team concert forum is where this is discussed. There is also example code for how to set other work item attributes. You could also create a work item here https://jazz.net/jazz/web/projects/Rational%20Team%20Concert#action=com.ibm.team.workitem.viewWelcome in case you think this is essential. I agree it would be a nice ides so I looked for a work item, but did find only this https://jazz.net/jazz/web/projects/Rational%20Team%20Concert#action=com.ibm.team.workitem.viewWorkItem&id=34443 . I added your case.
as already mentioned, as far as I know that ant task does not exist as far as http://publib.boulder.ibm.com/infocenter/clmhelp/v3r0m1/topic/com.ibm.team.build.doc/topics/r_ant-tasks.html goes. The WorkItemPublisher publishes the work items related to the changes to the build result.
You can easily use the Plain Java Client Library also called Plain Java API in some places to create a work item as mentioned already in the first answer. See here: https://jazz.net/wiki/bin/view/Main/ProgrammaticWorkItemCreation
The Plain Java Client Library can be downloaded from the all download pages e.g. https://jazz.net/downloads/rational-team-concert/releases/3.0.1.1/RTC-Client-plainJavaLib-3.0.1.1.zip
New is the API documentation: https://jazz.net/downloads/rational-team-concert/releases/3.0.1.1/RTC-Client-plainJavaLib-API-javadoc-3.0.1.1.zip
This is the code you want to use. It is only very basic but can be extended easily to add more attributes. The Extending Team concert forum is where this is discussed. There is also example code for how to set other work item attributes. You could also create a work item here https://jazz.net/jazz/web/projects/Rational%20Team%20Concert#action=com.ibm.team.workitem.viewWelcome in case you think this is essential. I agree it would be a nice ides so I looked for a work item, but did find only this https://jazz.net/jazz/web/projects/Rational%20Team%20Concert#action=com.ibm.team.workitem.viewWorkItem&id=34443 . I added your case.
public class CreateWorkItem {
private static class LoginHandler implements ILoginHandler, ILoginInfo {
private String fUserId;
private String fPassword;
private LoginHandler(String userId, String password) {
fUserId= userId;
fPassword= password;
}
public String getUserId() {
return fUserId;
}
public String getPassword() {
return fPassword;
}
public ILoginInfo challenge(ITeamRepository repository) {
return this;
}
}
private static class WorkItemInitialization extends WorkItemOperation {
private String fSummary;
private ICategoryHandle fCategory;
public WorkItemInitialization(String summary, ICategoryHandle category) {
super("Initializing Work Item");
fSummary= summary;
fCategory= category;
}
@Override
protected void execute(WorkItemWorkingCopy workingCopy, IProgressMonitor monitor) throws TeamRepositoryException {
IWorkItem workItem= workingCopy.getWorkItem();
workItem.setHTMLSummary(XMLString.createFromPlainText(fSummary));
workItem.setCategory(fCategory);
}
}
public static void main(String[] args) {
boolean result;
TeamPlatform.startup();
try {
result= run(args);
} catch (TeamRepositoryException x) {
x.printStackTrace();
result= false;
} finally {
TeamPlatform.shutdown();
}
if (!result)
System.exit(1);
}
private static boolean run(String[] args) throws TeamRepositoryException {
if (args.length != 7) {
System.out.println("Usage: CreateWorkItem <repositoryURI> <userId> <password> <projectArea> <workItemType> <summary> <category>");
return false;
}
String repositoryURI= args[0];
String userId= args[1];
String password= args[2];
String projectAreaName= args[3];
String typeIdentifier= args[4];
String summary= args[5];
String categoryName= args[6];
ITeamRepository teamRepository= TeamPlatform.getTeamRepositoryService().getTeamRepository(repositoryURI);
teamRepository.registerLoginHandler(new LoginHandler(userId, password));
teamRepository.login(null);
IProcessClientService processClient= (IProcessClientService) teamRepository.getClientLibrary(IProcessClientService.class);
IAuditableClient auditableClient= (IAuditableClient) teamRepository.getClientLibrary(IAuditableClient.class);
IWorkItemClient workItemClient= (IWorkItemClient) teamRepository.getClientLibrary(IWorkItemClient.class);
URI uri= URI.create(projectAreaName.replaceAll(" ", "%20"));
IProjectArea projectArea= (IProjectArea) processClient.findProcessArea(uri, null, null);
if (projectArea == null) {
System.out.println("Project area not found.");
return false;
}
IWorkItemType workItemType= workItemClient.findWorkItemType(projectArea, typeIdentifier, null);
if (workItemType == null) {
System.out.println("Work item type not found.");
return false;
}
List path= Arrays.asList(categoryName.split("/"));
ICategoryHandle category= workItemClient.findCategoryByNamePath(projectArea, path, null);
if (category == null) {
System.out.println("Category not found.");
return false;
}
WorkItemInitialization operation= new WorkItemInitialization(summary, category);
IWorkItemHandle handle= operation.run(workItemType, null);
IWorkItem workItem= auditableClient.resolveAuditable(handle, IWorkItem.FULL_PROFILE, null);
System.out.println("Created work item " + workItem.getId() + ".");
teamRepository.logout();
return true;
}
}