Skip to main content

Arjuna is a Python based test automation framework developed by Rahul Verma (www.rahulverma.net).

Project description

Arjuna

Arjuna is a Python based test automation framework developed by Rahul Verma (www.rahulverma.net). Rahul has implemented smaller variants of features in Arjuna across frameworks and organizations, or given advise around it. However Arjuna being a generic library has the most complete implementation of his ideas, away from project specific contexts and constraints.

Arjuna uses pytest as its recommended test engine. Arjuna also provides its markup for some common use cases on top of pytest. If you like, you can make use of Arjuna with any other test engine or custom frameworks as well.

You'd need Python 3.5+ to make use of Arjuna.

Note: On Linux, the built-in Python3 build has issues with the Python's built-in enum module which is heavily used in Arjuna. One alternative is to install ActiveState Python on linux. Advanced users can go for installing a custom Python build.

Tutorial

1. Arjuna Installation

  1. Download and install latest Python (3.5+) from https://python.org
    • If you are insterested to learn python Following are links for tutorials and docs.
  2. Confirm the python version installed by running the command python --version. If expected version in not shown, fix this by looking into PATH variables and/or to see whether you have multiple versions of Python installed.
  3. Install Arjuna using the following command
    • pip install arjuna

You can find the example code in arjex project.

2. Arjuna - Getting Started

  1. Project Structure
  2. Writing Your First Test

3. Arjuna's Configuration System

  1. Configuration
  2. project.conf - Project Level Configuration
  3. Configuration Builder - Creating Custom Configurations
  4. Defining and Handling User Options
  5. Using .conf files with Configuration Builder
  6. The Magic C Function
  7. Environments and Dynamic Configurations

4. Data Driven Testing and Contextual Data References

  1. Data Driven Testing
  2. Driving with Single or Multiple Data Records
  3. Driving with Data Functions
  4. Driving with Data Classes
  5. Driving with Data Files
  6. Driving with Multiple Data Sources
  7. Contextual Data References and the Magic R Function
  8. Excel Data References

5. Localization of Strings

  1. Excel Localizer and The Magic L Function
  2. Json Localizer
  3. Strict vs Non-Strict Mode

6. Basic Web UI Automation

  1. Getting Started with WebApp
  2. Gui Element Locators - Using ID, Name, Tag, Class, Link Text, Partial Link Text
  3. Gui Element Locators - Using XPath
  4. Gui Element Locators - Using CSS Selectors
  5. Gui Element Locators - Using Arjuna's Locator Extensions
  6. Basic Interactions with a Gui Element
  7. Concise Basic Interactions with a Gui Element

7. Basics of Gui Namespace (GNS) - Externalizing Identifiers

  1. What is Gui Namespace (GNS)
  2. Externalizing ID, Name, Tag, Class, Link Text, Partial Link Text
  3. Externalizing XPath
  4. Externalizing CSS Selectors
  5. Externalizing Arjuna's Locator Extensions

8. Advanced Web UI Automation

  1. Matching Multiple Elements as GuiMultiElement
  2. Handling Default HTML Select
  3. Handling Default HTML Radio Group
  4. Finding Nested Elements
  5. Alternative and Dynamic Identifiers
  6. Executing JavaScript
  7. Alerts, Windows, Frames
  8. Configuraing Interactions with GuiInteractionConfig
  9. Handling Custom DropDowns
  10. Retrieving Source code with GuiSource

9. Advanced Gui Namespace Constructs

  1. Element Templates - Multi Element, Dropdown and Radio Group
  2. Creating Your Own intra-GNS identifiers
  3. Creating Your Own Global Identifiers for use in code as well as GNS files

10. Gui Abstraction - GNS, App, Page, Widget and Gui Elements

  1. Thinking Procedurally -Creating Reusable Module
  2. Creating App Class
  3. App Object Model
  4. App-Page Object Model
  5. App-Page-Section Object Model
  6. Gui and Its Loading Model in Arjuna

Reference

  1. Command Line Options

Miscellaneous

  1. Using Arjuna With Your Test Framework

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

arjuna-0.9.13.tar.gz (116.4 kB view details)

Uploaded Source

Built Distribution

arjuna-0.9.13-py3-none-any.whl (202.8 kB view details)

Uploaded Python 3

File details

Details for the file arjuna-0.9.13.tar.gz.

File metadata

  • Download URL: arjuna-0.9.13.tar.gz
  • Upload date:
  • Size: 116.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.6.5

File hashes

Hashes for arjuna-0.9.13.tar.gz
Algorithm Hash digest
SHA256 344c5291b83ec80d612ce4d5fb9c7b6f2c7bd1ad13d39a9f2ef863bbb8c7b642
MD5 b9610dc5b2cad8d34373d90287f0a851
BLAKE2b-256 907523ab6f7e46237e7b537ba8adb4d1a1716f3a2f55edfd4e554fa94c367897

See more details on using hashes here.

File details

Details for the file arjuna-0.9.13-py3-none-any.whl.

File metadata

  • Download URL: arjuna-0.9.13-py3-none-any.whl
  • Upload date:
  • Size: 202.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.6.5

File hashes

Hashes for arjuna-0.9.13-py3-none-any.whl
Algorithm Hash digest
SHA256 1a6034a02fb7f3b5daaf37a390ce1f3623297af8414e75e4b4b2ac3984e9aeef
MD5 81a5c8151eab2fb70a2e9054e3c7e5aa
BLAKE2b-256 705cf562a8325389233f1bddc90c8c92e94cbe092e76bcbda6e6f373a677fa3c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page