/// context('Utilities', () => { beforeEach(() => { cy.visit('https://example.cypress.io/utilities') }) it('Cypress._ - call a lodash method', () => { // https://on.cypress.io/_ cy.request('https://jsonplaceholder.cypress.io/users') .then((response) => { let ids = Cypress._.chain(response.body).map('id').take(3).value() expect(ids).to.deep.eq([1, 2, 3]) }) }) it('Cypress.$ - call a jQuery method', () => { // https://on.cypress.io/$ let $li = Cypress.$('.utility-jquery li:first') cy.wrap($li) .should('not.have.class', 'active') .click() .should('have.class', 'active') }) it('Cypress.Blob - blob utilities and base64 string conversion', () => { // https://on.cypress.io/blob cy.get('.utility-blob').then(($div) => // https://github.com/nolanlawson/blob-util#imgSrcToDataURL // get the dataUrl string for the javascript-logo Cypress.Blob.imgSrcToDataURL('https://example.cypress.io/assets/img/javascript-logo.png', undefined, 'anonymous') .then((dataUrl) => { // create an element and set its src to the dataUrl let img = Cypress.$('', { src: dataUrl }) // need to explicitly return cy here since we are initially returning // the Cypress.Blob.imgSrcToDataURL promise to our test // append the image $div.append(img) cy.get('.utility-blob img').click() .should('have.attr', 'src', dataUrl) })) }) it('Cypress.minimatch - test out glob patterns against strings', () => { // https://on.cypress.io/minimatch let matching = Cypress.minimatch('/users/1/comments', '/users/*/comments', { matchBase: true, }) expect(matching, 'matching wildcard').to.be.true matching = Cypress.minimatch('/users/1/comments/2', '/users/*/comments', { matchBase: true, }) expect(matching, 'comments').to.be.false // ** matches against all downstream path segments matching = Cypress.minimatch('/foo/bar/baz/123/quux?a=b&c=2', '/foo/**', { matchBase: true, }) expect(matching, 'comments').to.be.true // whereas * matches only the next path segment matching = Cypress.minimatch('/foo/bar/baz/123/quux?a=b&c=2', '/foo/*', { matchBase: false, }) expect(matching, 'comments').to.be.false }) it('Cypress.moment() - format or parse dates using a moment method', () => { // https://on.cypress.io/moment const time = Cypress.moment().utc('2014-04-25T19:38:53.196Z').format('h:mm A') expect(time).to.be.a('string') cy.get('.utility-moment').contains('3:38 PM') .should('have.class', 'badge') // the time in the element should be between 3pm and 5pm const start = Cypress.moment('3:00 PM', 'LT') const end = Cypress.moment('5:00 PM', 'LT') cy.get('.utility-moment .badge') .should(($el) => { // parse American time like "3:38 PM" const m = Cypress.moment($el.text().trim(), 'LT') // display hours + minutes + AM|PM const f = 'h:mm A' expect(m.isBetween(start, end), `${m.format(f)} should be between ${start.format(f)} and ${end.format(f)}`).to.be.true }) }) it('Cypress.Promise - instantiate a bluebird promise', () => { // https://on.cypress.io/promise let waited = false /** * @return Bluebird */ function waitOneSecond () { // return a promise that resolves after 1 second // @ts-ignore TS2351 (new Cypress.Promise) return new Cypress.Promise((resolve, reject) => { setTimeout(() => { // set waited to true waited = true // resolve with 'foo' string resolve('foo') }, 1000) }) } cy.then(() => // return a promise to cy.then() that // is awaited until it resolves // @ts-ignore TS7006 waitOneSecond().then((str) => { expect(str).to.eq('foo') expect(waited).to.be.true })) }) })