Skip to content
Tellurium Automated Testing Framework
JavaScript Java
Find file
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Failed to load latest commit information.




             Tellurium Team (



The Tellurium Automated Testing Framework (Tellurium) is a UI module-based automated testing framework for web
applications. The UI module is a collection of UI elements you group together. Usually, the UI module represents
a composite UI object in the format of nested basic UI elements. For example, the Google search UI module can be
expressed as follows,

ui.Container(uid: "GoogleSearchModule", clocator: [tag: "td"], group: "true"){
   InputBox(uid: "Input", clocator: [title: "Google Search"])
   SubmitButton(uid: "Search", clocator: [name: "btnG", value: "Google Search"])
   SubmitButton(uid: "ImFeelingLucky", clocator: [value: "I'm Feeling Lucky"])

The UI module makes it possible to build UI elements' locators at run time. The framework does Object to Locator
Mapping (OLM) automatically at run time so that you can define UI objects simply by their attributes, i.e., Composite
Locators denoted by the "clocator". Furthermore, Tellurium uses the Group Locating Concept (GLC) to exploit
information inside a collection of UI components to help finding their locators and the GLC is denoted by the "group"
attribute in the above UI module.

The Tellurium framework defines a new Domain Specific Language (DSL) for web testing. Still take the above Google
search module as an example, you can use the following DSLs to do a Google search,

type "GoogleSearchModule.Input", "Tellurium test"
click "GoogleSearchModule.Search"
waitForPageToLoad 30000

One very powerful feature of Tellurium is that you can use UI templates to represent many identical UI elements or
dynamic size of different UI elements at runtime, which are extremely useful to test dynamic web such as a data grid.
One typical data grid example is as follows,

ui.Table(uid: "table", clocator: [:]){
   InputBox(uid: "{row: 1, column: 1} as Input", clocator: [:])
   Selector(uid: "{row: all, column: 2}", clocator: [:])
   UrlLink(uid: "{row: 3, column: all}", clocator: [:])
   TextBox(uid: "{row: all, column: all}", clocator: [:])

Data Driven Testing is another important feature of Tellurium. You can define data format in an expressive way.
In you data file, you can specify which test you want to run, the input parameters, and expected results. Tellurium
automatically binds the input data to variables defined in your test script and run the tests you specified in the
input file. The test results will be recorded by a test listener and output in different formats, for example,
an XML file.

Tellurium UI Model Plugin (TrUMP) is a Firefox plugin to automatically create UI modules for users. In addition,
Tellurium provides you the capability to composite UI objects into a Tellurium widget object. You can pack Tellurium
widgets as a jar file and then use a Tellurium widget just like a single tellurium UI object once you include the
jar file. As a result, Tellurium is robust, expressive, flexible, and reusable.

The Tellurium framework is written in Groovy and Java. The test cases can be written in Java, Groovy, or pure DSL.
You do not really need to know Groovy before you use it because the UI module definition and actions on UIs are
written in DSLs and the rest could be written in Java syntax. Tellurium also supports JUnit and TestNG. Detailed
Introduction, User Guide, Frequent Asked Questions, and illustrative examples are provided.

Your feedback and comments are very important to us. Please post your comments and suggestions on Tellurium user
group or write directly to us.



Tellurium Project Home

Tellurium User Group

Tellurium Developer Group

Tellurium on Twitter



    * 2010-04-14, Tellurium is on GitHub now
    * 2010-04-13, Tellurium 0.7.0 RC2 is Available Now
    * 2010-04-05, Tellurium UID Description Language prototype is done
    * 2010-03-10, is up and running
    * 2010-03-04, Run Tellurium Integration Tests with Maven Cargo Plugin
    * 2010-02-15, Disclose UI Module APIs in Tellurium 0.7.0.
    * 2010-02-11, Tellurium 0.7.0 RC1 is Available Now
    * 2010-02-10, Santa: The Tellurium UI Module Group Locating Algorithm
    * 2010-02-08, Tellurium UI Module Visual Effect
    * 2010-01-28, Tellurium is on Vimeo now.
    * 2010-01-22, Added new wiki guide How to create your own Tellurium testing project with IntelliJ 9.0 Community Edition.
    * 2010-01-15, What's New in Tellurium 0.7.0 is updated to track changes in 0.7.0.
    * 2009-12-02, Tellurium was presented at Rich Web Experience 2009.
    * 2009-11-22, Welcome Harihara Vinayakaram to our team.
    * 2009-11-20, IRC Channel #tellurium is Available Now.
    * 2009-10-10, Tellurium Facebook Group has been created and you are welcome to join.
    * 2009-09-20, Special thanks to Davlyn Jones, the Tellurium user guide 0.6.0 is officially released now.
    * 2009-09-18, Special thanks to Jared Rawlinson, Tellurium has a new project logo now.
    * 2009-09-09, Please poll where did you find Tellurium.
    * 2009-08-18, Welcome Kamal Ahmed to our team.
    * 2009-08-15, Welcome Mahendra Kariya and Ajay Ravichandran to our team.
    * 2009-07-27, The first draft of Tellurium User Guide is available now. You can download the pdf file from here.
    * 2009-07-15, Welcome Kevin Zhang to our team.
    * 2009-07-09, Welcome Davlyn Jones and Ramesh Ramamurthy to our team.
    * 2009-06-26, Tellurium was presented at CodeStock 2009.
    * 2009-06-26, Tellurium is on Twitter and Reddit now.
    * 2009-06-24, Tellurium celebrates its first anniversary. Please read the article, Tellurium First Anniversary: Retrospect and Prospect.
    * 2009-06-23, Added a video demo Tellurium beginner tutorial.
    * 2009-06-21, Welcome Jeff Xiong to our Team.
    * 2009-06-18, Tellurium 0.6.0 is released, please see the announcement.
    * 2009-06-12, Tellurium creator, Dr. Jian Fang, was interviewed by InfoQ China.
    * 2009-06-10, Tellurium Chinese Document project is created.
    * 2009-05-13, Tellurium Core and reference projects 0.6.0 RC1 are out, Please see the announcement.
    * 2009-05-10, Added Tellurium 0.6.0 feature introduction: Whats New in Tellurium 0.6.0
    * 2009-04-28, Tellurium provides Selenium Grid support
    * 2009-04-23, Tellurium Automated Testing Framework LinkedIn Group has been created and you are welcome to join.
    * 2009-04-14, Tellurium starts to support jQuery selector.
    * 2009-03-15, tutorial 10 Minutes to Tellurium is created and it includes a wiki page, presentation slides, and a screencast video.
    * 2009-03-13, two Tellurium Maven archetypes are available, i.e., tellurium-junit-archetype and tellurium-testng-archetype for Tellurium JUnit and TestNG project, respectively.
    * 2009-03-04, Tellurium UI Module Firefox Plugin (TrUMP) 0.1.0 is released
    * 2009-02-18, Tellurium UI Module Firefox Plugin (TrUMP) 0.1.0 Release Candidate is available
    * 2009-02-17, Tellurium Demo Videos are uploaded, you can use VLC media player to watch them
    * 2009-01-29, Tellurium UI Module Firefox Plugin (TrUMP) 0.1.0 preview version is available
    * 2008-12-03, Tellurium core 0.5.0 and reference projects are released
    * 2008-12-02, Welcome Mikhail Koryak to our team.
    * 2008-11-15, Tellurium 0.5.0 Release Candidate RC01 is out
    * 2008-08-22, Welcome Haroon Rasheed to our team.
    * 2008-08-13, Tellurium 0.4.0 is released and this release includes a lot of new features and enhancements such as data driven testing, framework configuration, and JUnit 4 support.
    * 2008-07-29, The AOST framework is officially renamed to the Tellurium Automated Testing framework (Tellurium).
    * 2008-07-29, Welcome Matt Senter to our team.
    * 2008-07-18, Welcome Vivek Mongolu to our team.
    * 2008-07-18, AOST user group is created. Please join and post your questions, comments, and suggestions there.
    * 2008-07-12, AOST 0.3.0 is out and it comes with significant feature enhancement including Composite Locator, Group Locating Concept, and Multiple UI Modules in one DslContext?.
    * 2008-07-02, UI Object ID is refactored to support nested UI objects.
    * 2008-06-25, The AOST framework became public with version 0.2.0.
    * 2008-01-01, the AOST framework second prototype was created.
    * 2007-06-01, the AOST framework first prototype was created.
Something went wrong with that request. Please try again.