Skip to content
This repository was archived by the owner on Nov 26, 2024. It is now read-only.
/ django-testhook Public archive

Template tag to enable testhook attributes on HTML elements.

License

Notifications You must be signed in to change notification settings

jjanssen/django-testhook

Folders and files

NameName
Last commit message
Last commit date

Latest commit

author
Janneke Janssen
May 17, 2017
7caa8ce · May 17, 2017

History

27 Commits
May 17, 2017
Jun 11, 2016
Jun 11, 2016
Apr 7, 2017
Jun 11, 2016
Jun 12, 2016
Jun 11, 2016
Jun 12, 2016
Apr 7, 2017
Jun 12, 2016
Jun 12, 2016
Apr 7, 2017

Repository files navigation

django-testhook

A Django template tag to enable testhook attributes on HTML elements.

https://travis-ci.org/jjanssen/django-testhook.svg?branch=master https://coveralls.io/repos/jjanssen/django-testhook/badge.svg?branch=master

About django-testhook

The django-testhook provides a template tag to generate data-testhook-id for HTML templates.

This can be useful for automated testing (for eg: Webdriver.IO) to maintain a fixed entry point, rather than having a automated test that breaks by just renaming a CSS class or an element which can require you to re-evaluate an XPath-selector.

Requirements

Django 1.8.x or greater, Python 2.7 or greater.

Installation

Install django-testhook with pip:

$ pip install django-testhook

Configuration

Configuring django-testhook

Add the following to your settings file:

INSTALLED_APPS += (
    'testhook',
)

Available settings

By default the rendering of testhook data attributes is enabled. If you are in the scenario you want to disable it for a certain environment just configure it to False.

TESTHOOK_ENABLED = False

Usage

Basic usage

Within your HTML template you must load the testhook tag in order to use it. The testhook tag only requires a single argument in order to return a result.

{% load testhook %}

<div class="my-elem" {% testhook "test-elem" %}>
    I want to test this
</div>

This will output to the following:

<div class="my-elem" data-testhook-id="test-elem">
    I want to test this
</div>

Object Usage

For dynamic elements there is also the option to pass arguments. For eg: given I have a product in a shopping basket with a primary key and a slug I could use it like this:

<div class="item" {% testhook "basket" product.id product.slug %}>
    {{ product.title }}
</div>

It will output to:

<div class="item" data-testhook-id="basket-1-product-slug">
    A product title
</div>