turning nightwatch.js test (using jquery function) into custom assertion or command -


i running jquery function many times through test suite in order validate whether elements visible in viewport (nightwatch's current commands visible, present, etc not factor in). seems valuable have reusable command or assertion, fighting uphill battle understand how translate current code new reusable code, , have spent many hours trying different things.

i have other custom commands work well, not work on validating result of function, perform repeatable commands. leads me believe should custom assertion? documentation on custom assertions sparse, , has not helped me in piecing own custom assertion.

this run in test files:

browser.execute(function () {       $.fn.isonscreen = function(){         var win = $(window);         var viewport = {             top : win.scrolltop(),             left : win.scrollleft()         };         viewport.right = viewport.left + win.width();         viewport.bottom = viewport.top + win.height();         var bounds = this.offset();         bounds.right = bounds.left + this.outerwidth();         bounds.bottom = bounds.top + this.outerheight();         return (!(viewport.right < bounds.left || viewport.left > bounds.right || viewport.bottom < bounds.top || viewport.top > bounds.bottom));     };       return {           search: $('.search').isonscreen(),           header: $('.gateway-header').isonscreen()       };     }, function (result) {         browser.verify.equal(result.value.search, false);         browser.verify.equal(result.value.header, false);     }); 

so custom command/assertion need able call isonscreen() , validate whether or not returns true or false. seems simple? can me understand how go this? appreciated.

you can create custom command achieve that:

  module.exports.command = function(options, callback) {     var = this;         .execute(function () {       $.fn.isonscreen = function(){         var win = $(window);         var viewport = {             top : win.scrolltop(),             left : win.scrollleft()         };         viewport.right = viewport.left + win.width();         viewport.bottom = viewport.top + win.height();         var bounds = this.offset();         bounds.right = bounds.left + this.outerwidth();         bounds.bottom = bounds.top + this.outerheight();         return (!(viewport.right < bounds.left || viewport.left > bounds.right || viewport.bottom < bounds.top || viewport.top > bounds.bottom));       };        var result = [];       options.foreach( function(element, index) {           result.push($(element).isonscreen());       });        return result;      }, function (result) {          result.value.foreach( function(element, index) {             that.verify.equal(element, false)         });     });   }; 

and can call this:

client.verifyifisonscreen(['.search', '.gateway-header']) 

Comments

Popular posts from this blog

wordpress - (T_ENDFOREACH) php error -

Export Excel workseet into txt file using vba - (text and numbers with formulas) -

Using django-mptt to get only the categories that have items -