UNPKG

unexpected

Version:
429 lines (333 loc) 18.2 kB
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=0"> <link rel="stylesheet" href="../../../static/normalize.css" type="text/css" media="screen" /> <link rel="stylesheet" href="../../../static/main.css" type="text/css" media="screen" /> <link rel="shortcut icon" type="image/vnd.microsoft.icon" href="../../../static/bug-icon-black.ico"> <title>function - to call the callback</title> </head> <body class="sidebar-hidden has-sidebar"> <header> <div class="logo-icon"></div> <nav> <ul> <li class="menu-toggle-item"> <button class="menu-toggle" onclick="toggleSidebar()"></button> </li> <li class=""><a href="../../..">Unexpected</a></li> <li class="active"><a href="../../any/to-be">Assertions</a></li> <li class=""><a href="../../../api/addAssertion">API</a></li> <li class=""><a href="../../../plugins">Plugins</a></li> </ul> </nav> <div class="search" style="visibility: hidden"> <input id="search" placeholder="Search..." value=""> <div id="searchDropDown" class="dropDown"> <ul id="searchResults"></ul> </div> </div> </header> <section id="assertions"> <nav id="assertion-menu" class="sidebar js-remember-scroll-position"> <ul> <li> <h3>any</h3> <ul> <li class=""> <a href="../../any/to-be">to be</a> </li> <li class=""> <a href="../../any/to-be-a">to be a</a> </li> <li class=""> <a href="../../any/to-be-defined">to be defined</a> </li> <li class=""> <a href="../../any/to-be-falsy">to be falsy</a> </li> <li class=""> <a href="../../any/to-be-null">to be null</a> </li> <li class=""> <a href="../../any/to-be-ok">to be ok</a> </li> <li class=""> <a href="../../any/to-be-truthy">to be truthy</a> </li> <li class=""> <a href="../../any/to-be-undefined">to be undefined</a> </li> <li class=""> <a href="../../any/to-equal">to equal</a> </li> <li class=""> <a href="../../any/to-satisfy">to satisfy</a> </li> <li class=""> <a href="../../any/when-passed-as-parameter-to">when passed as parameter to</a> </li> </ul> </li> <li> <h3>string</h3> <ul> <li class=""> <a href="../../string/to-be">to be</a> </li> <li class=""> <a href="../../string/to-be-empty">to be empty</a> </li> <li class=""> <a href="../../string/to-be-greater-than">to be greater than</a> </li> <li class=""> <a href="../../string/to-be-greater-than-or-equal-to">to be greater than or equal to</a> </li> <li class=""> <a href="../../string/to-be-less-than">to be less than</a> </li> <li class=""> <a href="../../string/to-be-less-than-or-equal-to">to be less than or equal to</a> </li> <li class=""> <a href="../../string/to-be-non-empty">to be non-empty</a> </li> <li class=""> <a href="../../string/to-be-within">to be within</a> </li> <li class=""> <a href="../../string/to-begin-with">to begin with</a> </li> <li class=""> <a href="../../string/to-contain">to contain</a> </li> <li class=""> <a href="../../string/to-end-with">to end with</a> </li> <li class=""> <a href="../../string/to-have-length">to have length</a> </li> <li class=""> <a href="../../string/to-match">to match</a> </li> </ul> </li> <li> <h3>number</h3> <ul> <li class=""> <a href="../../number/to-be-close-to">to be close to</a> </li> <li class=""> <a href="../../number/to-be-finite">to be finite</a> </li> <li class=""> <a href="../../number/to-be-greater-than">to be greater than</a> </li> <li class=""> <a href="../../number/to-be-greater-than-or-equal-to">to be greater than or equal to</a> </li> <li class=""> <a href="../../number/to-be-infinite">to be infinite</a> </li> <li class=""> <a href="../../number/to-be-less-than">to be less than</a> </li> <li class=""> <a href="../../number/to-be-less-than-or-equal-to">to be less than or equal to</a> </li> <li class=""> <a href="../../number/to-be-NaN">to be NaN</a> </li> <li class=""> <a href="../../number/to-be-negative">to be negative</a> </li> <li class=""> <a href="../../number/to-be-positive">to be positive</a> </li> <li class=""> <a href="../../number/to-be-within">to be within</a> </li> </ul> </li> <li> <h3>boolean</h3> <ul> <li class=""> <a href="../../boolean/to-be-false">to be false</a> </li> <li class=""> <a href="../../boolean/to-be-true">to be true</a> </li> </ul> </li> <li> <h3>object</h3> <ul> <li class=""> <a href="../../object/to-be-canonical">to be canonical</a> </li> <li class=""> <a href="../../object/to-have-key">to have key</a> </li> <li class=""> <a href="../../object/to-have-keys">to have keys</a> </li> <li class=""> <a href="../../object/to-have-keys-satisfying">to have keys satisfying</a> </li> <li class=""> <a href="../../object/to-have-properties">to have properties</a> </li> <li class=""> <a href="../../object/to-have-property">to have property</a> </li> <li class=""> <a href="../../object/to-have-values-satisfying">to have values satisfying</a> </li> </ul> </li> <li> <h3>function</h3> <ul> <li class="active"> <a href="">to call the callback</a> </li> <li class=""> <a href="../to-call-the-callback-with-error">to call the callback with error</a> </li> <li class=""> <a href="../to-call-the-callback-without-error">to call the callback without error</a> </li> <li class=""> <a href="../to-error">to error</a> </li> <li class=""> <a href="../to-have-arity">to have arity</a> </li> <li class=""> <a href="../to-throw">to throw</a> </li> </ul> </li> <li> <h3>Promise</h3> <ul> <li class=""> <a href="../../Promise/to-be-fulfilled">to be fulfilled</a> </li> <li class=""> <a href="../../Promise/to-be-rejected">to be rejected</a> </li> <li class=""> <a href="../../Promise/when-fulfilled">when fulfilled</a> </li> <li class=""> <a href="../../Promise/when-rejected">when rejected</a> </li> </ul> </li> <li> <h3>Error</h3> <ul> <li class=""> <a href="../../Error/to-have-message">to have message</a> </li> </ul> </li> <li> <h3>array-like</h3> <ul> <li class=""> <a href="../../array-like/to-be-empty">to be empty</a> </li> <li class=""> <a href="../../array-like/to-be-non-empty">to be non-empty</a> </li> <li class=""> <a href="../../array-like/to-contain">to contain</a> </li> <li class=""> <a href="../../array-like/to-have-items-satisfying">to have items satisfying</a> </li> <li class=""> <a href="../../array-like/to-have-length">to have length</a> </li> <li class=""> <a href="../../array-like/when-passed-as-parameters-to">when passed as parameters to</a> </li> </ul> </li> <li> <h3>Buffer</h3> <ul> <li class=""> <a href="../../Buffer/when-decoded-as">when decoded as</a> </li> </ul> </li> </ul> </nav> <div class="main" tabindex="-1"> <div class="content"> <h1>to call the callback</h1> <p>Asserts that a node.js-style asynchronous function taking a single callback will call it.</p> <div class="code lang-javascript"> <div><span style="color: #a71d5d">function</span>&nbsp;<span style="color: #000000">mySuccessfulAsyncFunction</span><span style="color: #000000">(</span>cb<span style="color: #000000">)</span>&nbsp;<span style="color: #000000">{</span></div> <div>&nbsp;&nbsp;&nbsp;&nbsp;<span style="color: #000000">setTimeout</span><span style="color: #000000">(</span><span style="color: #a71d5d">function</span>&nbsp;<span style="color: #000000">()</span>&nbsp;<span style="color: #000000">{</span></div> <div>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<span style="color: #000000">cb</span><span style="color: #000000">();</span></div> <div>&nbsp;&nbsp;&nbsp;&nbsp;<span style="color: #000000">});</span></div> <div><span style="color: #000000">}</span></div> <div>&nbsp;</div> <div><span style="color: #a71d5d">return</span>&nbsp;<span style="color: #000000">expect</span><span style="color: #000000">(</span>mySuccessfulAsyncFunction<span style="color: #000000">,</span>&nbsp;<span style="color: #df5000">'to&nbsp;call&nbsp;the&nbsp;callback'</span><span style="color: #000000">);</span></div> </div><p>If the callback is never called, it will hang until your test framework marks it as timed out. So the assertion itself only ever fails if the function throws an exception synchronously:</p> <div class="code lang-javascript"> <div><span style="color: #a71d5d">function</span>&nbsp;<span style="color: #000000">errorOut</span><span style="color: #000000">(</span>cb<span style="color: #000000">)</span>&nbsp;<span style="color: #000000">{</span></div> <div>&nbsp;&nbsp;&nbsp;&nbsp;<span style="color: #a71d5d">throw</span>&nbsp;<span style="color: #a71d5d">new</span>&nbsp;Error<span style="color: #000000">(</span><span style="color: #df5000">'ugh'</span><span style="color: #000000">);</span></div> <div><span style="color: #000000">}</span></div> <div><span style="color: #a71d5d">return</span>&nbsp;<span style="color: #000000">expect</span><span style="color: #000000">(</span>errorOut<span style="color: #000000">,</span>&nbsp;<span style="color: #df5000">'to&nbsp;call&nbsp;the&nbsp;callback'</span><span style="color: #000000">);</span></div> </div><div class="output"> <div><span style="color: red; font-weight: bold">ugh</span></div> </div><p>The assertion will pass even if the function passes an error to the callback. If you want that case to fail, look into the <a href="/assertions/function/to-call-the-callback-without-error/">to call the callback without error</a> assertion.</p> <p>If you want the parameters passed to the callback to be the subject of further assertions, you might be able to use the <a href="/assertions/array-like/when-passed-as-parameters-to/">when passed as parameters to</a> assertion.</p> <p>The parameters passed to the callback are also provided as the value of the returned promise, so you can do further assertions like this:</p> <div class="code lang-javascript"> <div><span style="color: #a71d5d">function</span>&nbsp;<span style="color: #000000">asyncFn</span><span style="color: #000000">(</span>cb<span style="color: #000000">)</span>&nbsp;<span style="color: #000000">{</span></div> <div>&nbsp;&nbsp;&nbsp;&nbsp;<span style="color: #000000">setTimeout</span><span style="color: #000000">(</span><span style="color: #a71d5d">function</span>&nbsp;<span style="color: #000000">()</span>&nbsp;<span style="color: #000000">{</span></div> <div>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<span style="color: #000000">cb</span><span style="color: #000000">(</span><span style="color: #a71d5d">null</span><span style="color: #000000">,</span>&nbsp;<span style="color: #df5000">'foo'</span><span style="color: #000000">);</span></div> <div>&nbsp;&nbsp;&nbsp;&nbsp;<span style="color: #000000">});</span></div> <div><span style="color: #000000">}</span></div> </div><div class="code lang-javascript"> <div><span style="color: #a71d5d">return</span>&nbsp;<span style="color: #000000">expect</span><span style="color: #000000">(</span>asyncFn<span style="color: #000000">,</span>&nbsp;<span style="color: #df5000">'to&nbsp;call&nbsp;the&nbsp;callback'</span><span style="color: #000000">).</span><span style="color: #000000">then</span><span style="color: #000000">(</span><span style="color: #a71d5d">function</span>&nbsp;<span style="color: #000000">(</span>args<span style="color: #000000">)</span>&nbsp;<span style="color: #000000">{</span></div> <div>&nbsp;&nbsp;&nbsp;<span style="color: #969896">&nbsp;//&nbsp;args&nbsp;will&nbsp;be&nbsp;[null,&nbsp;'foo'];</span></div> <div><span style="color: #000000">});</span></div> </div><p>Or using the Bluebird-specific <code>.spread</code> extension:</p> <div class="code lang-javascript"> <div><span style="color: #a71d5d">return</span>&nbsp;<span style="color: #000000">expect</span><span style="color: #000000">(</span>asyncFn<span style="color: #000000">,</span>&nbsp;<span style="color: #df5000">'to&nbsp;call&nbsp;the&nbsp;callback'</span><span style="color: #000000">).</span><span style="color: #000000">spread</span><span style="color: #000000">(</span><span style="color: #a71d5d">function</span>&nbsp;<span style="color: #000000">(</span>err<span style="color: #000000">,</span>&nbsp;result<span style="color: #000000">)</span>&nbsp;<span style="color: #000000">{</span></div> <div>&nbsp;&nbsp;&nbsp;<span style="color: #969896">&nbsp;//&nbsp;err&nbsp;will&nbsp;be&nbsp;null</span></div> <div>&nbsp;&nbsp;&nbsp;<span style="color: #969896">&nbsp;//&nbsp;result&nbsp;will&nbsp;be&nbsp;'foo'</span></div> <div><span style="color: #000000">});</span></div> </div> </div> </div> </section> <script type="text/javascript"> baseUrl = '../../..'; </script> <script type="text/javascript" src="../../../static/toggleSidebar.js"></script> <script type="text/javascript" src="../../../static/rememberScrollPosition.js"></script> <script type="text/javascript" src="../../../static/focusMain.js"></script> <script type="text/javascript" src="../../../static/search.js"></script> </body> </html>