Concordion

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search
Concordion
Concordion-logo-web-green.png
Developer(s) Concordion Organization
Stable release
2.1.0 / March 12, 2017 (2017-03-12)
Written in Java, .NET
Operating system Cross-platform
Type Specification by example tool
License Apache License 2.0
Website concordion.org

Concordion is a specification by example framework originally developed by David Peterson,[1] and now maintained by a team of contributors,[2] led by Nigel Charman.

Inspired by the Fit Framework, David states the following aims were behind Concordion:[3]

  • Improved readability of documents
  • More "opinionated" (scripting is actively discouraged)
  • Easier to use

How it works[edit]

Concordion specifications are written in Markdown, HTML or Excel[4] and then instrumented with special links, attributes or comments respectively. When the corresponding test fixture class is run, Concordion interprets the instrumentation to execute the test. Rather than forcing product owners to specify requirements in a specially structured language, Concordion lets you write them in normal language using paragraphs, tables and proper punctuation. This makes the specifications much more natural to read and write, and helps everyone to understand and agree about what a feature is supposed to do.[5]

The Markdown, HTML or Excel files are typically stored with the source code, which has the benefit that they can be under the same version control system as the rest of the code ensuring the specification and tests are branched and merged along with the main source code.

Concordion includes a flexible extension mechanism[6] for adding functionality, for example implementing new commands, listening to events, or modifying the output documentation. By providing functionality such as embedding screenshots,[7] storyboards[8] or logging output,[9] extensions provide confidence in what the test is doing without locking the test into a specific implementation.[10]

Concordion enriches agile processes[11][12] and has been successfully applied in industrial context.[13]

Example[edit]

Markdown format specification[edit]

HelloWorld.md

Before instrumentation

The greeting for World is Hello World!

HelloWorld.md

After instrumentation

The greeting for [World](- "#name") is [Hello World!](- "?=greetingFor(#name)")

HTML format specification[edit]

HelloWorld.html
Before instrumentation
<html>
    <body>
        <p>The greeting for <b>World</b> is <b>Hello World!</b></p>
    </body>
</html>
HelloWorld.html
After instrumentation
<html xmlns:concordion="http://www.concordion.org/2007/concordion">
    <body>
        <p>The greeting for <b concordion:set="#name">World</b> is
        <b concordion:assertEquals="greetingFor(#name)">Hello World!</b>
        </p>
    </body>
</html>
HelloWorldTest.java
The fixture that works with the instrumentation
package org.wikipedia;

import org.concordion.integration.junit4.ConcordionRunner;
import org.junit.runner.RunWith;

@RunWith(ConcordionRunner.class)
public class HelloWorldTest {

    public String greetingFor(String firstName) {
        return "Hello " + firstName + "!";
    }
}

Integrated Development Environment Support[edit]

The Concordion Support plugin for the IntelliJ IDEA Integrated development environment (IDE) simplifies development of fixtures and specifications with features including autocompletion, navigation between spec and test fixture, renaming, running tests, inspections and quick fixes.[14]

The Eclipse (software) Concordion plugin is much more limited and hasn't been updated since 2011.[15] The original author has stopped using Concordion and Eclipse and is unable to accommodate the necessary time to extend and maintain the plugin.[16]

Ports[edit]

Concordion has been ported to other languages including:

References[edit]

  1. ^ Gärtner, Markus (Jul 2012). ATDD by Example: A Practical Guide to Acceptance Test-Driven Development. Addison-Wesley Professional. ISBN 0321784154. 
  2. ^ "concordion". GitHub. Retrieved 2016-09-04. 
  3. ^ "Concordion FAQ". Retrieved May 2, 2011. .
  4. ^ "concordion/concordion-excel-extension". GitHub. Retrieved 2016-09-04. 
  5. ^ Riley, Tim; Goucher, Adam (October 2009). Beautiful Testing: Leading Professionals Reveal How They Improve Software. O'Reilly Media. p. 350. ISBN 0596159811. 
  6. ^ "Concordion | Extensions | Java". concordion.org. Retrieved 2016-09-04. 
  7. ^ "concordion/concordion-screenshot-extension". GitHub. Retrieved 2016-09-04. 
  8. ^ "concordion/concordion-storyboard-extension". GitHub. Retrieved 2016-09-04. 
  9. ^ "concordion/concordion-logback-extension". GitHub. Retrieved 2016-09-04. 
  10. ^ "David Peterson: Concordion Extensions". blog.davidpeterson.co.uk. Retrieved 2016-09-04. 
  11. ^ Besson, Felipe M.; Beder, Delano M.; Chaim, Marcos L. (June 2010). "An Automated Approach for Acceptance Web Test Case Modeling and Executing". Agile Processes in Software Engineering and Extreme Programming. 11th International Conference on Agile Software Development, XP 2010. Trondheim, Norway: Springer Berlin Heidelberg. pp. 160–165. 
  12. ^ Kamalrudin, Massila; Sidek, Safiah; Moketar, Nor Aiza; Robinson, Mark (2013). "Automated Acceptance Testing Tools Evaluation in Agile Software Development". Science International. Publications International Lahore, Pakistan. ISSN 1013-5316 (CODEN: SINTE 8): 1053–58. 
  13. ^ Latorre, Latorre (2014-06-01). "A successful application of a Test-Driven Development strategy in the industrial environment". Empirical Software Engineering. Springer US. 19 (3): 753–773. doi:10.1007/s10664-013-9281-9. 
  14. ^ "concordion/idea-concordion-support". GitHub. Retrieved 2016-09-04. 
  15. ^ "Google Code Archive - Long-term storage for Google Code Project Hosting". code.google.com. Retrieved 2016-09-04. 
  16. ^ "Google Groups". groups.google.com. Retrieved 2016-09-04. 

External links[edit]