etaoin icon indicating copy to clipboard operation
etaoin copied to clipboard

Pure Clojure Webdriver protocol implementation

image::art/pattern-small.jpg[]

= Etaoin :toclevels: 4 :project-src-coords: clj-commons/etaoin :project-mvn-coords: etaoin/etaoin :url-webdriver: https://www.w3.org/TR/webdriver/ :url-short-story: https://archive.org/details/Unknown_v05n05_1942-02_slpn/page/n66/mode/1up :url-doc: https://cljdoc.org/d/{project-mvn-coords} :url-slack: https://clojurians.slack.com/messages/C7KDM0EKW/

// Badges link:{url-doc}[image:https://cljdoc.org/badge/{project-mvn-coords}[cljdoc]] https://github.com/{project-src-coords}/actions/workflows/test.yml[image:https://github.com/{project-src-coords}/actions/workflows/test.yml/badge.svg[GitHub Actions Tests]] https://clojars.org/{project-mvn-coords}[image:https://img.shields.io/clojars/v/{project-mvn-coords}.svg[Clojars project]] https://babashka.org[image:https://raw.githubusercontent.com/babashka/babashka/master/logo/badge.svg[bb compatible]] https://clojurians.slack.com/archives/C7KDM0EKW[image:https://img.shields.io/badge/slack-join_chat-brightgreen.svg[Join chat]]

A pure Clojure implementation of the link:{url-webdriver}[Webdriver] protocol, named after link:{url-short-story}[Etaoin Shrdlu] -- a typing machine that came to life after a mysterious note was produced on it.

Use the Etaoin library to automate a browser, test your frontend behaviour, simulate human actions or whatever you want.

== Benefits

  • Selenium-free: no big dependencies, no tons of downloaded jars, etc.
  • Lightweight, fast. Simple, easy to understand.
  • Compact: just one main namespace with a couple of helpers.
  • Declarative: the code is just a list of actions.

== Capabilities

  • Currently supports Chrome, Firefox, Safari and Edge.
  • Can either connect to a remote WebDriver process, or have Etaoin launch one for you.
  • Run your unit tests directly from Emacs by pressing C-t t as usual.
  • Can imitate human-like behaviour (delays, typos, etc).

== Documentation

API docs and articles are best viewed on link:{url-doc}[cljdoc]:

  • link:doc/01-user-guide.adoc[User Guide]
  • link:doc/02-developer-guide.adoc[Developer Guide]

See also:

:ui-test: http://grishaev.me/en/ui-test :stream: https://www.youtube.com/watch?v=cLL_5rETLWY

  • link:{url-slack}[Slack channel]
  • link:{ui-test}[Thoughts on UI tests] Ivan's blog-post about pitfalls that can occur when testing UI.
  • link:{stream}[Live-coding session] where Ivan works through some Etaoin issues.

== Who uses Etaoin?

Some companies:

  • https://www.exoscale.com/[Exoscale]
  • https://www.flyerbee.com/[Flyerbee]
  • http://www.barrick.com/[Barrick Gold]
  • http://drevidence.com/[Doctor Evidence]
  • https://kevel.com/[Kevel (formerly Adzerk)]
  • https://www.rate.com/[Guaranteed Rate]

Some examples usages:

  • Control a https://github.com/DaniruKun/spacex-iss-docking-sim-autopilot[SpaceX ISS Docking Simulator].
  • Automatically https://github.com/babashka/book/blob/9853d7ed1d72b328e30342f546071cd450035a3f/script/watch.clj[watch/refresh] the browser when making edits to https://book.babashka.org/[Babashka book].
  • Generate contributor badges for https://github.com/clj-commons/rewrite-clj#people[rewrite-clj], https://github.com/cljdoc/cljdoc#contributors[cljdoc] and https://github.com/lread/test-doc-blocks#people[test-doc-blocks] via a https://github.com/clj-commons/rewrite-clj/blob/1795a71b7f8937a1482cf63de7f8dd90579c2007/script/doc_update_readme.clj[doc-update-readme babashka task].
  • https://github.com/borkdude/re-find.web/blob/1a2cc409b2f2791324798f6e1adb13efc244b3e2/test/re_find/web_test.clj[Test browser behavior] for https://borkdude.github.io/re-find.web/[re-find.web].
  • https://github.com/quil/quil/blob/1f214e712d834ede311fdc652eafe9cc0232c96e/test/clj/quil/snippet.clj#L159[Test browser interactions] for https://github.com/quil/quil[Quil].
  • https://github.com/jarcane/clojurice/blob/96f6af795636903b543b9f29aaea586c49a776c6/test/clj/app/test/integration.clj[Integration tests] for https://github.com/jarcane/clojurice[clojurice].

You are most welcome to submit your company or project to this list.

== Versioning

Eatoin uses: major.minor.patch-test-qualifier

  • major increments when a non alpha release API has been broken - something, as a rule, we'd like to avoid.
  • minor increments to convey significant new features have been added.
  • patch indicates bug fixes or minor changes - it is the total number of releases to date.
  • test-qualifier is absent for stable releases. Can be alpha, beta, rc1, etc.

== People

=== Contributors

  • https://github.com/Uunnamed[Alexey Shipilov]
  • https://github.com/AdamFrey[Adam Frey]
  • https://github.com/jwkoelewijn[JW Koelewijn]
  • https://github.com/nenadalm[Miloslav Nenadál]
  • https://github.com/atsman[Aleh Atsman]
  • https://github.com/marco-m[Marco Molteni]
  • https://github.com/nebesnytihohod[Maxim Stasenkov]
  • https://github.com/daveyarwood[Dave Yarwood]
  • https://github.com/jkrasnay[John Krasnay]
  • https://github.com/kidd[Raimon Grau]
  • https://github.com/verma[Uday Verma]
  • https://github.com/mjmeintjes[Matt Meintjes]

=== Current Maintainers

  • https://github.com/lread[Lee Read]
  • https://github.com/borkdude[Michiel Borkent]

=== Founder

  • https://github.com/igrishaev[Ivan Grishaev]

Etaoin is open for your improvements and ideas. If any of unit tests fail on your machine, please submit an issue giving your OS version, browser and console output.

== License

Copyright © 2017—2020 Ivan Grishaev.

Distributed under the Eclipse Public License either version 1.0 or (at your option) any later version.