TieFlow Process Editor CAPSTONE TEAM # 2 03/04/2009CSCI Spring 2009
Team Information Vishal Jadhav. Major: Computer Science Role: Team Leader/ Webmaster/Programmer Doyle Rodrigues. Major: Computer Science. Role: Documentation/ Researcher/Programmer Shardul Kale. Major: Computer Science Role: Programmer/ Tester/Documentation Pratik Zirpe. Major: Computer Science. Role:Programmer/Reseach er/Tester
Instructor and mentor Instructor Dr. Alfredo Perez- Davila Associate Professor Computer Science and Computer Information Systems. Mentor Scott Hetherington Tietronix Software, Inc. onix.com onix.com
Agenda Overview of the Company Introduction Background Problem Definition Requirements Resources Time Based Simulation Design Flowchart Deficiencies and Solutions Work Done Work to be Done
Overview of the Company Tietronix Software, Inc. was founded in 1999 by Victor W. Tang, Michel E. Izygon and Stuart S. Engelhardt. Tietronix is a full-service provider of custom software applications and advanced technology solutions. Tietronix’s mission: First to develop reliable software and technology solutions that solve customers’ problems on time and on budget. secondly, to apply technologies developed for NASA to commercial markets.
Introduction What is Workflow? A workflow is a automation of business process within which information, tasks or jobs are passed from one entity to another. Some Examples Credit Card application processing. Product design and development.
Existing Application TieFlow Workflow Toolkit TieFlow Workflow Toolkit is a web based electronic workflow system. Used to automate manual form based process. Major Function Create, display, modify process definition in XML. Workflow engine uses XML process definitions to load database tables to execute peocess. Current uses NASA's Flight Director's Office uses the same for its Flight Rules Change Request (FRCR) Process to electronically submit and review changes to the flight rules used during missions.
Problem Definition Removal of current deficiencies present in Tieflow process Editor. Problems related to reading and writing process definition XML files. Errors in editor user interface design. Failure of removing certain elements defined in process definition. Features to be added Ability to reuse the same process as a sub-process multiple times. Provide functionality to create copies of processes in the editor. Refine and improve simulation wizard.
Requirements The editor shall use the Xalan/Xerces XML parsers. The project shall introduce no third party dependencies. The editor does not handle the read and load of the Workflow User element. The editor does not handle the read and load of the ActivitiesInstancies Assignees element.
Requirements Cont.. The editor shall be able to read, load and save the creator tag properly. The editor shall use the id values that are already defined. The editor shall be able to support the concept of Dynamic repeat The Editor shall be able to remove the address that it stores to send a notification. The editor currently shows the properties panel of the parent element when the roles notification element is selected. The property panel should be blank.
Requirements Cont.. The editor shall allow the creation of transitions between sub-processes. The Editor shall allow the user to create a copy of the entire process. ▫ The copied process shall have a name as a new process would have. ▫ All elements of the process shall be copied. ▫ All elements shall have new unique “id” attribute values.
Requirements Cont.. The Editor shall provide a summary view of the resources assignments, start conditions, etc ▫The summary view shall be displayed whether defining or loading a simulation. ▫The save simulation shall be moved to the summary view screen. The Time based simulation shall be a wizard type flow of dialogs. ▫Each page shall have back and next button ▫The wizard shall have no pop-ups except for browsing a file.
Requirements Cont.. The Editor shall support a process if it has unequal AND joins and AND splits. The Assign resources dialog shall be redesigned to support the following properties. Shall allow assignments previously made to be removed. Shall allow the users to easily see current resources.
Resources Hardware Software J2SE 1.5 Eclipse 3.4.1
Time Based Simulation What is Time-Based simulation ? Problems with the GUI of current application o Haphazard dialogbox structure o No modifications to resource assignments to roles o Display of resource assignments is not easily comprehensible o Can not show all the starting conditions for a simulation before report
Editor ScreenShot
Approach to solution Create wizard like interface Facility to modify resource assignments More understandable view of resource assignments Create a summary view showing all the conditions/values for simulation Facility to go back from Summary view and change the setting
Load or Define Simulation Choose option Get the simulation(xml) Load or Define Resource Define resource and assign them to roles Assignments can be changed A Choose startup Get Resource B C Schedule Recurrent load define load define D
Get starting specifications C option cancel To D Summary View option back To A save Final Report Saved as xml end
Choose simulation Define simulation and schedule requirements B Load xml and setup conditions option load define back Summary View back option Change goto A cancel Report end
Deficiencies.. TieFlow Editor allows the user to right-click on the Address element and select Remove, but the element is not removed. Also TieFlow Editor allows the user to right-click on the ActivityInstanceAssignees element and select Remove, but the element is not removed.
Solution # 1 The removeFromParent() is the method that is called to initiate the removal process. The problem with the Activity Instance Assignee and address element was that they or any of their inherited classes did not have a overridden method for removeFromParent(). Element Activity Instance Assignee is inherited from ElementActivityInstance which didn’t have any overridden method for removefromParent ().
Solution #1 Cont.. So we have added a new overridden method for removeFromParent () in the ElementActivity Instance class. The definition is same as in the workflowuseratribute.java Now when the removeFromParent() function is called it executes the newly written method and the element is now getting removed.
Solution # 2 In the Address Problem it was inherited from the default base class for package elements i.e. DefaultPackageElement. We have now made address to extend WorkFlowUserAttribute instead of Default Package Element. Therefore on the removeFromParent function call the function in the WorkFlowUserAttribute is being called and not base class method and hence address element is now getting removed.
Work Done.. We have fixed the Activity Instance Assignee and Address Bug present in the editor. We have also finished with design of the simulation wizard to be developed. We have completed the Software Requirements Specification Document for the project. We have devised a project plan to decide who and when will be working on the bugs.
Work Done Cont.. We have spend more time in understanding the editor ▫Understanding and analyzing the relationships existing between various source files and classes ▫Developing a strategy and plan to encounter and cope with the bugs. ▫Deciding on the Best Integration Development Environment for the usage of editor. We generated Javadocs for the Editor using Eclipse..
Work to be done We have to fix deficiencies in the editor related to XML Reading/Writing. We also need to fix few of the problems in the user interface. We need to design refined and easy to use simulation wizard for the time-based simulation in editor.
THANK YOU!! ' ANY QUESTIONS??