The following are some simple definitions and answers to Frequently-Asked-Questions the Core Team and OLE developers have been asked to define throughout the OLE Fspec process. Over time, we will continue to insert additional resources, tips and tricks to this list in response to SME's requests (Subject Matter Experts, i.e. OLE library staff members). To make suggestions for additional content to the FAQ, please email the Core Team at ole.core.team@kuali.org, or add comments through the [link] at the bottom of this page.
This page is under development and content is continuously being added and edited. Please click on any of the questions below to jump to the discussion thread. Many hyperlinks are also connected in the content, and where images are included, click on the image or illustration to see an enlarged view.
1. [What is an Fspec?]
2. [What is a User Story?]
3. [What do you include in a functional specification?]
4. [What about technical details? How do we account for system considerations?]
5. [How do I learn about the other Fspec teams? What other resources are available?]
6. [I have heard that OLE is being developed using Agile. What does that mean for OLE?]
7. [Is there training or help available for using Google Docs, Kuali email, and Google Calendars?]
1.What is an "Fspec"?">1. What is an "Fspec"?
An F-spec is a "functional specification", or a set of functional library requirements for a specific library process or set of related activities. In OLE, we are isolating our Fspecs per User Story in order to define a small, easily specified set of requirements.
2. What is a User Story?">2. What is a User Story?
A user story is a very small, succinct set of functionality written as "As a <role>, I want <action> so that <result>". Examples would be "As a library staff member I need to create a purchase order to order a book.", or, "As a budget officer, I need to modify the fund that is allocated to an account."
3. What do you include in a Functional Specification?">3. What do you include in a Functional Specification?
A functional specification can include many things, but focuses on a general description of the work to be done by library users, the data elements or documents affected, and any business rules for managing the work specified. The basic parts of a functional specification may include all or part of the following:
- User Story name, number: An abbreviated name for the user story and a master identifying number (from user story master list).
- Goal: This is the narrative of the user story in a single sentence.
- Summary: Think of the summary like an "abstract". It is a general summary of the completed functional specification in a single paragraph.
- Users: Users can be defined as any person, organization, or system that engages in this requirement or library function.
- Preconditions: Preconditions define all the conditions that must be true (i.e., describes the state of the system or the data or documentst) for the trigger to cause the initiation of the User Story.
- Triggers: Triggers describe the event (s) that cause the user story to be initiated
- Author, Date, Version: It is always a good practice to note the author or source and date of the last modification to this document.
- Notes: Include anything else you think we should think about that's not covered elsewhere. Remember: by using User Stories, we are attempting to describe very small pieces of work. Notes are just a place to provide side notes or questions for items of concern.
- Course of events- Workflows: A workflow can be described narratively or with a simple illustration of a decision tree/flowchart, with alternative paths and decision points that illustrates the workflow process executed by the User (first do this, then this, then based on a decision, go this way or that way). This is about the user and his or her work process, not dataflows. Think: do.
- Data & Dataflow diagrams: Where does data come from? What is/are required fields/user inputs? What happens to the data- provide a description of how it is transformed. What is the output- what document with what data should be provided at the end of this workflow? Notating or illustrating the dataflows involves describing 1) what data you start with, 2) describe what happens to it (transformations), and 3) what is the end-state of the data or documents involved in the User Story. Think: what document do I have at each step in the workflow, and what data/fields does the document contain?
- Data Models: The OLE data-modeling team has created draft data models and an ERD diagram (Entity-Relationship) for most of Select and Acquire, with some of the data fields defined for further OLE processes. Fspec teams are asked to evaluate the D/M and note any corrections to the assumptions in the model, or merely add any additional fields.
- Alternative paths- Workflows & Dataflows: OLE is interested in documenting the "happy path" or "80%" on workflows or dataflows. Not all universities share the same workflow processes, and we will be able to configure OLE in the future per each site's requirements. Alternative paths may already be included in the original workflow described, in the form of Yes/No decision paths, or alternate paths based on certain criteria (different formats, certain $$ amounts, who requesting,etc).
- Post-Conditions – Dataflows (documents): Post-conditions can be described in the data model and in the goals of this User Story. Think: what is the document or data I end with that I did not have in the beginning?
- Acceptance Criteria: What are the conditions of satisfaction for this user story? Acceptance criteria can be phrased in the form of a question and answer for the testers to use as a test-script to see if the designed system satisfactorily completes the actions specified in the User Story.
4. What about technical details? How do we account for system considerations?">4. What about technical details? How do we account for system considerations?
The specification teams are asked to note any details for technical implementation that they feel comfortable documenting, but the Core Team and Developers are responsible for completing technical detail with the team and/or Technical Council representative through Q&A. Details for Technical Specifications or requirements may include:
- GUI preferences: TBD - List of fields where user can enter information. Where can the user go from here? What should results screen contain?
- Business Rules (Authentication/Authorization): Can insert overview of access (read, write, edit, delete, create, approve).
- Terminology: Description & definitions of domain-specific terminology as to be familiar to stakeholders, and to standardize on language for documentation & testing.
- Functional Details: Can include details about data interfaces, standards, & sources (i.e. use NCIP to populate user record in transactional datastore), interactivity of function (i.e. user-driven function or automated function), security requirements, validation requirement, initial state information (i.e. populate form from document directory based on resource id), etc
- Acceptance Testing: Per acceptance criteria above, these may be scenarios or tests that can be applied to determine successful outcome of this process.
- Implementation Details: Additional details on programming, Rice, KIM, routines, system interfaces.
- Vendor/System interfaces: This is where we can note any known vendor or system interfaces for dataflows, workflows, financial/university systems.
- Sample Data Sets: For each group of related user stories, Fspec teams may be requested to provide document samples (sample P.O., sample MARC record) and raw sets of sample data (for ingest and varied data standards).
5. How do I learn about the other Fspec Teams? What other resources are available?">5. How do I learn about the other Fspec Teams? What other resources are available?
Kuali OLE has multiple, simultaneous spec teams working at all times, in order to create an inventory or backlog of specifications ahead of their assignment to scheduled sprints for the developers. By drafting Fspecs in advance, we can organize coding in a logical or sequential fashion, and allow plenty of time for Q&A with spec teams to ensure high-quality development of OLE functionality. Below illustrates the organization and cooperation of our teams and resources. More information on overall OLE teams can be found here, or SME's may review the list of Fspec teams and resources.
There are many SMEs available to the Fspec teams, whether it be the Core Team or developers, or members of the Functional or Technical Councils. We also recommend Fspec teams utilize additional resources or expertise within their own libraries - - these are the best resources for understanding library process and ensuring OLE is developed as a fully-functioning, reliable, and comprehensive library management system.
6. I have heard that OLE is being developed using Agile. What does that mean for OLE?">6. I have heard that OLE is being developed using Agile. What does that mean for OLE?
The Kuali Open Library Environment project is intended to be developed utilizing an Agile project and software development model. It is characterized by collaboration, adaptation, and efficiency. Teams are to be self-organizing. Development is focused on innovation and incremental "builds" of code and function. Agile is believed to result in higher-quality technical solutions and less lag time, as work is defined into small, incremental units of functionality easily coded within two week sprints. Our exact method is probably a hybrid of traditional or waterfall development methods and agile, but we seek to blend the best practices of Agile development and scrum into our approach.
6. Is there training or help available for using Google Docs, Kuali email, and Google Calendars?">6. Is there training or help available for using Google Docs, Kuali email, and Google Calendars?
There are several tools available to users of Google Docs, Kuali email, and the Google Calendars used by Kuali OLE to manage our team documentation, communications and scheduling.
Google Docs: The
<A href="http://docs.google.com/support/?ctx=ausers&hl=en" mce_href="http://docs.google.com/support/?ctx=ausers&hl=en" target="_Blank">help center</A>
offers video tutorials, formatting assistance and discussion threads to answer common questions. Below are some tips for common OLE tasks too.
Older Version vs. Newer Version: Google Docs now defaults to a page view disliked by many. You may click on the quick link in the upper right corner of the GoogleDocs window to restore the "older version" view which allows easing sorting on column headings (to alphabetically sort documents, or sort on date oldest or newest.
Page Refresh: Google Docs will sometimes show only partial lists of documents. It's particularly frustrating when you know a document is in the file. Please click on your browser's refresh button to see a full folder view.
Mapping Folders: When you first open Google Docs, your left menu will not display any OLE file folders -only those owned by you. In order to map OLE folders into your "My Folders", please use these
<A href="https://docs.google.com/a/kuali.org/document/d/1HnMR2GIQAuk_CfzVK_giK2bO327MKebKhDtmC6El8Z8/edit?hl=en" mce_href="https://docs.google.com/a/kuali.org/document/d/1HnMR2GIQAuk_CfzVK_giK2bO327MKebKhDtmC6El8Z8/edit?hl=en" target="_Blank">instructions</A>
to map the OLE project folders. You only have to do this once, and then Google Docs navigation will be much easier.
Sharing Documents or Folders: When creating a new document, Google Docs sometimes defaults to a saved location in your personal space "Owned by me". Likewise, when uploading documents, the default setting is "private" and will also load to your personal folders. If you've accidentally loaded or saved files to your personal folders, you may drag and drop them into the correct folder. Documents will generall inherit the permissions of the parent folder they reside in. However, if you need to make sure that everyone who need to see the document you've created, please check the box next to the file, and click on button/menu above to select Share>Sharing Settings. First seach the list of people and groups who already have "Sharing", and then you may enter email addresses or KIS OLE distribution listes in the "Add People" box to share your document or file. Before clicking on the "share" button at the bottom of the pop-up window, be sure to select whether you want the people you are adding to edit (default) or merely be able to view document. GoogleDocs also defaults to "send email notification", so you'll want to uncheck that box if you do not want an email to go out to all the people or groups you've added. Similarly, in this same pop-up window, you may delete or edit groups from seeing your document if you wish to make it private.
Real-time editing & sharing: Google Docs provides real-time sharing of documents. When multiple users have a document open, you can see other users edits highlighted with different colored cursors in the document. If you see a "sharing" window in the upper right of an open document, you can click the down-arrow to the right of the name to see all those users logged into the docment. With this expanded right sidebar, you can enter into chat in the comments box too.
Unable to render embedded object: File (collapse.jpg) not found.Collapse or Hide Controls: On the view menu, you can increase your screen's view vertically by selecting "collapse controls" and "hide controls" to eliminate the uppermost Google headers and menus and give you more screen view of the open document.
Google Calendar: Please refer to the online
<A href="http://www.google.com/support/calendar/?ctx=ausers&hl=en" mce_href="http://www.google.com/support/calendar/?ctx=ausers&hl=en" target="_Blank">Calendar help center</A>
for tutorials and discussion threads. You may also create additional calendars, or access other Kuali OLE Team calendars. Open one of the linked OLE calendars, and click on the +Google Calendar button in its lower right corner to add it to your "Other Calendars" view. It is especially helpful if you add the
<A href="http://www.google.com/calendar/embed?src=kuali.org_irbnb4cc85emckj1868r6749c0%40group.calendar.google.com&ctz=America/New_York" mce_href="http://www.google.com/calendar/embed?src=kuali.org_irbnb4cc85emckj1868r6749c0%40group.calendar.google.com&ctz=America/New_York" target="_Blank">OLE Scheduling Calendar</A>
or your spec team's calendar to your personal calendar window, so that you may schedule activities, or copy meetings from one calendar to another. Note: if you set up a meeting in a team calendar, you cannot send from it unless you are authorized. It is often easier to setup a meeitng in your own calendar and mail an invite to the distribution email of the team.For the
<A href="http://www.google.com/calendar/embed?src=kuali.org_irbnb4cc85emckj1868r6749c0%40group.calendar.google.com&ctz=America/New_York" mce_href="http://www.google.com/calendar/embed?src=kuali.org_irbnb4cc85emckj1868r6749c0%40group.calendar.google.com&ctz=America/New_York" target="_Blank">OLE Scheduling Calendar</A>
r, you can reserve conference lines, but not invite attendees (the message may show up in invitee's Kuali inbox, but these invites direct from Team calendars often to not forward to your primary mail client.
Kuali Email: Everyone in Kuali that has KIS credentials will also have a Kuali email address ([\_____@kuali.org (mailto:_____@kuali.org)]). You may synch your Kuali email with your primary email client by using the help center for your specific application. Please note: some scheduling notifications or calendar reminders that originate in your Kuali calendar and email may not forward to your primary email client. Be aware of this and check your Kuali email periodically.