\documentclass[10pt,a4paper]{article} % Packages \usepackage{fancyhdr} % For header and footer \usepackage{multicol} % Allows multicols in tables \usepackage{tabularx} % Intelligent column widths \usepackage{tabulary} % Used in header and footer \usepackage{hhline} % Border under tables \usepackage{graphicx} % For images \usepackage{xcolor} % For hex colours %\usepackage[utf8x]{inputenc} % For unicode character support \usepackage[T1]{fontenc} % Without this we get weird character replacements \usepackage{colortbl} % For coloured tables \usepackage{setspace} % For line height \usepackage{lastpage} % Needed for total page number \usepackage{seqsplit} % Splits long words. %\usepackage{opensans} % Can't make this work so far. Shame. Would be lovely. \usepackage[normalem]{ulem} % For underlining links % Most of the following are not required for the majority % of cheat sheets but are needed for some symbol support. \usepackage{amsmath} % Symbols \usepackage{MnSymbol} % Symbols \usepackage{wasysym} % Symbols %\usepackage[english,german,french,spanish,italian]{babel} % Languages % Document Info \author{Mpie (mpie)} \pdfinfo{ /Title (selenium-webdriver-js-for-cucumber-js.pdf) /Creator (Cheatography) /Author (Mpie (mpie)) /Subject (Selenium webdriver js for cucumber js Cheat Sheet) } % Lengths and widths \addtolength{\textwidth}{6cm} \addtolength{\textheight}{-1cm} \addtolength{\hoffset}{-3cm} \addtolength{\voffset}{-2cm} \setlength{\tabcolsep}{0.2cm} % Space between columns \setlength{\headsep}{-12pt} % Reduce space between header and content \setlength{\headheight}{85pt} % If less, LaTeX automatically increases it \renewcommand{\footrulewidth}{0pt} % Remove footer line \renewcommand{\headrulewidth}{0pt} % Remove header line \renewcommand{\seqinsert}{\ifmmode\allowbreak\else\-\fi} % Hyphens in seqsplit % This two commands together give roughly % the right line height in the tables \renewcommand{\arraystretch}{1.3} \onehalfspacing % Commands \newcommand{\SetRowColor}[1]{\noalign{\gdef\RowColorName{#1}}\rowcolor{\RowColorName}} % Shortcut for row colour \newcommand{\mymulticolumn}[3]{\multicolumn{#1}{>{\columncolor{\RowColorName}}#2}{#3}} % For coloured multi-cols \newcolumntype{x}[1]{>{\raggedright}p{#1}} % New column types for ragged-right paragraph columns \newcommand{\tn}{\tabularnewline} % Required as custom column type in use % Font and Colours \definecolor{HeadBackground}{HTML}{333333} \definecolor{FootBackground}{HTML}{666666} \definecolor{TextColor}{HTML}{333333} \definecolor{DarkBackground}{HTML}{26729E} \definecolor{LightBackground}{HTML}{F1F6F8} \renewcommand{\familydefault}{\sfdefault} \color{TextColor} % Header and Footer \pagestyle{fancy} \fancyhead{} % Set header to blank \fancyfoot{} % Set footer to blank \fancyhead[L]{ \noindent \begin{multicols}{3} \begin{tabulary}{5.8cm}{C} \SetRowColor{DarkBackground} \vspace{-7pt} {\parbox{\dimexpr\textwidth-2\fboxsep\relax}{\noindent \hspace*{-6pt}\includegraphics[width=5.8cm]{/web/www.cheatography.com/public/images/cheatography_logo.pdf}} } \end{tabulary} \columnbreak \begin{tabulary}{11cm}{L} \vspace{-2pt}\large{\bf{\textcolor{DarkBackground}{\textrm{Selenium webdriver js for cucumber js Cheat Sheet}}}} \\ \normalsize{by \textcolor{DarkBackground}{Mpie (mpie)} via \textcolor{DarkBackground}{\uline{cheatography.com/29519/cs/8677/}}} \end{tabulary} \end{multicols}} \fancyfoot[L]{ \footnotesize \noindent \begin{multicols}{3} \begin{tabulary}{5.8cm}{LL} \SetRowColor{FootBackground} \mymulticolumn{2}{p{5.377cm}}{\bf\textcolor{white}{Cheatographer}} \\ \vspace{-2pt}Mpie (mpie) \\ \uline{cheatography.com/mpie} \\ \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Cheat Sheet}} \\ \vspace{-2pt}Published 25th July, 2016.\\ Updated 26th July, 2016.\\ Page {\thepage} of \pageref{LastPage}. \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Sponsor}} \\ \SetRowColor{white} \vspace{-5pt} %\includegraphics[width=48px,height=48px]{dave.jpeg} Measure your website readability!\\ www.readability-score.com \end{tabulary} \end{multicols}} \begin{document} \raggedright \raggedcolumns % Set font size to small. Switch to any value % from this page to resize cheat sheet text: % www.emerson.emory.edu/services/latex/latex_169.html \footnotesize % Small font. \begin{tabularx}{17.67cm}{x{3.454 cm} x{13.816 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{17.67cm}}{\bf\textcolor{white}{Fetching a Page}} \tn % Row 0 \SetRowColor{LightBackground} {\bf{Method}} & {\bf{Example}} \tn % Row Count 2 (+ 2) % Row 1 \SetRowColor{white} get() & \seqsplit{this.driver.get('http://www.google.com');} \tn % Row Count 4 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{Getting text values}} \tn \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{var element = \seqsplit{this.driver.findElement(this.driver.By.id('elementID'));} \newline % Row Count 2 (+ 2) \seqsplit{element.getText().then(text} =\textgreater{} console.log('Text is '));% Row Count 4 (+ 2) } \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{x{2.8679 cm} x{6.9167 cm} x{7.0854 cm} } \SetRowColor{DarkBackground} \mymulticolumn{3}{x{17.67cm}}{\bf\textcolor{white}{Finders}} \tn % Row 0 \SetRowColor{LightBackground} {\bf{Method}} & {\bf{Example}} & {\bf{Purpose}} \tn % Row Count 2 (+ 2) % Row 1 \SetRowColor{white} \seqsplit{findElement(by)} & this.driver.findElement(\{id: 'MyId'\}); & Finds the first element located by the provided method. \tn % Row Count 6 (+ 4) % Row 2 \SetRowColor{LightBackground} \seqsplit{findElements(by)} & this.driver.findElements(\{id: 'MyId'\}); & Finds all elements located by the provided method. \tn % Row Count 10 (+ 4) \hhline{>{\arrayrulecolor{DarkBackground}}---} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{x{2.1931 cm} x{8.6037 cm} x{6.0732 cm} } \SetRowColor{DarkBackground} \mymulticolumn{3}{x{17.67cm}}{\bf\textcolor{white}{Moving Between Windows and Frames}} \tn % Row 0 \SetRowColor{LightBackground} {\bf{Method}} & {\bf{Example}} & {\bf{Purpose}} \tn % Row Count 2 (+ 2) % Row 1 \SetRowColor{white} \seqsplit{window()} & \seqsplit{this.driver.switchTo().window('windowName');} & moving between named windows \tn % Row Count 5 (+ 3) % Row 2 \SetRowColor{LightBackground} \seqsplit{frame()} & \seqsplit{this.driver.switchTo().frame('frameName');} & moving between named frames \tn % Row Count 8 (+ 3) \hhline{>{\arrayrulecolor{DarkBackground}}---} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{x{3.0366 cm} x{6.9167 cm} x{6.9167 cm} } \SetRowColor{DarkBackground} \mymulticolumn{3}{x{17.67cm}}{\bf\textcolor{white}{Locating UI Elements}} \tn % Row 0 \SetRowColor{LightBackground} {\bf{Method}} & {\bf{Example}} & {\bf{Shorthand}} \tn % Row Count 2 (+ 2) % Row 1 \SetRowColor{white} id() & \seqsplit{this.driver.findElement(this.driver.By.id('MyId'));} & this.driver.findElement(\{id: 'MyId'\}); \tn % Row Count 6 (+ 4) % Row 2 \SetRowColor{LightBackground} \seqsplit{className()} & \seqsplit{this.driver.findElement(this.driver.By.className('MyClassName'));} & this.driver.findElement(\{className: 'MyClassName'\}); \tn % Row Count 11 (+ 5) % Row 3 \SetRowColor{white} \seqsplit{tagName()} & \seqsplit{this.driver.findElement(this.driver.By.tagName('img'));} & this.driver.findElement(\{tagName: 'img'\}); \tn % Row Count 15 (+ 4) % Row 4 \SetRowColor{LightBackground} name() & \seqsplit{this.driver.findElement(this.driver.By.name('username'));} & this.driver.findElement(\{name: 'username'\}); \tn % Row Count 19 (+ 4) % Row 5 \SetRowColor{white} \seqsplit{linkText()} & \seqsplit{this.driver.findElement(this.driver.By.linkText('click} here!')); & this.driver.findElement(\{linkText: 'click here!'\}); \tn % Row Count 23 (+ 4) % Row 6 \SetRowColor{LightBackground} \seqsplit{partialLinkText()} & \seqsplit{this.driver.findElement(this.driver.By.partialLinkText('here'));} & this.driver.findElement(\{partialLinkText: 'here'\}); \tn % Row Count 27 (+ 4) % Row 7 \SetRowColor{white} css() & \seqsplit{this.driver.findElement(this.driver.By.css('\#food} span.dairy.aged')); & this.driver.findElement(\{css: '\#food span.dairy.aged'\}); \tn % Row Count 32 (+ 5) \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{x{3.0366 cm} x{6.9167 cm} x{6.9167 cm} } \SetRowColor{DarkBackground} \mymulticolumn{3}{x{17.67cm}}{\bf\textcolor{white}{Locating UI Elements (cont)}} \tn % Row 8 \SetRowColor{LightBackground} \seqsplit{xpath()} & \seqsplit{this.driver.findElement(this.driver.By.xpath('//input'));} & this.driver.findElement(\{xpath: '//input'\}); \tn % Row Count 4 (+ 4) \hhline{>{\arrayrulecolor{DarkBackground}}---} \SetRowColor{LightBackground} \mymulticolumn{3}{x{17.67cm}}{always use lowercase in your xpath} \tn \hhline{>{\arrayrulecolor{DarkBackground}}---} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{x{5.2297 cm} x{5.9045 cm} x{5.7358 cm} } \SetRowColor{DarkBackground} \mymulticolumn{3}{x{17.67cm}}{\bf\textcolor{white}{WebElement Methods}} \tn % Row 0 \SetRowColor{LightBackground} {\bf{Method}} & {\bf{Example}} & {\bf{Purpose}} \tn % Row Count 1 (+ 1) % Row 1 \SetRowColor{white} clear() & this.driver.findElement(\{id: 'submit'\}).clear(); & Clears all of the contents if the element is a text entity. \tn % Row Count 6 (+ 5) % Row 2 \SetRowColor{LightBackground} click() & this.driver.findElement(\{id: 'submit'\}).click(); & Simulates a mouse click on the element. \tn % Row Count 10 (+ 4) % Row 3 \SetRowColor{white} \seqsplit{getAttribute()} & this.driver.findElement(\{id: 'submit'\}).getAttribute('name'); & Returns the value associated with the provided attribute name (if present) or null (if not present). \tn % Row Count 18 (+ 8) % Row 4 \SetRowColor{LightBackground} \seqsplit{getTagName()} & this.driver.findElement(\{id: 'submit'\}).getTagName(); & Returns the tag name for this element. \tn % Row Count 22 (+ 4) % Row 5 \SetRowColor{white} getText() & this.driver.findElement(\{id: 'submit'\}).getText(); & Returns the visible text contained within this element (including subelements) if not hidden via CSS. \tn % Row Count 30 (+ 8) \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{x{5.2297 cm} x{5.9045 cm} x{5.7358 cm} } \SetRowColor{DarkBackground} \mymulticolumn{3}{x{17.67cm}}{\bf\textcolor{white}{WebElement Methods (cont)}} \tn % Row 6 \SetRowColor{LightBackground} getValue() & this.driver.findElement(\{id: 'submit'\}).getValue(); & Gets the value of the element's "value" attribute. \tn % Row Count 5 (+ 5) % Row 7 \SetRowColor{white} isEnabled() & this.driver.findElement(\{id: 'submit'\}).isEnabled(); & Returns true for input elements that are currently enabled; otherwise false. \tn % Row Count 11 (+ 6) % Row 8 \SetRowColor{LightBackground} \seqsplit{isSelected()} & this.driver.findElement(\{id: 'submit'\}).isSelected(); & Returns true if the element (radio buttons, options within a select, and checkboxes) is currently selected; otherwise false. \tn % Row Count 21 (+ 10) % Row 9 \SetRowColor{white} \seqsplit{sendKeys(CharSequence…} keysToSend) & this.driver.findElement(\{id: 'submit'\}).sendKeys(this.webdriver.Key.ENTER); & Simulates typing into an element. \tn % Row Count 27 (+ 6) % Row 10 \SetRowColor{LightBackground} \seqsplit{setSelected()} & this.driver.findElement(\{id: 'submit'\}).setSelected(); & Select an element (radio buttons, options within a select, and checkboxes). \tn % Row Count 33 (+ 6) \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{x{5.2297 cm} x{5.9045 cm} x{5.7358 cm} } \SetRowColor{DarkBackground} \mymulticolumn{3}{x{17.67cm}}{\bf\textcolor{white}{WebElement Methods (cont)}} \tn % Row 11 \SetRowColor{LightBackground} submit() & \{id: 'submit'\}).submit(); & Submits the same block if the element is a form (or contained within a form). Blocks until new page is loaded. \tn % Row Count 9 (+ 9) % Row 12 \SetRowColor{white} toggle() & this.driver.findElement(\{id: 'submit'\}).toggle(); & Toggles the state of a checkbox element. \tn % Row Count 13 (+ 4) \hhline{>{\arrayrulecolor{DarkBackground}}---} \end{tabularx} \par\addvspace{1.3em} \end{document}