Category: 

What is a Functional Specification?

Article Details
  • Written By: R. Kimball
  • Edited By: Jenn Walker
  • Last Modified Date: 10 September 2016
  • Copyright Protected:
    2003-2016
    Conjecture Corporation
  • Print this Article
Free Widgets for your Site/Blog
In late 19th-century London, mail was delivered to residential addresses up to twelve times each day.   more...

September 28 ,  1924 :  Two US military planes complete the first flights around the world.  more...

A functional specification describes the basic functions of a software application. It is generally developed as part of the requirements analysis in software development. It serves as a blue print for the programmers to develop source code and test cases for the application.

Generally, there are many different players involved in the requirements analysis for developing each software application. These players include the business people expected to use the software, the data analysts, programmers and other technical staff. The business people explain to the other members of the team exactly what they expect from software to do, from a business perspective.

Business requirements are merged with the data that needs to be captured and is used to develop the way the team would like each of the screens to function. All of this requirements analysis must be completed in order to document the functional specification. Once the functional specification is roughly documented, the team works to fine tune it. The team reviews these documents and fills in any gaps in the requirements analysis. After the requirements analysis is complete, the team approves the functional specification. The approved specification document is used as a blueprint for software development.

Ad

Source code and test cases are developed using the functional specification. Team members use the functional specification to develop the test cases needed to confirm that the software functions as specified. The number of test cases used to debug the software varies based upon the complexity of the software developed. As the programmers develop the software, another part of the team develops the test cases. The testing process to approve the software begins once the programmers advise the team it is ready to be tested.

The functional specification does not specify such things as the software language to be used by the programmers. The specifications found within a functional specification are limited to the true functions of the program. The specification document explains what happens when a program user clicks on a specific button on the screen but not how the programmer is going to make the specific function occur.

Depending upon the complexity of the software to be developed, some teams use multiple levels of functional specification documents. The management team might participate in the specification of high-level functions while a group of senior analysts might define in greater detail the specific functions and a joint team of business analysts and programmers may define each screen. Each of the output documents from these levels may be considered a functional specification.

Ad

You might also Like

Recommended

Discuss this Article

Post your comments

exception 'Exception' with message 'error writing captcha: Duplicate entry '2147483647' for key 'PRIMARY'' in /ssd/www/wisegeek/public_html/_core/classes/public/Captcha.php:44
Stack trace:
#0 /ssd/www/wisegeek/public_html/_core/controls/public/ControlDiscussionPostBox.php(324): Captcha->createCaptcha()
#1 /ssd/www/wisegeek/public_html/framework/classes/Control.php(104): ControlDiscussionPostBox->preRender(false)
#2 /ssd/www/wisegeek/public_html/framework/classes/Control.php(149): Control->render()
#3 /ssd/www/wisegeek/public_html/tpl/default-nocustom-lu/pages/public/article/article.htm(526): Control->__toString()
#4 /ssd/www/wisegeek/public_html/framework/classes/Control.php(300): require('/ssd/www/wisege...')
#5 /ssd/www/wisegeek/public_html/framework/classes/Control.php(309): Control->requireTpl('pages/public/ar...', Object(PageArticleCom), true)
#6 /ssd/www/wisegeek/public_html/framework/classes/Control.php(131): Control->renderTpl('pages/public/ar...', Object(PageArticleCom))
#7 /ssd/www/wisegeek/public_html/framework/classes/FormDataControl.php(87): Control->renderTemplate()
#8 /ssd/www/wisegeek/public_html/framework/classes/Control.php(109): FormDataControl->renderTemplate()
#9 /ssd/www/wisegeek/public_html/framework/classes/ScriptPage.php(50): Control->render(false)
#10 /ssd/www/wisegeek/public_html/framework/classes/Control.php(149): ScriptPage->render()
#11 /ssd/www/wisegeek/public_html/framework/classes/Page.php(97): Control->__toString()
#12 /ssd/www/wisegeek/public_html/_core/classes/public/PublicFrontController.php(443): Page->processRequest()
#13 /ssd/www/wisegeek/public_html/_core/classes/public/PublicFrontController.php(7): PublicFrontController->renderPage()
#14 /ssd/www/wisegeek/public_html/index.php(11): PublicFrontController::run()
#15 {main}