\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{Adil Iqbal (aiqbal)} \pdfinfo{ /Title (cypress-io.pdf) /Creator (Cheatography) /Author (Adil Iqbal (aiqbal)) /Subject (Cypress.io 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}{34A389} \definecolor{LightBackground}{HTML}{F2F9F7} \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{Cypress.io Cheat Sheet}}}} \\ \normalsize{by \textcolor{DarkBackground}{Adil Iqbal (aiqbal)} via \textcolor{DarkBackground}{\uline{cheatography.com/122942/cs/23087/}}} \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}Adil Iqbal (aiqbal) \\ \uline{cheatography.com/aiqbal} \\ \uline{\seqsplit{www}.adil-iqbal.com} \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Cheat Sheet}} \\ \vspace{-2pt}Published 3rd June, 2020.\\ Updated 3rd June, 2020.\\ 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{multicols*}{2} \begin{tabularx}{8.4cm}{x{1.6 cm} x{6.4 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{Context and Hooks}} \tn % Row 0 \SetRowColor{LightBackground} \seqsplit{describe} & group \& label tests + manage context \& hooks \tn % Row Count 2 (+ 2) % Row 1 \SetRowColor{white} it & label a test block \tn % Row Count 3 (+ 1) % Row 2 \SetRowColor{LightBackground} before & hook that runs {\bf{before all}} tests in context/describe \tn % Row Count 5 (+ 2) % Row 3 \SetRowColor{white} after & hook that runs {\bf{after all}} tests in context/describe \tn % Row Count 7 (+ 2) % Row 4 \SetRowColor{LightBackground} \seqsplit{beforeEach} & hook that runs {\bf{before each}} tests in context/describe \tn % Row Count 9 (+ 2) % Row 5 \SetRowColor{white} \seqsplit{afterEach} & hook that runs {\bf{after each}} tests in context/describe \tn % Row Count 11 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}--} \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{Context docs: \seqsplit{https://mochajs.org/\#bdd} \newline Hooks docs: \seqsplit{https://mochajs.org/\#hooks}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{x{2 cm} x{6 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{.should \& Common Chainers}} \tn % Row 0 \SetRowColor{LightBackground} {\bf{.should}} & command used for asserting tests. \{\{link="https://docs.cypress.io/api/commands/should.html"\}\}(docs)\{\{/link\}\} \tn % Row Count 4 (+ 4) % Row 1 \SetRowColor{white} \seqsplit{"have.class"} & check for class \tn % Row Count 6 (+ 2) % Row 2 \SetRowColor{LightBackground} \seqsplit{"have.css"} & check for CSS style \tn % Row Count 7 (+ 1) % Row 3 \SetRowColor{white} \seqsplit{"be.visible"} & check if visible. \{\{link="https://docs.cypress.io/guides/core-concepts/interacting-with-elements.html\#Visibility"\}\}(docs)\{\{/link\}\} \tn % Row Count 12 (+ 5) % Row 4 \SetRowColor{LightBackground} "exist" & check if element exists \tn % Row Count 13 (+ 1) % Row 5 \SetRowColor{white} \seqsplit{"have.length"} & checks for number of matching elements \tn % Row Count 15 (+ 2) % Row 6 \SetRowColor{LightBackground} \seqsplit{"have.value"} & checks the value of input field \tn % Row Count 17 (+ 2) % Row 7 \SetRowColor{white} \seqsplit{"be.checked"} & checks for state of radio or checkbox \tn % Row Count 19 (+ 2) % Row 8 \SetRowColor{LightBackground} \seqsplit{"contains"} & checks value within opening and closing tags. \tn % Row Count 21 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}--} \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{Only some common chainers have been included here. \newline https://docs.cypress.io/guides/references/assertions.html} \tn \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{x{2.4 cm} x{5.6 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{Utility Commands}} \tn % Row 0 \SetRowColor{LightBackground} cy.log & log comment to command log \tn % Row Count 1 (+ 1) % Row 1 \SetRowColor{white} cy.fixture & yeilds fixture \{\{link="https://docs.cypress.io/api/commands/fixture.html"\}\}(docs)\{\{/link\}\} \tn % Row Count 5 (+ 4) % Row 2 \SetRowColor{LightBackground} .then( callback ) & work with yeilded subject \tn % Row Count 7 (+ 2) % Row 3 \SetRowColor{white} .wait & wait a certain amount of ms \{\{link="https://docs.cypress.io/api/commands/wait.html"\}\}(docs)\{\{/link\}\} \tn % Row Count 11 (+ 4) % Row 4 \SetRowColor{LightBackground} .pause & stop testing at certain point \tn % Row Count 13 (+ 2) % Row 5 \SetRowColor{white} .then( callback ) & work with yeilded subject \tn % Row Count 15 (+ 2) % Row 6 \SetRowColor{LightBackground} .screenshot & take a screenshot of state of DOM \tn % Row Count 17 (+ 2) % Row 7 \SetRowColor{white} .debug & print debug info to the console \tn % Row Count 19 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{x{1.76 cm} x{6.24 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{Selection Commands}} \tn % Row 0 \SetRowColor{LightBackground} cy.get & select based on HTML tag attrs \tn % Row Count 1 (+ 1) % Row 1 \SetRowColor{white} \seqsplit{cy.contains} & select based value within opening and closing tags \tn % Row Count 3 (+ 2) % Row 2 \SetRowColor{LightBackground} .first & select first matching element \tn % Row Count 4 (+ 1) % Row 3 \SetRowColor{white} .last & select last matching element \tn % Row Count 5 (+ 1) % Row 4 \SetRowColor{LightBackground} .next & select next matching element \tn % Row Count 6 (+ 1) % Row 5 \SetRowColor{white} .prev & select previous matching element \tn % Row Count 8 (+ 2) % Row 6 \SetRowColor{LightBackground} \seqsplit{.parents} & select parent of element \tn % Row Count 9 (+ 1) % Row 7 \SetRowColor{white} \seqsplit{.children} & select child of element \tn % Row Count 11 (+ 2) % Row 8 \SetRowColor{LightBackground} \seqsplit{.siblings} & select sibling of element \tn % Row Count 13 (+ 2) % Row 9 \SetRowColor{white} \seqsplit{.closest} & find closest element \tn % Row Count 14 (+ 1) % Row 10 \SetRowColor{LightBackground} .find & find matching child element \tn % Row Count 15 (+ 1) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{x{2.48 cm} x{5.52 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{Action Commands}} \tn % Row 0 \SetRowColor{LightBackground} .click & click on an element \tn % Row Count 1 (+ 1) % Row 1 \SetRowColor{white} .dblclick & double click on an element \tn % Row Count 2 (+ 1) % Row 2 \SetRowColor{LightBackground} .rightclick & right click on an element \tn % Row Count 3 (+ 1) % Row 3 \SetRowColor{white} \seqsplit{.type("foobar")} & type "foobar" into an element \tn % Row Count 5 (+ 2) % Row 4 \SetRowColor{LightBackground} .clear & clear all text from an element \tn % Row Count 7 (+ 2) % Row 5 \SetRowColor{white} .check & check a checkbox or radio \tn % Row Count 8 (+ 1) % Row 6 \SetRowColor{LightBackground} .uncheck & uncheck a checkbox or radio \tn % Row Count 9 (+ 1) % Row 7 \SetRowColor{white} .focus & focus on an element \tn % Row Count 10 (+ 1) % Row 8 \SetRowColor{LightBackground} .blur & blur an element \tn % Row Count 11 (+ 1) % Row 9 \SetRowColor{white} .submit & submit a form. \tn % Row Count 12 (+ 1) % Row 10 \SetRowColor{LightBackground} \seqsplit{.trigger(''click")} & trigger any DOM event \tn % Row Count 14 (+ 2) % Row 11 \SetRowColor{white} .hover & hover over an element \{\{link="https://docs.cypress.io/api/commands/hover.html"\}\}(docs)\{\{/link\}\} \tn % Row Count 18 (+ 4) % Row 12 \SetRowColor{LightBackground} .select & select option from a dropdown menu \tn % Row Count 20 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}--} \SetRowColor{LightBackground} \mymulticolumn{2}{x{8.4cm}}{\seqsplit{https://docs.cypress.io/api/api/table-of-contents.html} \newline All commands are on the side bar under "Commands."} \tn \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{x{2.48 cm} x{5.52 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{Browser Commands}} \tn % Row 0 \SetRowColor{LightBackground} cy.visit & visit url \tn % Row Count 1 (+ 1) % Row 1 \SetRowColor{white} \seqsplit{cy.go("back")} & click on browser's "back" button \tn % Row Count 3 (+ 2) % Row 2 \SetRowColor{LightBackground} \seqsplit{cy.go("forward")} & click on browser's "forward" button \tn % Row Count 5 (+ 2) % Row 3 \SetRowColor{white} cy.reload & refresh the page \tn % Row Count 6 (+ 1) % Row 4 \SetRowColor{LightBackground} cy.viewport & change window size \tn % Row Count 7 (+ 1) % Row 5 \SetRowColor{white} cy.url & yeilds current url \tn % Row Count 8 (+ 1) % Row 6 \SetRowColor{LightBackground} cy.window & yeilds current window object \tn % Row Count 10 (+ 2) % Row 7 \SetRowColor{white} cy.title & yeilds document.title object \tn % Row Count 12 (+ 2) % Row 8 \SetRowColor{LightBackground} \seqsplit{.scrollIntoView} & scroll element into view \tn % Row Count 14 (+ 2) % Row 9 \SetRowColor{white} .scrollTo & scroll to position in the window \tn % Row Count 16 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} % That's all folks \end{multicols*} \end{document}