Quantcast
Channel: Hacker News
Viewing all articles
Browse latest Browse all 25817

TA.Gui – A tool for non-developers and business users to automate web apps

$
0
0

README.md

TA.Gui is a tool for non-developers and business users to automate web apps

Sample Automation Flow

Above video shows a sample automation flow to automate mass account registrations (record, edit, play)

Automate repetitive parts of your work - use cases include data acquisition, process and test automations of web apps. TA.Gui is open-source software released under the MIT license, that means you can freely use, modify or share it.

FEATURES

  • natural language with JavaScript support
  • Chrome extension for recording steps
  • headless (invisible) and visible mode
  • repositories for reusable objects
  • datatables for batch automation
  • auto-wait for element to interact
  • dynamic XPath/CSS element selector
  • run by schedule, command line, REST API
  • support outgoing API calls to webservices
  • cross-platform (macOS/Linux; Windows soon)

HOW IT WORKS

TA.Gui converts your intentions in simple natural language into lines of working JavaScript code for CasperJS & PhantomJS to cast their web automation magic. As an example, TA.Gui will instantly convert the automation flow below into 100+ lines of JavaScript code and perform the sequence of steps to download a Typeform report automatically.

https://www.typeform.com
click login
type username as user@gmail.com
type password as 12345678
click btnlogin
hover Test Event
click action results tooltip
click section_results
download https://admin.typeform.com/form/2592751/analyze/csv to report.csv

The automation flow can be triggered from scheduling, command line, URL, REST API, email etc. Everything happens headlessly in the background without seeing any web browser, so you can continue using the computer or server uninterrupted. Running on a visible web browser is supported, using Firefox and SlimerJS (see firefox option below). Outgoing API calls can be made with a single line to integrate with other downstream applications.

If you know JavaScript coding and want to be more expressive, you can even use JavaScript directly in the flow. If not, you will still enjoy friendly but powerful features such as repositories to store your reusable objects, datatables for batch automation, and a Chrome extension which creates automation flows by recording your actions.

Originally developed by a test automation engineer to avoid writing code to automate web-based interactions.

TA.Gui is in beta version (v0.6.0) and runs on macOS/Linux (coming to Windows soon)

  1. install CasperJS (navigation/testing for PhantomJS) - http://casperjs.org
  2. install PhantomJS (headless scriptable web browser) - http://phantomjs.org
  3. install TA.Gui (friendly lightning fast automation tool) - https://git.io/vMCTZ

Optional - configure web browser settings in tagui_config.txt (browser resolution, step timeout of 10s etc)

COMMAND LINE

./tagui flow_filename option(s)
  • Automation flow filename can have no extension, .gui or .txt file extension
  • Objects, keywords, datatables can be defined in flow_filename.csv (optional)
OptionPurpose
firefoxrun on visible Firefox browser (first install Firefox, and SlimerJS - https://slimerjs.org)
reportgenerate a web report for easy sharing of run results (default is only a text log file)
debugshow run-time backend messages from PhantomJS for detailed tracing and logging
testprofessional testing using CasperJS assertions; TA.Gui XPath tx('selector') usable

BY SCHEDULING

To schedule an automation flow in crontab, for example at 8am daily

0 8 * * * /full_path_on_your_server/tagui flow_filename option(s)

CHROME EXTENSION

Prior to public release, to use TA.Gui Chrome web browser extension for recording automation flows, type chrome://extensions in Google Chrome, then drag and drop TA.Gui chrome folder into the browser. TA.Gui Chrome extension is based on Resurrectio tool and records steps such as page navigation, clicking web elements and entering information. To start recording and exporting your automation flows, simply click TA.Gui icon on your Chrome toolbar.

TA.GUI WORKFLOW

What happens behind the scenes when you run an automation flow

TA.Gui Flowchart

To feedback bugs or suggestions, kindly email support@tebel.org

FeaturePurpose
Microsoft Friendlysupport running on Microsoft Windows
Enhancementsfeel free to review and suggest new features

STEPS DESCRIPTION

  • TA.Gui auto-waits for a webpage element to appear and interacts with it as soon as it appears
  • Element identifier can be auto-recorded using TA.Gui Chrome extension, or found from web browser
  • TA.Gui auto-checks identifier XPath in this order - full-xpath, full-css, id, name, class, title, text()
StepParameters (separator in bold)Purpose
tap / clickelement to clickclick on an element
hover / moveelement to hovermove cursor to element
type / enterelement to type as text to typeenter element as text
read / fetchelement to read to variable namefetch text to variable
show / printelement to readprint element text to output
echotext (in quotation marks) and variablesprint text/variables to output
downloadurl to download to filename to savedownload url to file
receiveurl keyword to watch to filename to savereceive resource to file
saveelement to read to optional filenamesave text to file
dumpvariable name to optional filenamesave variable to file
snapelement (page = webpage) to optional filenamesave screenshot to file
waitoptional time in seconds (default is 5 seconds)explicitly wait for some time
checkcondition to check | text if true | text if falsecheck condition and print result
frameframe name | subframe name if anynext step in frame/subframe
apifull url (including parameters) of api callcall api and print response
//user comments (ignored during execution)add user comments

CONDITIONS EXAMPLES

  • Conditions can be expressed in natural language (optional brackets) or JavaScript
  • JavaScript can be used (CasperJS's context) - if/for/while applies to the next step
Condition (in natural language)JavaScript
for example - if A more than B and C not equal to Dif (A > B && C != D)
for example - while cupcakes equal to 12while (cupcakes == 12)
more than or equal to / greater than or equal to / higher than or equal to>=
less than or equal to / lesser than or equal to / lower than or equal to<=
more than / greater than / higher than>
less than / lesser than / lower than<
not equal to!=
equal to==
and&&
or||

REPOSITORIES

  • Repositories help to make objects or steps reusable and improve readability
  • Save repository file with same name as your flow filename and with .csv behind
  • Repository must have 2 columns, for example below (headers up to you to name)
  • Using `object` in your flow replaces it with its definition (which can contain objects)
  • For example, `type email` becomes type user-email-textbox as user@gmail.com
OBJECTDEFINITION
emailuser-email-textbox
create accountbtn btn--green btn-xl signup-btn
type emailtype `email` as user@gmail.com

DATATABLES

  • Datatables extend the power of repositories files to manage batch automation
  • Datatable has 2 or more columns, for example below (headers up to you to name)
  • Data-centric approach with rows representing data fields (usually row = test case)
  • TA.Gui loops through each column to automate using values from different datasets
  • Eg, echo "TESTCASE - `testname`" in your flow shows TESTCASE - Trade USDSGD
TEST TRADESTEST #1TEST #2TEST #3
testnameTrade USDSGDTrade USDJPYTrade EURUSD
usernametest_accounttest_accounttest_account
password123456781234567812345678
currency-pairUSDSGDUSDJPYEURUSD
size100001000100000
directionBUYSELLBUY

TESTING (for QA folks and test automation engineers)

The step check allows simple testing of conditions. For professional test automation, CasperJS comes with a tester module for unit and functional testing purpose. To use the advanced testing features, run TA.Gui with the test option.

CasperJS test scripts are inherently different in structure and syntax from its usual automation scripts. With the test option, TA.Gui automatically converts your automation flow to work as a test script and output a XUnit XML file, which is compatible with continuous integration tools such as Jenkins. Running together with the report option outputs a web report of the test execution for easy sharing.

TA.Gui allows you to reuse the same flow for testing or automation by running it with or without the test option. Below are examples of CasperJS test assertions written in JavaScript code that can be used directly in your automation flow (after navigating and taking desired actions using usual flow steps etc).

test.assertTextExists('About Tebel.Automation','Check for About Tebel.Automation text');test.assertSelectorHasText(tx('header'), 'interface automation','Check for phrase in header element');

For the list of expressive test assertions built into CasperJS, click here. To know more about CasperJS testing framework, click here. As TA.Gui allows you to write JavaScript code directly within the automation flow, advanced testing or coding techniques that can be implemented in CasperJS should be able to be work directly within your automation flow.

TA.Gui recognizes most JavaScript code. In the rare event you get an error saying that it cannot understand the step for your JavaScript line, kindly raise an issue or feel free to modify the source code (tagui_parse.php is where interpretation of natural language to CasperJS JavaScript code takes place). Alternatively, you can use the undocumented step js to explicitly declare that whatever follows on that line is JavaScript code.

TA.GUI API (for developers and the curious ones)

Automation flows can also be triggered via REST API. TA.Gui has an API service and runner for managing a queue of incoming requests via API. To setup, add a crontab entry on your server with the desired frequency to check and process incoming service requests. For example, the following job will check every 15 minutes and run pending flows in the queue.

0,15,30,45 * * * * /full_path_on_your_server/tagui_crontab

To call an automation flow from your application or web browser, use below API syntax. Automation flows can also be triggered from emails using the API. For email integration, install TA.Mail, an open-source mailbot to act on incoming emails or perform mass emailing.

your_website_url/tagui_service.php?SETTINGS="flow_filename option(s)"

Besides integrating with web applications, TA.Gui can be extended to integrate with hardware (for example Arduino or Raspberry Pi) for physical world interactions or machine learning service providers for fuzzy decision-making capacity.

For making outgoing API calls in your automation flow, to feed data somewhere or send emails etc, use the api step followed by full URL (including parameters) of the API call. Response from the API will be printed to output. For example using TA.Mail, emails can be sent directly from your flow with a single line.

File ReferencePurpose
taguimain runner for TA.Gui automation
tagui_config.txtweb browser settings used for automation
tagui_crontabto run service request batch from crontab
tagui_footer.jsfooter template for CasperJS code
tagui_header.jsheader template for CasperJS code
tagui_parse.phpto interpret natural language into code
tagui_report.phpto generate html report from text log
tagui_runner.phpretrieving service requests from queue
tagui_service.phpreceiving service requests into queue
tagui_service.inlog to track incoming service requests
tagui_service.outlog to track processed service requests
tagui_service.loglog to track service requests history
tagui_service.actservice request batch ready to execute
tagui_service.runservice request batch currently running
tagui_service.doneservice request batch finished running

TA.Gui is open-source software released under the MIT license


Viewing all articles
Browse latest Browse all 25817

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>